summaryrefslogtreecommitdiff
path: root/os/drivers/clock/stm32f769_clock_control.c
diff options
context:
space:
mode:
authorKonstantin Kirik (snegovick) <snegovick@uprojects.org>2026-01-07 21:07:48 +0300
committerKonstantin Kirik (snegovick) <snegovick@uprojects.org>2026-01-07 21:07:48 +0300
commit860e71622e1c9ab558aa7ff2c6fff2b2b8a1862d (patch)
tree09300c18e3da608041a65f5b4d59af2a664c6e21 /os/drivers/clock/stm32f769_clock_control.c
parente18d4312c5f246902426baffb4ad1d03d50fce88 (diff)
Re-use CONFIG_definitions instead of cmsis ones
Diffstat (limited to 'os/drivers/clock/stm32f769_clock_control.c')
-rw-r--r--os/drivers/clock/stm32f769_clock_control.c11
1 files changed, 6 insertions, 5 deletions
diff --git a/os/drivers/clock/stm32f769_clock_control.c b/os/drivers/clock/stm32f769_clock_control.c
index 31cc8f1a..2b4c1fe1 100644
--- a/os/drivers/clock/stm32f769_clock_control.c
+++ b/os/drivers/clock/stm32f769_clock_control.c
@@ -9,7 +9,7 @@
#include "stm32f769_clocks.h"
#define STM32F769_CLOCK_ID_OFFSET(id) (((id) >> 6U) & 0xFFU)
-#define STM32F769_CLOCK_ID_BIT(id) ((id)&0x1FU)
+#define STM32F769_CLOCK_ID_BIT(id) (id & 0x1FU)
volatile uint64_t uptime_ctr;
@@ -18,6 +18,8 @@ void SysTick_Handler(void) {
}
int stm32f769_clock_control_on(uint16_t id) {
+ uint32_t addr = RCC_BASE + STM32F769_CLOCK_ID_OFFSET(id);
+ uint32_t bit = STM32F769_CLOCK_ID_BIT(id);
sys_set_bit(RCC_BASE + STM32F769_CLOCK_ID_OFFSET(id),
STM32F769_CLOCK_ID_BIT(id));
int ret = sys_test_bit(RCC_BASE + STM32F769_CLOCK_ID_OFFSET(id),
@@ -126,7 +128,6 @@ int stm32f769_clock_control_get_rate(uint16_t id, uint32_t *rate)
int stm32f769_clock_control_init(struct device *dev)
{
uint32_t tickstart;
- uint32_t pll_config;
if ((__HAL_RCC_GET_SYSCLK_SOURCE() == RCC_SYSCLKSOURCE_STATUS_HSE) || ((__HAL_RCC_GET_SYSCLK_SOURCE() == RCC_SYSCLKSOURCE_STATUS_PLLCLK) && ((RCC->PLLCFGR & RCC_PLLCFGR_PLLSRC) == RCC_PLLCFGR_PLLSRC_HSE))) {
if ((__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) != 0)) {// && (RCC_OscInitStruct->HSEState == RCC_HSE_OFF)) {
@@ -136,10 +137,10 @@ int stm32f769_clock_control_init(struct device *dev)
#if defined(CONFIG_BOARD_HSE_CLK)
#if CONFIG_BOARD_HSE_BYP == 1
- sys_set_bit(RCC->CR, RCC_CR_HSEBYP);
- sys_set_bit(RCC->CR, RCC_CR_HSEON);
+ RCC->CR |= RCC_CR_HSEBYP;
+ RCC->CR |= RCC_CR_HSEON;
#else
- sys_set_bit(RCC->CR, RCC_CR_HSEON);
+ RCC->CR |= RCC_CR_HSEON;
#endif
/* Get Start Tick*/
tickstart = uptime_ctr;