From f41ff24a3a9621e720c35be117b5550a8f7cd0ed Mon Sep 17 00:00:00 2001 From: Francois Ramu Date: Wed, 26 Feb 2020 09:07:02 +0100 Subject: [PATCH] driver: clock: stm32: boost voltage when clock exceeds 80MHz This patch activates the boost mode for the main regulator when the system frequency above 80MHz for stm32l4Rx/stm32l4Sx soc series. To save power, the boost mode should be disabled below 80MHz. Signed-off-by: Francois Ramu --- drivers/clock_control/clock_stm32l4_wb.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/drivers/clock_control/clock_stm32l4_wb.c b/drivers/clock_control/clock_stm32l4_wb.c index 972a7b3c47..7fc5c97ae8 100644 --- a/drivers/clock_control/clock_stm32l4_wb.c +++ b/drivers/clock_control/clock_stm32l4_wb.c @@ -30,6 +30,12 @@ void config_pll_init(LL_UTILS_PLLInitTypeDef *pllinit) pllinit->PLLM = pllm(CONFIG_CLOCK_STM32_PLL_M_DIVISOR); pllinit->PLLN = CONFIG_CLOCK_STM32_PLL_N_MULTIPLIER; pllinit->PLLR = pllr(CONFIG_CLOCK_STM32_PLL_R_DIVISOR); +#ifdef PWR_CR5_R1MODE + /* set power boost mode for sys clock greater than 80MHz */ + if (sys_clock_hw_cycles_per_sec() >= MHZ(80)) { + LL_PWR_EnableRange1BoostMode(); + } +#endif /* PWR_CR5_R1MODE */ } #endif /* CONFIG_CLOCK_STM32_SYSCLK_SRC_PLL */