2022-12-07 08:10 AM - last edited on 2023-09-01 09:38 AM by Amel NASRI
Hi!
I'd like to reconfigure power supply settings on our custom board with an STM32H742.
I've done some research reading reference manual and application note.
CubeMX has generated code with the following two calls I am using inside of SystemClock_Config():
HAL_PWREx_ConfigSupply(PWR_EXTERNAL_SOURCE_SUPPLY);
...
__HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1);
...
This seems to make sense for me. However, HAL_PWREx_ConfigSupply() returns with a HAL_ERROR error code as it seems that the "Supply configuration update enable" bit (PWR_CR3->SCUEN) is not set.
Is there any HAL or LL API function that I must call to set the bit?
Or do it completely manual (which feels wrong right now)?
Or am I missing some other setting/prerequisite here?
I don't want to brick my controller. :grinning_face:
Best regards
2022-12-09 12:49 AM
Hello @mwb,
I invite you to check this article for power supply configuration
Unable to connect to STM32H7 devices
You can find the configurable parameters in CubeMX in this screenshot
To give better visibility on the answered topics, please click on Accept as Solution on the reply which solved your issue or answered your question.
2022-12-14 01:49 AM
Bonjour @F.Belaid ,
thanks for the reference to CubeMX.
I think this is a debugging phenomenon. In my understanding the SCUEN bit is reset to 1 after POR.
When the configuration is updated, the bit is automatically cleared.
However, this leads to a problem during debugging as in my understanding the target is a) being flashed, resets and boots after flashing and then b) is restarted another time when the debugger is attached. This is why we never see the bit beeing set in a debug session.
Another run after resetting the target's power works: the HAL driver still checks the SCUEN bit, "sees" it being set to 0 but exits with HAL_OK as there's no new different value to be written to the register:
HAL_StatusTypeDef HAL_PWREx_ConfigSupply (uint32_t SupplySource)
{
uint32_t tickstart;
/* Check the parameters */
assert_param (IS_PWR_SUPPLY (SupplySource));
/* Check if supply source was configured */
#if defined (PWR_FLAG_SCUEN)
if (__HAL_PWR_GET_FLAG (PWR_FLAG_SCUEN) == 0U)
#else
if ((PWR->CR3 & (PWR_CR3_SMPSEN | PWR_CR3_LDOEN | PWR_CR3_BYPASS)) != (PWR_CR3_SMPSEN | PWR_CR3_LDOEN))
#endif /* defined (PWR_FLAG_SCUEN) */
{
/* Check supply configuration */
if ((PWR->CR3 & PWR_SUPPLY_CONFIG_MASK) != SupplySource)
{
/* Supply configuration update locked, can't apply a new supply config */
return HAL_ERROR;
}
else
{
/* Supply configuration update locked, but new supply configuration
matches with old supply configuration : nothing to do
*/
return HAL_OK; // <------------------------ returns here
}
}
I'd be happy if you could confirm my theory.
Best regards
2022-12-14 07:05 AM
Hello again @mwb,
Power is configured once after POR; it cannot be changed. You need to perform power down then power up to switch to a new power mode.
To give better visibility on the answered topics, please click on Accept as Solution on the reply which solved your issue or answered your question.