2025-01-02 02:45 AM
Software Versions
Issue:
Hello everyone, we are encountering an issue that might be related to the HAL (although we think this is unlikely as it is a rather fundamental function of the HAL).
We're developing software on a STM32H753BIT6 MCU on a custom PCB. We're making use of CubeMX and the STM32H7 HAL (provided by CubeMX). Currently we are measuring the baud rate of the UART4 that we are using to be half of the expected baud rate (115200). Upon code inspection is found that the uart prescaler is incorrectly calculated. It assumes a peripheral clock speed of 240MHz instead of the configured 120Mhz.
See our CubeMX clock configuration:
When inspecting the HAL implementation of the uart we see that the baud rate prescaler is calculated using the HAL_RCC_GetPCLK1Freq() function. You would expect the function to return 120000000, but instead it return 240000000.
We've narrowed the issue down to the way that the PCLK1 frequency is calculated in the STM32Cube HAL.
return (HAL_RCC_GetHCLKFreq() >> ((D1CorePrescTable[(RCC->D2CFGR & RCC_D2CFGR_D2PPRE1) >> RCC_D2CFGR_D2PPRE1_Pos]) & 0x1FU));
HAL_RCC_GetHCLKFreq correctly return 240MHz and the D2PPRE1 is correctly read as 0x04, which corresponds to a division of 2. Which is in line with our CubeMX configuration. However the D1CorePrescTable returns 0 instead of a shift 1. Are we linking against the wrong CMSIS file.
Since this is such a fundamental function we are surprised that we are running into such a low-level issue.
Solved! Go to Solution.
2025-01-02 02:59 AM
Hello @jellemeijer and welcome to the community,
Please check this thread.
2025-01-02 02:59 AM
Hello @jellemeijer and welcome to the community,
Please check this thread.
2025-01-02 05:58 AM - edited 2025-01-02 06:06 AM
FYI: the issue has been already fixed with the patch 1.12.1
+
https://github.com/STMicroelectronics/STM32CubeH7/issues/301