| <!DOCTYPE html> |
| <html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en"> |
| <head> |
| <meta charset="utf-8" /> |
| <meta name="generator" content="pandoc" /> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" /> |
| <title>Release Notes for STM32G4xx HAL Drivers</title> |
| <style> |
| code{white-space: pre-wrap;} |
| span.smallcaps{font-variant: small-caps;} |
| span.underline{text-decoration: underline;} |
| div.column{display: inline-block; vertical-align: top; width: 50%;} |
| div.hanging-indent{margin-left: 1.5em; text-indent: -1.5em;} |
| ul.task-list{list-style: none;} |
| .display.math{display: block; text-align: center; margin: 0.5rem auto;} |
| </style> |
| <link rel="stylesheet" href="_htmresc/mini-st.css" /> |
| <!--[if lt IE 9]> |
| <script src="//cdnjs.cloudflare.com/ajax/libs/html5shiv/3.7.3/html5shiv-printshiv.min.js"></script> |
| <![endif]--> |
| <link rel="icon" type="image/x-icon" href="_htmresc/favicon.png" /> |
| </head> |
| <body> |
| <div class="row"> |
| <div class="col-sm-12 col-lg-4"> |
| <center> |
| <h1 id="release-notes-for-stm32g4xx-hal-drivers"><small>Release Notes for</small> STM32G4xx HAL Drivers</h1> |
| <p>Copyright © 2019 STMicroelectronics<br /> |
| </p> |
| <a href="https://www.st.com" class="logo"><img src="_htmresc/st_logo.png" alt="ST logo" /></a> |
| </center> |
| <h1 id="purpose">Purpose</h1> |
| <p>The STM32Cube HAL and LL, an STM32 abstraction layer embedded software, ensure maximized portability across STM32 portfolio.</p> |
| <p>The Portable APIs layer provides a generic, multi instanced and simple set of APIs to interact with the upper layer (application, libraries and stacks). It is composed of native and extended APIs set. It is directly built around a generic architecture and allows the build-upon layers, like the middleware layer, to implement its functions without knowing in-depth the used STM32 device. This improves the library code reusability and guarantees an easy portability on other devices and STM32 families.</p> |
| <p>The Low Layer (LL) drivers are part of the STM32Cube firmware HAL that provide basic set of optimized and one shot services. The Low layer drivers, contrary to the HAL ones are not Fully Portable across the STM32 families; the availability of some functions depend on the physical availability of the relative features on the product. The Low Layer (LL) drivers are designed to offer the following features:</p> |
| <ul> |
| <li>New set of inline function for direct and atomic register access</li> |
| <li>One-shot operations that can be used by the HAL drivers or from application level.</li> |
| <li>Fully Independent from HAL and can be used in standalone usage (without HAL drivers)</li> |
| <li>Full features coverage of the all the supported peripherals.</li> |
| </ul> |
| </div> |
| <section id="update-history" class="col-sm-12 col-lg-8"> |
| <h1>Update History</h1> |
| <div class="collapse"> |
| <input type="checkbox" id="collapse-section8" checked aria-hidden="true"> <label for="collapse-section8" aria-hidden="true">V1.2.4 / 05-June-2024</label> |
| <div> |
| <h2 id="main-changes">Main Changes</h2> |
| <h3 id="maintenance-release">Maintenance Release</h3> |
| <ul> |
| <li><p>Add support of <strong>STM32G414xx</strong> devices.</p></li> |
| <li><p>General updates to fix known defects and enhancements implementation.</p></li> |
| <li><p><strong>HAL DAC</strong> update</p> |
| <ul> |
| <li>Update HAL_DACEx_SelfCalibrate() API to manage case of calibration factor equal to range maximum value.</li> |
| </ul></li> |
| <li><p><strong>HAL CORTEX</strong> update</p> |
| <ul> |
| <li>Update HAL_MPU_ConfigRegion() API to allow the configuration of the MPU registers independently of the value of Enable/Disable field.</li> |
| <li>Add new HAL_MPU_EnableRegion() / HAL_MPU_DisableRegion() APIs.</li> |
| </ul></li> |
| <li><p><strong>HAL QSPI</strong> update</p> |
| <ul> |
| <li>Clear AR register after CCR to avoid new transfer when address is not needed.</li> |
| </ul></li> |
| <li><p><strong>HAL I2C</strong> update</p> |
| <ul> |
| <li>Code quality enhancement MISRA-C 2012 Rule-13.5 within the HAL_I2C_Master_Abort_IT() API: |
| <ul> |
| <li>Add a temporary variable to get the value to check before comparison.</li> |
| </ul></li> |
| <li>Add abort memory management to HAL_I2C_Master_Abort_IT() API.</li> |
| <li>Move the prefetch process in HAL_I2C_Slave_Transmit() API.</li> |
| </ul></li> |
| <li><p><strong>HAL SPI</strong> update</p> |
| <ul> |
| <li>HAL code quality enhancement for MISRA-C Rule-8.13 by adding const qualifiers..</li> |
| </ul></li> |
| <li><p><strong>HAL/LL TIM</strong> update</p> |
| <ul> |
| <li>Fixed typo in PWM asymmetric mode related constants.</li> |
| </ul></li> |
| <li><p><strong>HAL UART</strong> update</p> |
| <ul> |
| <li>Add HAL_UART_RXEVENT_IDLE event notification to user in case of HAL_UARTEx_ReceiveToIdle_DMA() use with Circular DMA, even if occurring just after TC event.</li> |
| <li>Align prescaler value used by default in UART_GET_DIV_FACTOR macro with RM.</li> |
| <li>Correct wrong comment in HAL_UARTEx_DisableFifoMode() API.</li> |
| <li>Ensure UART Rx buffer is not written beyond boundaries in case of RX FIFO reception in Interrupt mode.</li> |
| </ul></li> |
| <li><p><strong>HAL USART</strong> update</p> |
| <ul> |
| <li>Align prescaler value used by default in USART_GET_DIV_FACTOR macro with RM.</li> |
| <li>Correct wrong comment in HAL_USARTEx_DisableFifoMode() API.</li> |
| <li>Improve the visibility of the SPI mode support in HAL USART description.</li> |
| </ul></li> |
| <li><p><strong>HAL CRYP</strong> update</p> |
| <ul> |
| <li>Code quality enhancement MISRA-C 2012 Rule-10.4 within HAL_CRYP_IRQHandler() API.</li> |
| </ul></li> |
| <li><p><strong>HAL FDCAN</strong> update</p> |
| <ul> |
| <li>HAL code quality enhancement for MISRA-C Rule-8.13 by adding const qualifiers.</li> |
| </ul></li> |
| <li><p><strong>LL BUS</strong> update</p> |
| <ul> |
| <li>Update macro definition LL_AHB2_GRP1_PERIPH_CCM.</li> |
| </ul></li> |
| <li><p><strong>LL LPUART</strong> update</p> |
| <ul> |
| <li>Add LL_LPUART_RequestTxDataFlush() API allowing TX FIFO flush request.</li> |
| </ul></li> |
| <li><p><strong>LL UCPD</strong> update</p> |
| <ul> |
| <li>HAL code quality enhancement for MISRA-C Rule-8.13 by adding const qualifiers.</li> |
| <li>Fix typo in Doxygen sections.</li> |
| </ul></li> |
| </ul> |
| <h2 id="development-toolchains-and-compilers">Development Toolchains and Compilers</h2> |
| <ul> |
| <li>IAR Embedded Workbench for ARM (EWARM) toolchain <strong>V8.50.9</strong> + ST-LINKV2</li> |
| <li>RealView Microcontroller Development Kit (MDK-ARM) toolchain <strong>V5.38</strong> + ST-LINKV2</li> |
| <li>STM32CubeIDE toolchain (gcc9_2020_q2_update) <strong>V1.14.0</strong></li> |
| </ul> |
| <h2 id="supported-devices">Supported Devices</h2> |
| <ul> |
| <li>STM32G431xx/41xx</li> |
| <li>STM32G471xx</li> |
| <li><strong>STM32G414</strong>/73/83xx</li> |
| <li>STM32G474/84xx</li> |
| <li>STM32G491/A1xx</li> |
| </ul> |
| </div> |
| </div> |
| <div class="collapse"> |
| <input type="checkbox" id="collapse-section7" aria-hidden="true"> <label for="collapse-section7" aria-hidden="true">V1.2.3 / 15-December-2023</label> |
| <div> |
| <h2 id="main-changes-1">Main Changes</h2> |
| <h3 id="maintenance-release-1">Maintenance Release</h3> |
| <ul> |
| <li>HAL code quality enhancement for MISRA-C Rule-8.13 by adding const qualifiers.</li> |
| <li><strong>HAL Generic</strong> update |
| <ul> |
| <li>Add implementation of utility APIs HAL_GetUIDw0, HAL_GetUIDw1 and HAL_GetUIDw2.</li> |
| <li>Allow redefinition of macro UNUSED(x).</li> |
| <li>Update of HAL_GetTickFreq() brief.</li> |
| </ul></li> |
| <li><strong>HAL/LL ADC</strong> update |
| <ul> |
| <li>Add “ADC_CHANNEL_0” in IS_ADC_CHANNEL() macro.</li> |
| <li>Add helper macro to convert data from differential mode.</li> |
| <li>Remove useless action of conversion trigger change in function LL_ADC_DeInit(); Moreover; this action was not compliant with ADC enable state (cf reference manual).</li> |
| </ul></li> |
| <li><strong>HAL/LL TIM</strong> update |
| <ul> |
| <li>Manage configuration of the Capture/compare DMA request source: |
| <ul> |
| <li>Add related new exported constants (TIM_CCDMAREQUEST_CC, TIM_CCDMAREQUEST_UPDATE).</li> |
| <li>Create a new macro __HAL_TIM_SELECT_CCDMAREQUEST() allowing to program the TIMx_CR2.CCDS bitfield.</li> |
| </ul></li> |
| <li>Remove useless definition of macro IS_TIM_INTERNAL_TRIGGEREVENT_SELECTION.</li> |
| <li>Improve driver robustness against wrong period values.</li> |
| <li>Improve driver robustness against wrong DMA related parameters.</li> |
| <li>Improve period configuration parameter check.</li> |
| <li>Minor typo correction in hal_tim header file.</li> |
| <li>Update __LL_TIM_CALC_PSC() macro to round up the evaluated value when the fractional part of the division is greater than 0.5.</li> |
| <li>Remove useless check on IS_TIM_ADVANCED_INSTANCE() within LL_TIM_BDTR_Init() to fix Break Filter configuration problem with specific TIM instances.</li> |
| <li>Update LL_TIM_DisableBreakInputSource() and LL_TIM_SetBreakInputSourcePolarity() APIs description.</li> |
| <li>Remove lock management from callback management functions.</li> |
| <li>Remove multiple volatile reads or writes in interrupt handler for better performance.</li> |
| <li>Improve HAL TIM driver’s operational behavior.</li> |
| <li>Assert check for the right channels.</li> |
| <li>Fix typo in PWM symmetric mode related constants names.</li> |
| <li>Remove unnecessary change of MOE bitfield in LL_TIM_BDTR_Init().</li> |
| </ul></li> |
| <li><strong>HAL/LL LPTIM</strong> update |
| <ul> |
| <li>Improve LPTIM FSM management consistency.</li> |
| <li>Apply same naming rules to clear FLAG related functions.</li> |
| <li>Remove Lock management from callback management functions.</li> |
| <li>Remove redundant IS_LPTIM_AUTORELOAD macro.</li> |
| </ul></li> |
| <li><strong>HAL/LL RCC</strong> update |
| <ul> |
| <li>Add uint32_t cast to shift left operands constants defined with ‘U’ suffix in case MISRAC2012-Rule-12.2 violated.</li> |
| <li>Wait PLL1RDY to be off before clearing PLL1 source.</li> |
| <li>Set RCC_CRS_HSI48CALIBRATION_DEFAULT to 0x40 to be consistent with REFMAN and LL CRS driver.</li> |
| <li>Fix wrong RCC_APB1ENR1_WWDG2EN bit referenced in __HAL_RCC_WWDG_CLK_DISABLE() macro.</li> |
| <li>Modify the comment in PLL configuration.</li> |
| </ul></li> |
| <li><strong>HAL CORTEX</strong> update |
| <ul> |
| <li>Updated HAL_MPU_ConfigRegion() to allow the configuration of the MPU registers independently of the value of Enable/Disable field.</li> |
| <li>Add new APIs HAL_MPU_EnableRegion() / HAL_MPU_DisableRegion().</li> |
| </ul></li> |
| <li><strong>HAL DAC</strong> update |
| <ul> |
| <li>Fix incorrect word ‘surcharged’ in functions headers.</li> |
| <li>Updated DAC buffer calibration according to RM.</li> |
| <li>Fix HAL_GetTick() timeout vulnerability.</li> |
| </ul></li> |
| <li><strong>HAL EXTI</strong> update |
| <ul> |
| <li>Fix computation of pExtiConfig->GPIOSel in HAL_EXTI_GetConfigLine().</li> |
| <li>Fix the wrong references in the “How to use this driver” section.</li> |
| </ul></li> |
| <li><strong>HAL CORDIC</strong> update |
| <ul> |
| <li>Fix incorrect word ‘surcharged’ in functions headers.</li> |
| </ul></li> |
| <li><strong>HAL FMAC</strong> update |
| <ul> |
| <li>Avoid usage of magic numbers.</li> |
| <li>Fix incorrect word ‘surcharged’ in functions headers.</li> |
| </ul></li> |
| <li><strong>HAL/LL HRTIM</strong> update |
| <ul> |
| <li>Rework HAL_HRTIM_Get…() getter functions not to change the handle state in case input parameter is out-of-range.</li> |
| <li>Add a right shift of the read bit field in LL_HRTIM_FLT_GetResetMode() before returning the result.</li> |
| <li>Fix erroneous fault counter threshold configuration function.</li> |
| <li>Fix typo in LL_HRTIM_FLT_ResetCounter() API header.</li> |
| </ul></li> |
| <li><strong>HAL RTC</strong> update |
| <ul> |
| <li>Check if the RTC calendar has been previously initialized before entering Initialization mode.</li> |
| <li>Optimize the way RSF flag is cleared in HAL_RTC_WaitForSynchro().</li> |
| <li>Correct misleading note about shadow registers.</li> |
| </ul></li> |
| <li><strong>HAL FMC</strong> update |
| <ul> |
| <li>Fix Hardfault issues when executing NOR read operations caused by FMC_WRITE_OPERATION_DISABLE.</li> |
| </ul></li> |
| <li><strong>HAL CRYP</strong> update |
| <ul> |
| <li>Mask arrays are declared as static const.</li> |
| <li>Update Crypt/Decrypt IT processes to avoid Computation Completed IRQ fires before the DINR pointer increment.</li> |
| <li>Update AES GCM in interrupt mode to avoid Computation Completed IRQ fires before the DINR pointer increment.</li> |
| </ul></li> |
| <li><strong>HAL FLASH</strong> update |
| <ul> |
| <li>Update the hal_flash_ex.c file to correctly support the PB4_PUPEN Option.</li> |
| <li>Fix FLASH_PAGE_NB value for STM32G4 category 3 devices.</li> |
| </ul></li> |
| <li><strong>HAL CRC</strong> update |
| <ul> |
| <li>Add filter in HAL_CRCEx_Polynomial_Set() to exclude even polynomials.</li> |
| </ul></li> |
| <li><strong>HAL QSPI</strong> update |
| <ul> |
| <li>Update HAL_QSPI_Abort() and HAL_QSPI_Abort_IT() APIs to check on QSPI BUSY flag status before executing the abort procedure.</li> |
| <li>Fix incorrect word ‘surcharged’ in functions headers.</li> |
| </ul></li> |
| <li><strong>HAL SMBUS</strong> update |
| <ul> |
| <li>Remove Lock management from callback management functions.</li> |
| <li>Update HAL SMBUS driver to prefetch data before starting the transmission: implementation of errata sheet workaround I2C2-190208 : Transmission stalled after first byte.</li> |
| <li>Update SMBUS_ITErrorHandler to flash TXDR just in case of error.</li> |
| </ul></li> |
| <li><strong>HAL UART</strong> update |
| <ul> |
| <li>Add a new API HAL_UARTEx_GetRxEventType that could be used to retrieve the type of event that has led the RxEventCallback execution.</li> |
| <li>Remove of HAL_LOCK/HAL_UNLOCK calls in HAL UART Tx and Rx APIs.</li> |
| <li>Remove __HAL_LOCK() from HAL_xxx_RegisterCallback()/HAL_xxx_UnRegisterCallback().</li> |
| <li>Disable the Receiver Timeout Interrupt when data reception is completed.</li> |
| <li>Rework of UART_WaitOnFlagUntilTimeout() API to avoid being stuck forever when UART overrun error occurs and to enhance behavior.</li> |
| <li>Update initialisation sequence for TXINV, RXINV and TXRXSWAP settings.</li> |
| <li>Fix incorrect gState check in HAL_UART_RegisterRxEventCallback/HAL_UART_UnRegisterRxEventCallback to allow user Rx Event Callback registration when a transmit is ongoing.</li> |
| <li>Avoid RTOF flag to be cleared by a transmit process in polling mode.</li> |
| </ul></li> |
| <li><strong>HAL SMARTCARD</strong> update |
| <ul> |
| <li>Remove __HAL_LOCK() from HAL_xxx_RegisterCallback()/HAL_xxx_UnRegisterCallback().</li> |
| </ul></li> |
| <li><strong>HAL SPI</strong> update |
| <ul> |
| <li>Fix driver to don’t update state in case of error (HAL_SPI_STATE_READY will be set only in case of HAL_TIMEOUT).</li> |
| <li>Update HAL_SPI_TransmitReceive API to set the bit CRCNEXT in case of one byte transaction.</li> |
| <li>Update IT API to enable interrupts after process unlock.</li> |
| </ul></li> |
| <li><strong>HAL IRDA</strong> update |
| <ul> |
| <li>Remove __HAL_LOCK() from HAL_xxx_RegisterCallback()/HAL_xxx_UnRegisterCallback().</li> |
| </ul></li> |
| <li><strong>HAL FDCAN</strong> update |
| <ul> |
| <li>Refine description of IsFilterMatchingFrame and FilterIndex, members of structure FDCAN_RxHeaderTypeDef.</li> |
| <li>Fix GetIndex issue in HAL_FDCAN_GetRxMessage.</li> |
| <li>Modify misleading DataLength values.</li> |
| </ul></li> |
| <li><strong>HAL SAI</strong> update |
| <ul> |
| <li>Avoid using magic numbers.</li> |
| <li>Fix misalignment between reference manual and HAL SAI driver: remove GCR register.</li> |
| <li>Improve audio quality (avoid potential glitch).</li> |
| <li>Fix incorrect word ‘surcharged’.</li> |
| </ul></li> |
| <li><strong>HAL USART</strong> update |
| <ul> |
| <li>Remove __HAL_LOCK() from HAL_xxx_RegisterCallback()/HAL_xxx_UnRegisterCallback().</li> |
| </ul></li> |
| <li><strong>HAL/LL I2C</strong> update |
| <ul> |
| <li>Move polling code of HAL memory interface through interrupt management to prevent timeout issue using HAL MEM interface through FreeRTOS.</li> |
| <li>Update I2C_IsErrorOccurred to return error if timeout is detected.</li> |
| <li>Clear the ADDRF flag only when direction is confirmed as changed, to prevent that the ADDRF flag is cleared too early when the restart is received.</li> |
| <li>Remove Lock management from callback management functions.</li> |
| <li>Duplicate the test condition after timeout detection to avoid false timeout detection.</li> |
| <li>Update HAL_I2C_IsDeviceReady() API to support 10_bit addressing mode: Update done on the macro I2C_GENERATE_START.</li> |
| <li>Update HAL I2C driver to prefetch data before starting the transmission: implementation of errata sheet workaround I2C2-190208 : Transmission stalled after first byte.</li> |
| <li>Update HAL I2C driver to disable all interrupts after end of transaction.</li> |
| <li>Update HAL_I2C_Init API to clear ADD10 bit in 7 bit addressing mode.</li> |
| <li>Solve Slave No stretch not functional by using HAL Slave interface.</li> |
| <li>Update HAL_I2C_Mem_Write_IT API to initialize XferSize at 0.</li> |
| <li>Update I2C_Slave_ISR_IT, I2C_Slave_ISR_DMA and I2C_ITSlaveCplt to prevent the call of HAL_I2C_ListenCpltCallback twice.</li> |
| <li>Update I2C_WaitOnRXNEFlagUntilTimeout to check I2C_FLAG_AF independently from I2C_FLAG_RXNE.</li> |
| <li>Remove the unusable code in function HAL_I2C_IsDeviceReady.</li> |
| <li>Update I2C_WaitOnFlagUntilTimeout to handle error case.</li> |
| <li>Update HAL_I2C_Slave_Transmit to check if the received NACK is the good one.</li> |
| <li>Update LL_I2C_HandleTranfer function to prevent undefined behavior of volatile usage before updating the CR2 register.</li> |
| </ul></li> |
| <li><strong>LL UCPD</strong> update |
| <ul> |
| <li>Correct register accessed by LL_UCPD_ReadRxPaySize() function.</li> |
| </ul></li> |
| <li><strong>HAL USB</strong> update |
| <ul> |
| <li>Add new function HAL_PCD_EP_Abort() to abort current USB endpoint transfer.</li> |
| <li>PCD: add supporting multi packets transfer on Interrupt endpoint.</li> |
| <li>PCD: software correction added to avoid unexpected STALL condition during EP0 multi packet OUT transfer.</li> |
| <li>Set DCD timeout to a minimum of 300ms before starting BCD primary detection process.</li> |
| <li>hal_pcd.h: add a mask for USB RX bytes count.</li> |
| </ul></li> |
| <li><strong>LL UTILS</strong> update |
| <ul> |
| <li>Align UTILS_PLLVCO_INPUT_MAX value with documentation.</li> |
| <li>Update the number of LATENCY to be coherent with the reference manual.</li> |
| <li>Update package type definitions to be aligned with RM0440.</li> |
| <li>Fix a condition in LL_SetFlashLatency() API to avoid generation of Rule-10.1_R2 warning.</li> |
| <li>Add else statement in the end of LL_SetFlashLatency API to avoid Misra-C 2012 Rule-15.7 warnings.</li> |
| <li>Fix a note about Ticks parameter.</li> |
| </ul></li> |
| </ul> |
| <h2 id="development-toolchains-and-compilers-1">Development Toolchains and Compilers</h2> |
| <ul> |
| <li>IAR Embedded Workbench for ARM (EWARM) toolchain <strong>V8.50.9</strong> + ST-LINKV2</li> |
| <li>RealView Microcontroller Development Kit (MDK-ARM) toolchain <strong>V5.38</strong> + ST-LINKV2</li> |
| <li>STM32CubeIDE toolchain (gcc9_2020_q2_update) <strong>V1.14.0</strong></li> |
| </ul> |
| <h2 id="supported-devices-1">Supported Devices</h2> |
| <ul> |
| <li>STM32G431/41xx</li> |
| <li>STM32G471xx</li> |
| <li>STM32G473/83xx</li> |
| <li>STM32G474/84xx</li> |
| <li>STM32G491/A1xx</li> |
| </ul> |
| </div> |
| </div> |
| <div class="collapse"> |
| <input type="checkbox" id="collapse-section6" aria-hidden="true"> <label for="collapse-section6" aria-hidden="true">V1.2.2 / 10-November-2021</label> |
| <div> |
| <h2 id="main-changes-2">Main Changes</h2> |
| <h3 id="maintenance-release-2">Maintenance Release</h3> |
| <ul> |
| <li><p>General updates to fix known defects and enhancements implementation.</p></li> |
| <li><p><strong>HAL/LL ADC</strong> update</p> |
| <ul> |
| <li>Update HAL_ADC_Start_DMA() API to avoid return error when using Independent instance with multimode activated.</li> |
| <li>Update of the TEMPSENSOR_CAL2_TEMP value in the ll_adc.h file.</li> |
| <li>Update LL_ADC_SetChannelSingleDiff() API to be compliant with ARM CLang compiler v6.16.</li> |
| </ul></li> |
| <li><p><strong>HAL/LL RCC</strong> update</p> |
| <ul> |
| <li>Add missing API IsEnabled for PLL "domain" output.</li> |
| <li>Enhance RCC_MCOx in order to support both MCO number (PA8 and PG10) and AF mapping.</li> |
| </ul></li> |
| <li><p><strong>HAL/LL USART</strong> update</p> |
| <ul> |
| <li>Handling of UART concurrent register access in case of race condition between Tx and Rx transfers (HAL UART and LL LPUART)</li> |
| <li>Add const qualifier for read only pointers.</li> |
| <li>Improve header description of USART_WaitOnFlagUntilTimeout() function</li> |
| <li>Add a check on the USART parity before enabling the parity error interrupt.</li> |
| </ul></li> |
| <li><p><strong>HAL/LL UART</strong> update</p> |
| <ul> |
| <li>Fix erroneous UART’s handle state in case of error returned after DMA reception start within UART_Start_Receive_DMA().</li> |
| <li>Correction on UART ReceptionType management in case of ReceptionToIdle API are called from RxEvent callback</li> |
| <li>Handling of UART concurrent register access in case of race condition between Tx and Rx transfers (HAL UART and LL LPUART)</li> |
| <li>Improve header description of UART_WaitOnFlagUntilTimeout() function</li> |
| <li>Add a check on the UART parity before enabling the parity error interruption.</li> |
| <li>Add const qualifier for read only pointers.</li> |
| <li>Fix wrong cast when computing the USARTDIV value in UART_SetConfig().</li> |
| </ul></li> |
| <li><p><strong>LL LPTIM</strong> update</p> |
| <ul> |
| <li>Add check on PRIMASK register to prevent from enabling unwanted global interrupts within LPTIM_Disable() and LL_LPTIM_Disable().</li> |
| </ul></li> |
| <li><p><strong>LL TIM</strong> update</p> |
| <ul> |
| <li>Update LL_TIM_OC_SetPulseWidth implementation to properly align the PulseWidth input value with the TIM_ECR register.</li> |
| <li>Fix wrong compile switch used in TIM_LL_EC_DMABURST_BASEADDR constant definitions.</li> |
| </ul></li> |
| <li><p><strong>LL LPUART</strong> update</p> |
| <ul> |
| <li>Remove useless TXFECF reference from LL LPUART driver.</li> |
| </ul></li> |
| <li><p><strong>HAL IRDA</strong> update</p> |
| <ul> |
| <li>Improve header description of IRDA_WaitOnFlagUntilTimeout() function</li> |
| <li>Add a check on the IRDA parity before enabling the parity error interrupt.</li> |
| <li>Add const qualifier for read only pointers.</li> |
| <li>Fix wrong cast when computing the USARTDIV value in IRDA_SetConfig().</li> |
| </ul></li> |
| <li><p><strong>HAL SMARTCARD</strong> update</p> |
| <ul> |
| <li>Improve header description of SMARTCARD_WaitOnFlagUntilTimeout() function.</li> |
| <li>Add const qualifier for read only pointers.</li> |
| <li>Fix wrong cast when computing the USARTDIV value in SMARTCARD_SetConfig().</li> |
| </ul></li> |
| <li><p><strong>HAL/LL SPI</strong> update</p> |
| <ul> |
| <li>Updated to fix MISRA-C 2012 Rule-13.2.</li> |
| <li>Update LL_SPI_TransmitData8() API to avoid casting the result to 8 bits.</li> |
| </ul></li> |
| <li><p><strong>HAL RTC</strong> update</p> |
| <ul> |
| <li>Update __HAL_RTC_…(<strong>HANDLE</strong>, …) macros to access registers through (<strong>HANDLE</strong>)->Instance pointer and avoid “unused variable” warnings.</li> |
| </ul></li> |
| <li><p><strong>HAL CRYP</strong> update</p> |
| <ul> |
| <li>CRYP_AESCCM_Process_IT() update to manage header lengths in bytes or words when header length is less than 16 bytes.</li> |
| </ul></li> |
| <li><p><strong>HAL HRTIM</strong> update</p> |
| <ul> |
| <li>Fix compilation ARMCLANG -Wparenteses-equality warnings.</li> |
| <li>Fix missing initial update when Resynchronized update is used.</li> |
| </ul></li> |
| <li><p><strong>HAL FLASH</strong> update</p> |
| <ul> |
| <li>Update to support STM32G4 part numbers with 256K flash</li> |
| <li>Disable ICache while Flash programming. |
| <ul> |
| <li>Update HAL_FLASHEx_Erase() to remove __HAL_FLASH_INSTRUCTION_CACHE_DISABLE().</li> |
| </ul></li> |
| </ul></li> |
| <li><p><strong>HAL USB</strong> update</p> |
| <ul> |
| <li>HAL PCD: add fix transfer complete for IN Interrupt transaction in single buffer mode</li> |
| </ul></li> |
| <li><p><strong>HAL GPIO</strong> update</p> |
| <ul> |
| <li>Reorder EXTI configuration sequence in order to avoid unexpected level detection.</li> |
| <li>Optimize assertion control for GPIO Pull mode in HAL_GPIO_Init() API.</li> |
| <li>Update HAL_GPIO_Init() API to avoid the configuration of PUPDR register when Analog mode is selected.</li> |
| </ul></li> |
| <li><p><strong>HAL EXTI</strong> update</p> |
| <ul> |
| <li>Update HAL_EXTI_GetConfigLine() API to set default configuration value of Trigger and GPIOSel before checking each corresponding registers.</li> |
| </ul></li> |
| <li><p><strong>HAL USART</strong> update</p> |
| <ul> |
| <li>Improve header description of USART_WaitOnFlagUntilTimeout() function</li> |
| <li>Add a check on the USART parity before enabling the parity error interrupt.</li> |
| <li>Fix compilation warnings generated with ARMV6 compiler.</li> |
| </ul></li> |
| <li><p><strong>HAL I2C</strong> update</p> |
| <ul> |
| <li>Update I2C_IsAcknowledgeFailed() API to avoid I2C in busy state if NACK received after transmitting register address.</li> |
| <li>Update to handle errors in polling mode. |
| <ul> |
| <li>Rename I2C_IsAcknowledgeFailed() to I2C_IsErrorOccurred() and correctly manage when error occurs.</li> |
| </ul></li> |
| <li>Update to fix issue detected due to low system frequency execution (HSI).</li> |
| <li>Declare an internal macro link to DMA macro to check remaining data: I2C_GET_DMA_REMAIN_DATA.</li> |
| </ul></li> |
| <li><p><strong>HAL SMBUS</strong> update</p> |
| <ul> |
| <li>Add the support of wake up capability. |
| <ul> |
| <li>Add new APIs: |
| <ul> |
| <li>HAL_SMBUSEx_EnableWakeUp()</li> |
| <li>HAL_SMBUSEx_DisableWakeUp()</li> |
| </ul></li> |
| </ul></li> |
| <li>Update to fix issue of mismatched data received by master in case of data size to be transmitted by the slave is greater than the data size to be received by the master. |
| <ul> |
| <li>Add flush on TX register.</li> |
| </ul></li> |
| </ul></li> |
| <li><p><strong>HAL IWDG</strong> update</p> |
| <ul> |
| <li>Add LSI startup time in default IWDG timeout calculation (HAL_IWDG_DEFAULT_TIMEOUT).</li> |
| </ul></li> |
| <li><p><strong>HAL RNG</strong> update</p> |
| <ul> |
| <li>Update timeout mechanism to avoid false timeout detection in case of preemption.</li> |
| </ul></li> |
| <li><p><strong>HAL NAND</strong> update</p> |
| <ul> |
| <li>Update implementation of “HAL_NAND_Write_Page_16b” and “HAL_NAND_Read_Page_16b” APIs implementation to fix an issue with the page calculation of 8 bits memories.</li> |
| </ul></li> |
| </ul> |
| <h2 id="development-toolchains-and-compilers-2">Development Toolchains and Compilers</h2> |
| <ul> |
| <li>IAR Embedded Workbench for ARM (EWARM) toolchain V8.50.4 + ST-LINKV2</li> |
| <li>RealView Microcontroller Development Kit (MDK-ARM) toolchain V5.31 + ST-LINKV2</li> |
| <li>STM32CubeIDE toolchain (gcc9_2020_q2_update) <strong>V1.7.0</strong></li> |
| </ul> |
| <h2 id="supported-devices-2">Supported Devices</h2> |
| <ul> |
| <li>STM32G431/41xx</li> |
| <li>STM32G471xx</li> |
| <li>STM32G473/83xx</li> |
| <li>STM32G474/84xx</li> |
| <li>STM32G491/A1xx</li> |
| </ul> |
| </div> |
| </div> |
| <div class="collapse"> |
| <input type="checkbox" id="collapse-section5" aria-hidden="true"> <label for="collapse-section5" aria-hidden="true">V1.2.1 / 27-January-2021</label> |
| <div> |
| <h2 id="main-changes-3">Main Changes</h2> |
| <h3 id="maintenance-release-3">Maintenance Release</h3> |
| <ul> |
| <li><p>General updates to fix known defects and enhancements implementation</p></li> |
| <li><p><strong>HAL</strong></p></li> |
| <li><p>General updates to fix known defects and enhancements implementation.</p></li> |
| <li><p>Support for new ARM compiler Keil V6.</p></li> |
| <li><p>Added new defines for ARM compiler V6:</p> |
| <ul> |
| <li>__weak</li> |
| <li>__packed</li> |
| <li>__NOINLINE</li> |
| </ul></li> |
| <li><p><strong>LL RCC</strong> update</p> |
| <ul> |
| <li>Private functions made static.</li> |
| </ul></li> |
| <li><p><strong>HAL CRYP</strong> update</p> |
| <ul> |
| <li>Correction made for the Official NIST CCM test pattern ciphering failing when header length is null.</li> |
| <li>GCM/GMAC/CCM data header is now fed using DMA instead of polling.</li> |
| <li>Fixed CRYP HAL driver to manage GCM header lengths not multiple of 4 bytes in 8-bit, 16-bit and 32-bit data types.</li> |
| <li>Fixed handling of AUD with size not multiple of 4 bytes in CRYP_AESGCM_Process_IT for GCM.</li> |
| </ul></li> |
| <li><p><strong>HAL RTC</strong> Update</p> |
| <ul> |
| <li>New APIs to subtract or add one hour to the calendar in one single operation without going through the initialization procedure (Daylight Saving): |
| <ul> |
| <li>Add HAL_RTC_DST_Add1Hour()</li> |
| <li>HAL_RTC_DST_Sub1Hour()</li> |
| <li>HAL_RTC_DST_SetStoreOperation()</li> |
| <li>HAL_RTC_DST_ClearStoreOperation()</li> |
| </ul></li> |
| <li>Fixed executing TimeStamp callback when HAL_RTC_SetTimeStamp is called with “Rising Edge” configuration |
| <ul> |
| <li>Updated HAL_RTC_SetTimeStamp() API to call __HAL_RTC_TIMESTAMP_EXTI_ENABLE_IT before configuring the TimeStamp.</li> |
| </ul></li> |
| </ul></li> |
| <li><p><strong>HAL/LL TIM</strong> update</p> |
| <ul> |
| <li>Updated HAL_TIMEx_OnePulseN_Start() and HAL_TIMEx_OnePulseN_Stop() APIs (pooling and IT mode) to take into consideration all OutputChannel parameters.</li> |
| <li>Corrected reversed description of TIM_LL_EC_ONEPULSEMODE One Pulse Mode.</li> |
| <li>Updated LL_TIM_GetCounterMode() API to return the correct counter mode.</li> |
| </ul></li> |
| <li><p><strong>HAL/LL LPTIM</strong> update</p> |
| <ul> |
| <li>Updated HAL_LPTIM_Init() API implementation to configure digital filter for external clock when LPTIM is configured with internal clock source.</li> |
| </ul></li> |
| <li><p><strong>HAL/LL HRTIM</strong> update</p> |
| <ul> |
| <li>IRQ handlers optimized by reducing the multiple read-accesses to ISR and IER registers to one read-access per register.</li> |
| <li>LL_HRTIM_FLT_SetSrc() API updated to avoid overwriting the content of FLTINR2 register on successive calls.</li> |
| </ul></li> |
| <li><p><strong>HAL EXTI</strong> update</p> |
| <ul> |
| <li>__EXTI__LINE is now used instead of <strong>LINE</strong> which is a standard C macro.</li> |
| </ul></li> |
| <li><p><strong>HAL OPAMP</strong> update</p> |
| <ul> |
| <li>Corrected OPAMPs outputs for the STM32G4 device table to be coherent with reference manual.</li> |
| </ul></li> |
| <li><p><strong>HAL/LL ADC</strong> Update</p> |
| <ul> |
| <li>Update HAL_ADC_DeInit() to avoid ADC hardware resource deinitialization when other ADC instances sharing the same common ADC instance are disable.</li> |
| <li>Update temperature sensor stabilization time management.</li> |
| <li>Update timeout mechanism to avoid false timeout detection in case of preemption.</li> |
| <li>Align the defined value of internal regulator stabilization time (LL_ADC_DELAY_INTERNAL_REGUL_STAB_US) with product documentation (20us instead of 10us).</li> |
| </ul></li> |
| <li><p><strong>HAL DAC</strong> update</p> |
| <ul> |
| <li>Updated HAL_DAC_Stop_DMA() API to not return HAL_ERROR when DAC is already disabled.</li> |
| <li>Updated HAL_DAC_ConfigChannel to return the right timeout error for channel 2.</li> |
| <li>Update HAL_DACEx_DualStart when checking if the software trigger enabled: |
| <ul> |
| <li>DAC_TRIGGER_SOFTWARE instead of DAC_CR_TEN1</li> |
| <li>(DAC_TRIGGER_SOFTWARE << (DAC_CHANNEL_2 & 0x10UL)) instead of DAC_CR_TEN2</li> |
| </ul></li> |
| </ul></li> |
| <li><p><strong>HAL NOR</strong> Update</p> |
| <ul> |
| <li>Corrected how p_endaddress is computed and how p_currentaddress is used in the HAL_NOR_ProgramBuffer() API.</li> |
| <li>NOR command sets can now be selected by manufacturer code, as specified in JEDEC JEP137B 2004-05, using NOR_HandleTypeDef field CommandSet. the following APIs have been updated: |
| <ul> |
| <li>HAL_NOR_Init()</li> |
| <li>HAL_NOR_Read_ID()</li> |
| <li>HAL_NOR_ReturnToReadMode()</li> |
| <li>HAL_NOR_Read()</li> |
| <li>HAL_NOR_Program()</li> |
| <li>HAL_NOR_ReadBuffer()</li> |
| <li>HAL_NOR_ProgramBuffer()</li> |
| <li>HAL_NOR_Erase_Block()</li> |
| <li>HAL_NOR_Erase_Chip()</li> |
| <li>HAL_NOR_GetStatus()</li> |
| </ul></li> |
| <li>Added new command operations: |
| <ul> |
| <li>NOR_CMD_READ_ARRAY</li> |
| <li>NOR_CMD_WORD_PROGRAM</li> |
| <li>NOR_CMD_BUFFERED_PROGRAM</li> |
| <li>NOR_CMD_CONFIRM</li> |
| <li>NOR_CMD_BLOCK_ERASE</li> |
| <li>NOR_CMD_BLOCK_UNLOCK</li> |
| <li>NOR_CMD_READ_STATUS_REG</li> |
| <li>NOR_CMD_CLEAR_STATUS_REG</li> |
| </ul></li> |
| <li>Updated multiple APIs to treat separately the different memory types.</li> |
| </ul></li> |
| <li><p><strong>LL FMC </strong> Update</p> |
| <ul> |
| <li>Updated FMC_NORSRAM_Extended_Timing_Init() API to manage the “bus turn around duration” parameter availability.</li> |
| <li>Updated FMC_NORSRAM_Init() API to resolve compilation issue with Microsoft Visual Studio 2017.</li> |
| </ul></li> |
| <li><p><strong>HAL NAND</strong> update</p> |
| <ul> |
| <li>Updated HAL_NAND_Read_SpareArea_16b() and HAL_NAND_Write_SpareArea_16b() APIs to fix the column address calculation.</li> |
| </ul></li> |
| <li><p><strong>HAL/LL SMARTCARD</strong> update</p> |
| <ul> |
| <li>Fixed invalid initialization of SMARTCARD configuration by removing the FIFO mode configuration.</li> |
| <li>Fixed typos in SMARTCARD State definition description.</li> |
| <li>Optimized stack usage for multiple APIs.</li> |
| </ul></li> |
| <li><p><strong>HAL/LL IRDA</strong> update</p> |
| <ul> |
| <li>Fixed typos in IRDA State definition description.</li> |
| <li>Optimized stack usage for multiple APIs.</li> |
| </ul></li> |
| <li><p><strong>HAL/LL UART</strong> update</p> |
| <ul> |
| <li>Enhanced reception for idle services (ReceptionToIdle): |
| <ul> |
| <li>Added a new field (HAL_UART_RxTypeTypeDef) to the UART_HandleTypeDef structure to identify the type of ongoing reception.</li> |
| <li>Added UART Reception Event Callback registration.</li> |
| </ul></li> |
| <li>Added reception specific APIs specific to reception for Idle transfer in different modes: |
| <ul> |
| <li>HAL_UARTEx_ReceiveToIdle(): Receive an amount of data in blocking mode until either the expected number of data is received or an IDLE event occurs.</li> |
| <li>HAL_UARTEx_ReceiveToIdle_IT(): Receive an amount of data in interrupt mode until either the expected number of data is received or an IDLE event occurs.</li> |
| <li>HAL_UARTEx_ReceiveToIdle_DMA(): Receive an amount of data in DMA mode until either the expected number of data is received or an IDLE event occurs.</li> |
| </ul></li> |
| <li>Updated HAL_UART_Receive(), HAL_UART_Receive_IT() and HAL_UART_Receive_DMA() APIs to support the new enhancement of ReceptionToIdle.</li> |
| <li>Fixed invalid initialization of UART configuration by removing FIFO mode configuration as it is not member of UART_InitTypeDef Structure.</li> |
| <li>Fixed typos in UART State definition description.</li> |
| <li>Optimized stack usage for multiple APIs.</li> |
| </ul></li> |
| <li><p><strong>HAL/LL USART</strong> update</p> |
| <ul> |
| <li>Removed IS_USART_OVERSAMPLING() as it is unused.</li> |
| <li>LL_USART_ClockInit now supports clock phase and clock polarity configuration for SPI_Slave mode.</li> |
| <li>Remove useless check on maximum BRR value by removing IS_LL_USART_BRR_MAX() macro.</li> |
| <li>Optimized stack usage for multiple APIs.</li> |
| <li>Removed useless check on maximum BRR value by removing IS_LL_USART_BRR_MAX() macro.</li> |
| </ul></li> |
| <li><p><strong>HAL SMBUS</strong> update</p> |
| <ul> |
| <li>Support for Fast Mode Plus to be SMBUS rev 3 compliant. |
| <ul> |
| <li>Added HAL_SMBUSEx_EnableFastModePlus() and HAL_SMBUSEx_DisableFastModePlus() APIs to manage Fm+.</li> |
| </ul></li> |
| </ul></li> |
| <li><p><strong>LL SPI</strong> update</p> |
| <ul> |
| <li>Updated to set the FRXTH bit for 8bit data for LL_SPI_Init() API.</li> |
| </ul></li> |
| <li><p><strong>HAL WWDG</strong> update</p> |
| <ul> |
| <li>Updated HAL driver description.</li> |
| </ul></li> |
| <li><p><strong>HAL/LL USB</strong> update</p> |
| <ul> |
| <li>Fixed USB ISO IN double buffer mode Transfer.</li> |
| <li>Fixed PMA rx count descriptor</li> |
| </ul></li> |
| <li><p>Added few instructions before reading the RX count register.</p></li> |
| </ul> |
| <h2 id="development-toolchains-and-compilers-3">Development Toolchains and Compilers</h2> |
| <ul> |
| <li>IAR Embedded Workbench for ARM (EWARM) toolchain <strong>V8.50.4</strong> + ST-LINKV2</li> |
| <li>RealView Microcontroller Development Kit (MDK-ARM) toolchain <strong>V5.31</strong> + ST-LINKV2</li> |
| <li>STM32CubeIDE toolchain <strong>V1.6.0</strong></li> |
| </ul> |
| <h2 id="supported-devices-3">Supported Devices</h2> |
| <ul> |
| <li>STM32G431/41xx</li> |
| <li>STM32G471xx</li> |
| <li>STM32G473/83xx</li> |
| <li>STM32G474/84xx</li> |
| <li>STM32G491/A1xx</li> |
| </ul> |
| </div> |
| </div> |
| <div class="collapse"> |
| <input type="checkbox" id="collapse-section4" aria-hidden="true"> <label for="collapse-section4" aria-hidden="true">V1.2.0 / 26-June-2020</label> |
| <div> |
| <h2 id="main-changes-4">Main Changes</h2> |
| <h3 id="maintenance-release-4">Maintenance Release</h3> |
| <ul> |
| <li><p>Add support for STM32G491xx and STM32G4A1 part numbers</p></li> |
| <li><p>General updates to fix known defects and enhancements implementation</p></li> |
| <li><p><strong>HAL/LL GPIO</strong> update</p> |
| <ul> |
| <li>Enhancement GPIO_TogglePin API to allow the toggling of many pins</li> |
| <li>Update GPIO initialization sequence to avoid unwanted pulse on GPIO Pin’s</li> |
| </ul></li> |
| <li><p><strong>HAL/LL HRTIM</strong> update</p> |
| <ul> |
| <li>Constants renaming: |
| <ul> |
| <li>Rename HAL constants HRTIM_TIMEEVENT_… and HRTIM_TIMEEVENTRESETMODE_… respectively HRTIM_EVENT<strong>COUNTER</strong>_… and HRTIM_EVENT<strong>COUNTER</strong>_RSTMODE_… to reflect their relation to external event <strong>counters</strong>.</li> |
| <li>Rename LL constants LL_HRTIM_OUTPUTSET_TIM… and LL_HRTIM_OUTPUTRESET_TIM… to make them compliant to the CMSIS bits definitions they correspond to.</li> |
| <li><strong>Warning:</strong> Possible <strong>compatibility break</strong> with CubeMX 5.6.0 and previous versions!</li> |
| </ul></li> |
| <li>Constants removal: |
| <ul> |
| <li>Remove unused HAL constants HRTIM_RSYNCUPDATE_… and HRTIM_TIMEEVENTCOUNTER_….</li> |
| <li>Remove unused LL constant LL_HRTIM_RESETTRIG_OTHER5_CMP4 as the definition it corresponds to (HRTIM_RSTR_TIMFCMP4) exists neither in the CMSIS nor in the reference manual.</li> |
| </ul></li> |
| </ul></li> |
| <li><p><strong>HAL/LL I2S</strong> update</p> |
| <ul> |
| <li>Update HAL_I2S_DMAStop() API to be more safe |
| <ul> |
| <li>Add a check on BSY, TXE and RXNE flags before disabling the I2S</li> |
| </ul></li> |
| <li>Update HAL_I2S_DMAStop() API to fix multi-call transfer issue(to avoid re-initializing the I2S for the next transfer). |
| <ul> |
| <li>Add __HAL_I2SEXT_FLUSH_RX_DR() and __HAL_I2S_FLUSH_RX_DR() macros to flush the remaining data inside DR registers.</li> |
| <li>Add new ErrorCode define: HAL_I2S_ERROR_BUSY_LINE_RX</li> |
| </ul></li> |
| </ul></li> |
| <li><p><strong>HAL/LL SPI</strong> update</p> |
| <ul> |
| <li>Update HAL_SPI_Init() API |
| <ul> |
| <li>To avoid setting the BaudRatePrescaler in case of Slave Motorola Mode</li> |
| <li>Use the bit-mask for SPI configuration</li> |
| </ul></li> |
| <li>Update Transmit/Receive processes in half-duplex mode |
| <ul> |
| <li>Disable the SPI instance before setting BDIOE bit</li> |
| </ul></li> |
| <li>Update SPI_DMAReceiveCplt() API to handle efficiently the repeated transfers. |
| <ul> |
| <li>Disable TX DMA request only in bidirectional receive mode.</li> |
| </ul></li> |
| <li>Fix wrong timeout management |
| <ul> |
| <li>Calculate Timeout based on a software loop to avoid blocking issue if Systick is disabled</li> |
| </ul></li> |
| </ul></li> |
| <li><p><strong>HAL SAI</strong> update</p> |
| <ul> |
| <li>Update HAL_SAI_Init() API to correct the formula in case of SPDIF is wrong</li> |
| </ul></li> |
| <li><p><strong>HAL/LL ADC</strong> update</p> |
| <ul> |
| <li>Update Channel & external trigger to support <strong>STM32G491/STM32G4A1</strong> embedded with 3 ADC: |
| <ul> |
| <li>IS_ADC_EXTRIG, IS_ADC_CHANNEL, IS_ADC_EXTRIGINJ, ADC_IS_INDEPENDENT.</li> |
| <li>IS_LL_ADC_REG_TRIG_SOURCE, IS_LL_ADC_INJ_TRIG_SOURCE, __LL_ADC_IS_CHANNEL_INTERNAL_AVAILABLE.</li> |
| </ul></li> |
| <li>Update note in ll_adc.h & hal_adc.h to highlight that the ADC with transfers DMA and ADC mode auto delay can work simultaneously.</li> |
| </ul></li> |
| <li><p><strong>HAL COMP</strong> update</p> |
| <ul> |
| <li>Update Blanking sources to support <strong>STM32G491/STM32G4A1</strong> embedded with 4 COMP: |
| <ul> |
| <li>IS_COMP_BLANKINGSRC_INSTANCE</li> |
| </ul></li> |
| </ul></li> |
| <li><p><strong>HAL OPAMP</strong> update</p> |
| <ul> |
| <li>Update hal_opamp_ex.c to support <strong>STM32G491/STM32G4A1</strong> embedded with 4 OPAMP (OPAMP1/OPAMP2/OPAMP3/OPAMP6):</li> |
| </ul></li> |
| <li><p><strong>HAL FLASH</strong> update</p> |
| <ul> |
| <li>Update FLASH Latency comment param to list all supported flash latency values.</li> |
| <li>Update FLASH_PAGE_NB to return the right page number(256 pages for devices embedded with 512KB flash size and 64 for devices embedded with 128KB flash size)</li> |
| </ul></li> |
| <li><p><strong>HAL/LL RCC</strong> update</p> |
| <ul> |
| <li>Update Table 1. HCLK clock frequency for STM32G4xx devices to be aligned with reference manual RM0440</li> |
| <li>Update peripheral clock to support <strong>STM32G491/STM32G4A1</strong> devices: |
| <ul> |
| <li>HAL_RCCEx_GetPeriphCLKConfig</li> |
| <li>IS_RCC_PERIPHCLOCK</li> |
| </ul></li> |
| </ul></li> |
| <li><p><strong>HAL/LL TIM</strong> driver</p> |
| <ul> |
| <li>Align HAL/LL TIM driver with latest updates and enhancements</li> |
| <li>Add new macros to enable and disable the fast mode when using the one pulse mode to output a waveform with a minimum delay |
| <ul> |
| <li>__HAL_TIM_ENABLE_OCxFAST() and __HAL_TIM_DISABLE_OCxFAST().</li> |
| </ul></li> |
| <li>Update HAL_TIMEx_MasterConfigSynchronization() API to avoid functional errors and assert fails when using some TIM instances as input trigger. |
| <ul> |
| <li>Replace IS_TIM_SYNCHRO_INSTANCE() macro by IS_TIM_MASTER_INSTANCE() macro.</li> |
| <li>Add IS_TIM_SLAVE_INSTANCE() macro to check on TIM_SMCR_MSM bit.</li> |
| </ul></li> |
| <li>Remove ‘register’ storage class specifier from LL TIM driver.</li> |
| <li>Add new API HAL_TIM_DMABurst_MultiWriteStart() allowing to configure the DMA Burst to transfer multiple Data from the memory to the TIM peripheral</li> |
| <li>Add new API HAL_TIM_DMABurst_MultiReadStart() allowing to configure the DMA Burst to transfer Data from the TIM peripheral to the memory</li> |
| </ul></li> |
| <li><p><strong>HAL/LL UART</strong> driver</p> |
| <ul> |
| <li>Update UART polling processes to handle efficiently the Lock mechanism |
| <ul> |
| <li>Move the process unlock at the top of the HAL_UART_Receive() and HAL_UART_Transmit() API.</li> |
| </ul></li> |
| <li>Update UART BRR calculation for ROM size gain</li> |
| <li>Remove ‘register’ storage class specifier from LL UART driver.</li> |
| </ul></li> |
| <li><p><strong>HAL/LL USART</strong> driver</p> |
| <ul> |
| <li>Remove ‘register’ storage class specifier from LL USART driver.</li> |
| </ul></li> |
| <li><p><strong>HAL/LL USB</strong> driver</p> |
| <ul> |
| <li>Fix USB Bulk transfer double buffer mode</li> |
| <li>Remove register keyword from USB defined macros as no more supported by c++ compiler</li> |
| <li>minor rework USBD_Start and USBD_Stop API, stop device to be handled by HAL_PCD_DeInit()</li> |
| <li>Correct some word spelling issues</li> |
| </ul></li> |
| </ul> |
| <h2 id="development-toolchains-and-compilers-4">Development Toolchains and Compilers</h2> |
| <ul> |
| <li>IAR Embedded Workbench for ARM (EWARM) toolchain V8.40.1</li> |
| <li>RealView Microcontroller Development Kit (MDK-ARM) toolchain <strong>V5.29</strong></li> |
| <li>STM32CubeIDE toolchain <strong>V1.4.0</strong></li> |
| </ul> |
| <h2 id="supported-devices-4">Supported Devices</h2> |
| <ul> |
| <li>STM32G431/41xx</li> |
| <li>STM32G471xx</li> |
| <li>STM32G473/83xx</li> |
| <li>STM32G474/84xx</li> |
| <li>STM32G4<strong>91</strong>/<strong>A1</strong>xx</li> |
| </ul> |
| </div> |
| </div> |
| <div class="collapse"> |
| <input type="checkbox" id="collapse-section3" aria-hidden="true"> <label for="collapse-section3" aria-hidden="true">V1.1.1 / 14-February-2020</label> |
| <div> |
| <h2 id="main-changes-5">Main Changes</h2> |
| <h3 id="maintenance-release-5">Maintenance Release</h3> |
| <ul> |
| <li><p>General updates to fix known defects and enhancements implementation</p></li> |
| <li><p><strong>HAL/LL CRYP</strong> update</p> |
| <ul> |
| <li>Correct MISRA C:2012 warnings reported by rules 2.2_c, 10.1_R6, 10.3, 10.4_a, 10.6, 12.1, 13.5 15.7</li> |
| <li>Perform a new check mechanism on the cryp buffer size in Encryption et Decryption API |
| <ul> |
| <li>Add IS_CRYP_BUFFERSIZE() macro</li> |
| </ul></li> |
| <li>Clean up the HAL_CRYP_Resume() API to avoid infinite loop due to an early interruption during resumption process |
| <ul> |
| <li>Remove __HAL_CRYP_ENABLE_IT() and __HAL_CRYP_ENABLE() API .</li> |
| </ul></li> |
| <li>Add new parameter in the CRYP_HandleTypeDef structure |
| <ul> |
| <li>Add SizesSum_saved to save the SizesSum when processing is suspended</li> |
| <li>Update the HAL_CRYP_Suspend() and HAL_CRYP_Resume() API by adding this new parameter</li> |
| </ul></li> |
| <li>Add missing interruptions re-enabling operations following an all flags clear-up in the CRYP_PhaseProcessingResume() API</li> |
| <li>Support AAD with all possible byte sizes, not only multiple of 4 bytes |
| <ul> |
| <li>Update CRYP_GCMCCM_SetHeaderPhase() API</li> |
| <li>Add new parameter HeaderWidthUnit in the CRYP_ConfigTypeDef structure which contains the Cryp Header Width Unit</li> |
| <li>Add new definition of the CRYP Header size Unit |
| <ul> |
| <li>CRYP_HEADERWIDTHUNIT_WORD</li> |
| <li>CRYP_HEADERWIDTHUNIT_BYTE</li> |
| </ul></li> |
| </ul></li> |
| <li>Support data encryption and decryption with length not only multiple of 16 bytes |
| <ul> |
| <li>Update IS_CRYP_BUFFERSIZE() macro</li> |
| <li>Update AES functions : CRYP_AES_ProcessData() / CRYP_AES_IT() / CRYP_AESCCM_Process() / CRYP_AESGCM_Process_DMA()</li> |
| <li>Update CRYP_GCMCCM_SetPayloadPhase_IT() API</li> |
| </ul></li> |
| </ul></li> |
| <li><p><strong>HAL/LL FMAC</strong> update</p> |
| <ul> |
| <li>General updates to comply to internal coding rules.</li> |
| </ul></li> |
| <li><p><strong>HAL GPIO</strong> update</p> |
| <ul> |
| <li>Update the GPIO initialization sequence in HAL_GPIO_Init() API to avoid unwanted glitches on GPIO pins.</li> |
| <li>Add missing GPIO Alternate Function definitions: |
| <ul> |
| <li>GPIO_AF2_TIM16, GPIO_AF9_TIM8, GPIO_AF11_TIM8, GPIO_AF12_TIM1.</li> |
| </ul></li> |
| </ul></li> |
| <li><p><strong>HAL HRTIM</strong> update</p> |
| <ul> |
| <li>Update HAL_HRTIM_WaveformCompareConfig() to clear HRTIM_TIMxCR.DELCMP bitfield when the auto-delayed protection mode is disabled.</li> |
| <li>Correct some “HRTIM_OUTPUTSET_TIMxx” constant names which are not compliant with Timer Events Mapping specified in the reference manual |
| <ul> |
| <li>Remove HRTIM_OUTPUTSET_TIMCEV1_TIMACMP1, HRTIM_OUTPUTSET_TIMEEV5_TIMDCMP2 , HRTIM_OUTPUTRESET_TIMCEV1_TIMACMP1 and HRTIM_OUTPUTRESET_TIMEEV5_TIMDCMP2</li> |
| <li>Add HRTIM_OUTPUTSET_TIMEEV5_TIMCCMP2 and HRTIM_OUTPUTSET_TIMCEV2_TIMACMP3 , HRTIM_OUTPUTRESET_TIMCEV2_TIMACMP3 and HRTIM_OUTPUTRESET_TIMEEV5_TIMCCMP2</li> |
| <li>Update HRTIM_OUTPUTSET_TIMCEV2_TIMACMP2 and HRTIM_OUTPUTRESET_TIMCEV2_TIMACMP2 definitions</li> |
| </ul></li> |
| <li>Update HAL_HRTIM_DLLCalibrationStart() and HAL_HRTIM_DLLCalibrationStart_IT() API by setting HRTIM state ready to avoid some unstable behavior of the TIMER E.</li> |
| <li>Add new check field in the IS_HRTIM_EVENTSRC() macro to check also on EVENT</li> |
| <li>Add a new check in the HAL_HRTIM_EventConfig() API on event and event source through the IS_HRTIM_EVENTSRC() macro</li> |
| <li>Remove UPDGAT bits reset from the HRTIM_TimingUnitWaveform_Control() API</li> |
| <li>Add a lock and unlock handle process in the HAL_HRTIM_SimpleOCChannelConfig() API</li> |
| </ul></li> |
| <li><p><strong>HAL I2C</strong> update</p> |
| <ul> |
| <li>Update I2C_DMAAbort() APIs to fix hardfault issue when hdmatx and hdmarx parameters in i2c handle aren’t initialized (NULL pointer). |
| <ul> |
| <li>Add additional check on hi2c->hdmtx and hi2c->hdmarx before resetting DMA Tx/Rx complete callbacks</li> |
| </ul></li> |
| <li>Fix HAL I2C slave interrupt handling issue with I2C sequential transfers. |
| <ul> |
| <li>Update I2C_Slave_ISR_IT() and I2C_Slave_ISR_DMA() APIs to check on STOP condition and handle it before clearing the ADDR flag</li> |
| </ul></li> |
| </ul></li> |
| <li><p><strong>HAL LPTIM</strong> update</p> |
| <ul> |
| <li>Add a polling mechanism to check on LPTIM_FLAG_XXOK flags in different API |
| <ul> |
| <li>Add LPTIM_WaitForFlag() API to wait for flag set.</li> |
| <li>Perform new checks on HAL_LPTIM_STATE_TIMEOUT.</li> |
| </ul></li> |
| <li>Apply digital filter for external clock for all LPTIM clock source. |
| <ul> |
| <li>Update HAL_LPTIM_Init() API</li> |
| </ul></li> |
| <li>Correct the input1source and input2source selection |
| <ul> |
| <li>Update LL_LPTIM_SetInput1Src and LL_LPTIM_SetInput2Src |
| <ul> |
| <li>Remove WRITE_REG and replace it by MODIFY_REG</li> |
| </ul></li> |
| </ul></li> |
| </ul></li> |
| <li><p><strong>HAL/LL RTC</strong> update</p> |
| <ul> |
| <li>Update API HAL_RTC_SetAlarm_IT() to allow changing alarm time “on the fly” simply by calling the API again.</li> |
| <li>Update API LL_RTC_BKP_SetRegister() and API LL_RTC_BKP_GetRegister() to comply to rules 2.2 and 13.2 of MISRAC-2012.</li> |
| </ul></li> |
| <li><p><strong>HAL SPI</strong> update</p> |
| <ul> |
| <li>Update the “Rx DMA transfer complete callback” to disable the Tx DMA request only in case of full-duplex mode and not it in half-duplex mode.</li> |
| </ul></li> |
| <li><p><strong>HAL TIM</strong> update</p> |
| <ul> |
| <li>Update Encoder interface mode to keep TIM_CCER_CCxNP bits low |
| <ul> |
| <li>Add TIM_ENCODERINPUTPOLARITY_RISING and TIM_ENCODERINPUTPOLARITY_FALLING definitions to determine encoder input polarity.</li> |
| <li>Add IS_TIM_ENCODERINPUT_POLARITY() macro to check the encoder input polarity.</li> |
| <li>Update HAL_TIM_Encoder_Init() API |
| <ul> |
| <li>Replace IS_TIM_IC_POLARITY() macro by IS_TIM_ENCODERINPUT_POLARITY() macro.</li> |
| </ul></li> |
| </ul></li> |
| <li>Provide new API to set and clear UIFREMAP |
| <ul> |
| <li>Add new definition for TIM Update Interrupt Flag Remap |
| <ul> |
| <li>TIM_UIFREMAP_DISABLE</li> |
| <li>TIM_UIFREMAP_ENABLE</li> |
| </ul></li> |
| <li>Add new macro in HAL driver to enable and desable the Update Interrupt Flag Remap |
| <ul> |
| <li>__HAL_TIM_UIFREMAP_ENABLE()</li> |
| <li>__HAL_TIM_UIFREMAP_DISABLE()/__HAL_TIM_GET_UIFCPY macro</li> |
| </ul></li> |
| <li>Add new mechanism to check whether the update interrupt flag (UIF) copy is set or not |
| <ul> |
| <li>Add the __HAL_TIM_GET_UIFCPY() macro in the HAL driver</li> |
| <li>Add LL_TIM_IsActiveUIFCPY() API in the LL driver</li> |
| </ul></li> |
| <li>Add new macro to check on the Update Interrupt Flag Remap mode |
| <ul> |
| <li>IS_TIM_UIFREMAP_MODE()</li> |
| </ul></li> |
| </ul></li> |
| <li>Remove useless TIM trigger selector</li> |
| <li>Fix bug when using multiple DMA request to different channels of same timer |
| <ul> |
| <li>Introduce DMA burst state management mechanism |
| <ul> |
| <li>Add a new structure for DMA Burst States definition : HAL_TIM_DMABurstStateTypeDef</li> |
| <li>Update __HAL_TIM_RESET_HANDLE_STATE to support DMABurstState</li> |
| <li>Add a new API HAL_TIM_DMABurstState() to get the actual state of a DMA burst operation</li> |
| <li>Add DMABurstState, the DMA burst operation state, in the TIM_HandleTypeDef structure</li> |
| <li>Add new API TIM_DMAErrorCCxN() for TIM DMA error callback (complementary channel)</li> |
| <li>Add new API TIM_DMADelayPulseNCplt() for TIM DMA Delay Pulse complete callback (complementary channel)</li> |
| </ul></li> |
| </ul></li> |
| <li>Implement TIM channel state management mechanism |
| <ul> |
| <li>Add new macro |
| <ul> |
| <li>TIM_CHANNEL_STATE_SET_ALL and TIM_CHANNEL_N_STATE_SET_ALL</li> |
| <li>TIM_CHANNEL_STATE_SET and TIM_CHANNEL_N_STATE_SET</li> |
| <li>TIM_CHANNEL_STATE_GET and TIM_CHANNEL_N_STATE_GET</li> |
| </ul></li> |
| <li>Add new API HAL_TIM_GetActiveChannel()</li> |
| <li>Add new API HAL_TIM_GetChannelState() to get actual state of the TIM channel</li> |
| <li>Add a new structure for TIM channel States definition : HAL_TIM_ChannelStateTypeDef</li> |
| <li>Update __HAL_TIM_RESET_HANDLE_STATE to support ChannelState and ChannelNState</li> |
| <li>Add a new element in the TIM_HandleTypeDef structure : ChannelState to manage TIM channel operation stat.</li> |
| <li>Add a new element in the TIM_HandleTypeDef structure : ChannelNState to manage TIM complementary channel operation state</li> |
| </ul></li> |
| </ul></li> |
| <li><p><strong>HAL/LL USART</strong> update</p> |
| <ul> |
| <li>Add support to the Receiver Timeout Interrupt in the HAL_USART_IRQHandler</li> |
| <li>Fix wrong value for SlaveMode field in USART handle after HAL_USARTEx_DisableSlaveMode() call |
| <ul> |
| <li>Set USART_SLAVEMODE_DISABLE instead of USART_SLAVEMODE_ENABLE</li> |
| </ul></li> |
| </ul></li> |
| <li><p><strong>HAL USB</strong> update</p> |
| <ul> |
| <li>Improve USB endpoint out re-enabling with double-buffer mode.</li> |
| </ul></li> |
| <li><p><strong>LL UTILS</strong> update</p> |
| <ul> |
| <li>API UTILS_SetFlashLatency() renamed LL_SetFlashLatency() and set exportable.</li> |
| <li>API LL_PLL_ConfigSystemClock_HSI() and API LL_PLL_ConfigSystemClock_HSE() updated to set back the AHB prescaler to 1 after it has been temporarily set to 2 to avoid undershoot when configuring PLL at high frequencies.</li> |
| </ul></li> |
| </ul> |
| <h2 id="development-toolchains-and-compilers-5">Development Toolchains and Compilers</h2> |
| <ul> |
| <li>IAR Embedded Workbench for ARM (EWARM) toolchain V8.32.3</li> |
| <li>RealView Microcontroller Development Kit (MDK-ARM) toolchain V5.27.1</li> |
| <li>STM32CubeIDE toolchain v1.3.0</li> |
| </ul> |
| <h2 id="supported-devices-5">Supported Devices</h2> |
| <ul> |
| <li>STM32G431/41xx</li> |
| <li>STM32G471xx</li> |
| <li>STM32G473/<strong>83xx</strong></li> |
| <li>STM32G474/84xx</li> |
| </ul> |
| </div> |
| </div> |
| <div class="collapse"> |
| <input type="checkbox" id="collapse-section2" aria-hidden="true"> <label for="collapse-section2" aria-hidden="true">V1.1.0 / 28-June-2019</label> |
| <div> |
| <h2 id="main-changes-6">Main Changes</h2> |
| <h3 id="maintenance-release-6">Maintenance Release</h3> |
| <p>Maintenance release of HAL (Hardware Abstraction Layer) and LL (Low layers) drivers to support STM32G431/41xx, STM32G471xx, STM32G473/83xx and STM32G474/84xx.</p> |
| <h2 id="contents">Contents</h2> |
| <table> |
| <caption>Additional features and changes :</caption> |
| <thead> |
| <tr class="header"> |
| <th style="text-align: left;">Headline</th> |
| </tr> |
| </thead> |
| <tbody> |
| <tr class="odd"> |
| <td style="text-align: left;">General: Support of device STM32G483xx in HAL and LL drivers</td> |
| </tr> |
| <tr class="even"> |
| <td style="text-align: left;">COMP: Suppress Deglitcher mode - Not supported on STM32G4 series</td> |
| </tr> |
| <tr class="odd"> |
| <td style="text-align: left;">HAL: Change naming of the IRQn 2 to RTC_TAMP_LSECSS_IRQn</td> |
| </tr> |
| <tr class="even"> |
| <td style="text-align: left;">HRTIM: HRTIM_OUTPUTRESET_TIMAEVx renamed to HRTIM_OUTPUTRESET_TIMEVx</td> |
| </tr> |
| <tr class="odd"> |
| <td style="text-align: left;">TIM: Add new macro to configure fast mode</td> |
| </tr> |
| <tr class="even"> |
| <td style="text-align: left;">TIM: Master Slave Mode (MSM) is now configurable</td> |
| </tr> |
| </tbody> |
| </table> |
| <table> |
| <caption>Bugs fix :</caption> |
| <thead> |
| <tr class="header"> |
| <th style="text-align: left;">Headline</th> |
| </tr> |
| </thead> |
| <tbody> |
| <tr class="odd"> |
| <td style="text-align: left;">General : redefinition of registers with adjusted address MUST be volatile</td> |
| </tr> |
| <tr class="even"> |
| <td style="text-align: left;">DMA : DMA2 instance cannot be configured in LL drivers</td> |
| </tr> |
| <tr class="odd"> |
| <td style="text-align: left;">GPIO: HAL_GPIO_DeInit() bug on EXTI management</td> |
| </tr> |
| <tr class="even"> |
| <td style="text-align: left;">GPIO: Compilation warning with IAR v8.30</td> |
| </tr> |
| <tr class="odd"> |
| <td style="text-align: left;">HAL: Correct potential issue within HAL_SetTickFreq() function</td> |
| </tr> |
| <tr class="even"> |
| <td style="text-align: left;">HRTIM: HRTIM_TIMxCR.DELCMP isn’t systematically programmed</td> |
| </tr> |
| <tr class="odd"> |
| <td style="text-align: left;">HRTIM: Fault source programming isn’t wrong in HAL_HRTIM_FaultConfig</td> |
| </tr> |
| <tr class="even"> |
| <td style="text-align: left;">HRTIM : Useless Assignment at function HAL_HRTIM_SimpleOCChannelConfig</td> |
| </tr> |
| <tr class="odd"> |
| <td style="text-align: left;">RCC: Should not overwrite Tick priority</td> |
| </tr> |
| <tr class="even"> |
| <td style="text-align: left;">RTC: HAL_RTCEx_SetWakeUpTimer WUTWF management reworked to be aligned with Reference Manual</td> |
| </tr> |
| <tr class="odd"> |
| <td style="text-align: left;">RTC: INITF can rise too early when entering init mode just after exiting</td> |
| </tr> |
| <tr class="even"> |
| <td style="text-align: left;">RTC : fix issue in define with STM32L4 LL RTC month macros</td> |
| </tr> |
| <tr class="odd"> |
| <td style="text-align: left;">RTC : Remove ALRBWF and ALRAWF bits</td> |
| </tr> |
| <tr class="even"> |
| <td style="text-align: left;">TIM: CodeSonar warnings about useless assignment in HAL_TIMEx_ConfigBreakInput()</td> |
| </tr> |
| </tbody> |
| </table> |
| <h2 id="development-toolchains-and-compilers-6">Development Toolchains and Compilers</h2> |
| <ul> |
| <li>IAR Embedded Workbench for ARM (EWARM) toolchain V8.20.2</li> |
| <li>RealView Microcontroller Development Kit (MDK-ARM) toolchain V5.25</li> |
| <li>System Workbench STM32 (SW4STM32) toolchain V2.7.2</li> |
| </ul> |
| <h2 id="supported-devices-6">Supported Devices</h2> |
| <ul> |
| <li>STM32G431/41xx</li> |
| <li>STM32G471xx</li> |
| <li>STM32G473/<strong>83xx</strong></li> |
| <li>STM32G474/84xx</li> |
| </ul> |
| </div> |
| </div> |
| <div class="collapse"> |
| <input type="checkbox" id="collapse-section1" aria-hidden="true"> <label for="collapse-section1" aria-hidden="true">V1.0.0 / 12-April-2019</label> |
| <div> |
| <h2 id="main-changes-7">Main Changes</h2> |
| <h3 id="first-release">First release</h3> |
| <p>First official release of HAL (Hardware Abstraction Layer) and LL (Low layers) drivers to support STM32G431/41xx, STM32G471xx, STM32G473/83xx and STM32G474/84xx.</p> |
| <h2 id="development-toolchains-and-compilers-7">Development Toolchains and Compilers</h2> |
| <ul> |
| <li>IAR Embedded Workbench for ARM (EWARM) toolchain V8.20.2</li> |
| <li>RealView Microcontroller Development Kit (MDK-ARM) toolchain V5.25</li> |
| <li>System Workbench STM32 (SW4STM32) toolchain V2.7.2</li> |
| </ul> |
| <h2 id="supported-devices-7">Supported Devices</h2> |
| <ul> |
| <li>STM32G431/41xx</li> |
| <li>STM32G471xx</li> |
| <li>STM32G473xx</li> |
| <li>STM32G474/84xx</li> |
| </ul> |
| </div> |
| </div> |
| </section> |
| </div> |
| <footer class="sticky"> |
| <p>For complete documentation on STM32G4xx, visit: [<a href="http://www.st.com/stm32g4">www.st.com/stm32g4</a>]</p> |
| <p>This release note uses up to date web standards and, for this reason, should not be opened with Internet Explorer but preferably with popular browsers such as Google Chrome, Mozilla Firefox, Opera or Microsoft Edge.</p> |
| </footer> |
| </body> |
| </html> |