10#ifndef ZEPHYR_INCLUDE_DRIVERS_CLOCK_CONTROL_STM32_CLOCK_CONTROL_H_
11#define ZEPHYR_INCLUDE_DRIVERS_CLOCK_CONTROL_STM32_CLOCK_CONTROL_H_
15#if defined(CONFIG_SOC_SERIES_STM32C0X)
17#elif defined(CONFIG_SOC_SERIES_STM32F0X)
19#elif defined(CONFIG_SOC_SERIES_STM32F1X)
20#if defined(CONFIG_SOC_STM32F10X_CONNECTIVITY_LINE_DEVICE)
25#elif defined(CONFIG_SOC_SERIES_STM32F3X)
27#elif defined(CONFIG_SOC_SERIES_STM32F2X) || \
28 defined(CONFIG_SOC_SERIES_STM32F4X)
31#elif defined(CONFIG_SOC_SERIES_STM32F7X)
33#elif defined(CONFIG_SOC_SERIES_STM32G0X)
35#elif defined(CONFIG_SOC_SERIES_STM32G4X)
37#elif defined(CONFIG_SOC_SERIES_STM32L0X)
39#elif defined(CONFIG_SOC_SERIES_STM32L1X)
41#elif defined(CONFIG_SOC_SERIES_STM32L4X) || \
42 defined(CONFIG_SOC_SERIES_STM32L5X)
44#elif defined(CONFIG_SOC_SERIES_STM32MP2X)
46#elif defined(CONFIG_SOC_SERIES_STM32WBX)
48#elif defined(CONFIG_SOC_SERIES_STM32WB0X)
50#elif defined(CONFIG_SOC_SERIES_STM32WLX)
52#elif defined(CONFIG_SOC_SERIES_STM32H5X)
54#elif defined(CONFIG_SOC_SERIES_STM32H7X)
56#elif defined(CONFIG_SOC_SERIES_STM32H7RSX)
58#elif defined(CONFIG_SOC_SERIES_STM32MP13X)
60#elif defined(CONFIG_SOC_SERIES_STM32N6X)
62#elif defined(CONFIG_SOC_SERIES_STM32U0X)
64#elif defined(CONFIG_SOC_SERIES_STM32U3X)
66#elif defined(CONFIG_SOC_SERIES_STM32U5X)
68#elif defined(CONFIG_SOC_SERIES_STM32WBAX)
75#define STM32_CLOCK_CONTROL_NODE DT_NODELABEL(rcc)
79#define STM32_AHB_PRESCALER DT_PROP(DT_NODELABEL(rcc), ahb_prescaler)
80#define STM32_APB1_PRESCALER DT_PROP(DT_NODELABEL(rcc), apb1_prescaler)
81#define STM32_APB2_PRESCALER DT_PROP(DT_NODELABEL(rcc), apb2_prescaler)
82#define STM32_APB3_PRESCALER DT_PROP(DT_NODELABEL(rcc), apb3_prescaler)
83#define STM32_APB4_PRESCALER DT_PROP(DT_NODELABEL(rcc), apb4_prescaler)
84#define STM32_APB5_PRESCALER DT_PROP(DT_NODELABEL(rcc), apb5_prescaler)
85#define STM32_APB7_PRESCALER DT_PROP(DT_NODELABEL(rcc), apb7_prescaler)
86#define STM32_AHB3_PRESCALER DT_PROP(DT_NODELABEL(rcc), ahb3_prescaler)
87#define STM32_AHB4_PRESCALER DT_PROP(DT_NODELABEL(rcc), ahb4_prescaler)
88#define STM32_AHB5_PRESCALER DT_PROP_OR(DT_NODELABEL(rcc), ahb5_prescaler, 1)
89#define STM32_CPU1_PRESCALER DT_PROP(DT_NODELABEL(rcc), cpu1_prescaler)
90#define STM32_CPU2_PRESCALER DT_PROP(DT_NODELABEL(rcc), cpu2_prescaler)
92#if DT_NODE_HAS_PROP(DT_NODELABEL(rcc), ahb_prescaler)
93#define STM32_CORE_PRESCALER STM32_AHB_PRESCALER
94#elif DT_NODE_HAS_PROP(DT_NODELABEL(rcc), cpu1_prescaler)
95#define STM32_CORE_PRESCALER STM32_CPU1_PRESCALER
98#if DT_NODE_HAS_PROP(DT_NODELABEL(rcc), ahb3_prescaler)
99#define STM32_FLASH_PRESCALER STM32_AHB3_PRESCALER
100#elif DT_NODE_HAS_PROP(DT_NODELABEL(rcc), ahb4_prescaler)
101#define STM32_FLASH_PRESCALER STM32_AHB4_PRESCALER
103#define STM32_FLASH_PRESCALER STM32_CORE_PRESCALER
106#define STM32_ADC_PRESCALER DT_PROP(DT_NODELABEL(rcc), adc_prescaler)
107#define STM32_ADC12_PRESCALER DT_PROP(DT_NODELABEL(rcc), adc12_prescaler)
108#define STM32_ADC34_PRESCALER DT_PROP(DT_NODELABEL(rcc), adc34_prescaler)
110#define STM32_TIMER_PRESCALER DT_PROP(DT_NODELABEL(rcc), timpre)
113#if defined(CONFIG_SOC_SERIES_STM32H7RSX)
114#define STM32_D1CPRE DT_PROP(DT_NODELABEL(rcc), dcpre)
115#define STM32_HPRE DT_PROP(DT_NODELABEL(rcc), hpre)
116#define STM32_PPRE1 DT_PROP(DT_NODELABEL(rcc), ppre1)
117#define STM32_PPRE2 DT_PROP(DT_NODELABEL(rcc), ppre2)
118#define STM32_PPRE4 DT_PROP(DT_NODELABEL(rcc), ppre4)
119#define STM32_PPRE5 DT_PROP(DT_NODELABEL(rcc), ppre5)
121#define STM32_D1CPRE DT_PROP(DT_NODELABEL(rcc), d1cpre)
122#define STM32_HPRE DT_PROP(DT_NODELABEL(rcc), hpre)
123#define STM32_D2PPRE1 DT_PROP(DT_NODELABEL(rcc), d2ppre1)
124#define STM32_D2PPRE2 DT_PROP(DT_NODELABEL(rcc), d2ppre2)
125#define STM32_D1PPRE DT_PROP(DT_NODELABEL(rcc), d1ppre)
126#define STM32_D3PPRE DT_PROP(DT_NODELABEL(rcc), d3ppre)
130#define STM32_AHB5_DIV DT_PROP(DT_NODELABEL(rcc), ahb5_div)
132#define DT_RCC_CLOCKS_CTRL DT_CLOCKS_CTLR(DT_NODELABEL(rcc))
137#if DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(pll))
138#define STM32_SYSCLK_SRC_PLL 1
140#if DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(clk_hsi))
141#define STM32_SYSCLK_SRC_HSI 1
143#if DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(clk_hse))
144#define STM32_SYSCLK_SRC_HSE 1
146#if DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(clk_msi))
147#define STM32_SYSCLK_SRC_MSI 1
149#if DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(clk_msis))
150#define STM32_SYSCLK_SRC_MSIS 1
152#if DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(clk_csi))
153#define STM32_SYSCLK_SRC_CSI 1
155#if DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(ic2))
156#define STM32_SYSCLK_SRC_IC2 1
159#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(rcc), st_stm32n6_rcc, okay)
160#if (DT_SAME_NODE(DT_CLOCKS_CTLR_BY_IDX(DT_NODELABEL(cpusw), 0), DT_NODELABEL(rcc)))
161#if (DT_CLOCKS_CELL_BY_IDX(DT_NODELABEL(cpusw), 0, bus) == STM32_SRC_HSI)
162#define STM32_CPUCLK_SRC_HSI 1
163#elif (DT_CLOCKS_CELL_BY_IDX(DT_NODELABEL(cpusw), 0, bus) == STM32_SRC_MSI)
164#define STM32_CPUCLK_SRC_MSI 1
165#elif (DT_CLOCKS_CELL_BY_IDX(DT_NODELABEL(cpusw), 0, bus) == STM32_SRC_HSE)
166#define STM32_CPUCLK_SRC_HSE 1
167#elif (DT_CLOCKS_CELL_BY_IDX(DT_NODELABEL(cpusw), 0, bus) == STM32_SRC_IC1)
168#define STM32_CPUCLK_SRC_IC1 1
172#define STM32_TIMG_PRESCALER DT_PROP(DT_NODELABEL(rcc), timg_prescaler)
177#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f2_pll_clock, okay) || \
178 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f4_pll_clock, okay) || \
179 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f7_pll_clock, okay) || \
180 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32g0_pll_clock, okay) || \
181 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32g4_pll_clock, okay) || \
182 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32l4_pll_clock, okay) || \
183 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32u0_pll_clock, okay) || \
184 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32u5_pll_clock, okay) || \
185 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32wb_pll_clock, okay) || \
186 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32wba_pll_clock, okay) || \
187 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32h7_pll_clock, okay) || \
188 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32h7rs_pll_clock, okay) || \
189 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32mp13_pll_clock, okay)
190#define STM32_PLL_ENABLED 1
191#define STM32_PLL_M_DIVISOR DT_PROP(DT_NODELABEL(pll), div_m)
192#define STM32_PLL_N_MULTIPLIER DT_PROP(DT_NODELABEL(pll), mul_n)
193#define STM32_PLL_P_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll), div_p)
194#define STM32_PLL_P_DIVISOR DT_PROP_OR(DT_NODELABEL(pll), div_p, 1)
195#define STM32_PLL_Q_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll), div_q)
196#define STM32_PLL_Q_DIVISOR DT_PROP_OR(DT_NODELABEL(pll), div_q, 1)
197#define STM32_PLL_R_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll), div_r)
198#define STM32_PLL_R_DIVISOR DT_PROP_OR(DT_NODELABEL(pll), div_r, 1)
199#define STM32_PLL_S_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll), div_s)
200#define STM32_PLL_S_DIVISOR DT_PROP_OR(DT_NODELABEL(pll), div_s, 1)
201#define STM32_PLL_FRACN_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll), fracn)
202#define STM32_PLL_FRACN_VALUE DT_PROP_OR(DT_NODELABEL(pll), fracn, 1)
205#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(plli2s), st_stm32f4_plli2s_clock, okay)
206#define STM32_PLLI2S_ENABLED 1
207#define STM32_PLLI2S_M_DIVISOR STM32_PLL_M_DIVISOR
208#define STM32_PLLI2S_N_MULTIPLIER DT_PROP(DT_NODELABEL(plli2s), mul_n)
209#define STM32_PLLI2S_R_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(plli2s), div_r)
210#define STM32_PLLI2S_R_DIVISOR DT_PROP_OR(DT_NODELABEL(plli2s), div_r, 1)
213#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(plli2s), st_stm32f411_plli2s_clock, okay)
214#define STM32_PLLI2S_ENABLED 1
215#define STM32_PLLI2S_M_DIVISOR DT_PROP(DT_NODELABEL(plli2s), div_m)
216#define STM32_PLLI2S_N_MULTIPLIER DT_PROP(DT_NODELABEL(plli2s), mul_n)
217#define STM32_PLLI2S_Q_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(plli2s), div_q)
218#define STM32_PLLI2S_Q_DIVISOR DT_PROP_OR(DT_NODELABEL(plli2s), div_q, 1)
219#define STM32_PLLI2S_R_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(plli2s), div_r)
220#define STM32_PLLI2S_R_DIVISOR DT_PROP_OR(DT_NODELABEL(plli2s), div_r, 1)
223#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pllsai), st_stm32fx_pllsai_clock, okay)
224#define STM32_PLLSAI_ENABLED 1
225#define STM32_PLLSAI_M_DIVISOR DT_PROP(DT_NODELABEL(pllsai), div_m)
226#define STM32_PLLSAI_N_MULTIPLIER DT_PROP(DT_NODELABEL(pllsai), mul_n)
227#define STM32_PLLSAI_P_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pllsai), div_p)
228#define STM32_PLLSAI_P_DIVISOR DT_PROP_OR(DT_NODELABEL(pllsai), div_p, 1)
229#define STM32_PLLSAI_Q_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pllsai), div_q)
230#define STM32_PLLSAI_DIVQ_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pllsai), div_divq)
231#if (STM32_PLLSAI_Q_ENABLED && !STM32_PLLSAI_DIVQ_ENABLED) || \
232 (!STM32_PLLSAI_Q_ENABLED && STM32_PLLSAI_DIVQ_ENABLED)
233#error "On STM32F4/STM32F7, both div_q and div_divq must be present if one of them is present"
235#define STM32_PLLSAI_Q_DIVISOR DT_PROP_OR(DT_NODELABEL(pllsai), div_q, 1)
236#define STM32_PLLSAI_DIVQ_DIVISOR DT_PROP_OR(DT_NODELABEL(pllsai), div_divq, 1)
237#define STM32_PLLSAI_R_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pllsai), div_r)
238#define STM32_PLLSAI_DIVR_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pllsai), div_divr)
239#if (STM32_PLLSAI_R_ENABLED && !STM32_PLLSAI_DIVR_ENABLED) || \
240 (!STM32_PLLSAI_R_ENABLED && STM32_PLLSAI_DIVR_ENABLED)
241#error "On STM32F4/STM32F7, both div_r and div_divr must be present if one of them is present"
243#define STM32_PLLSAI_R_DIVISOR DT_PROP_OR(DT_NODELABEL(pllsai), div_r, 1)
244#define STM32_PLLSAI_DIVR_DIVISOR DT_PROP_OR(DT_NODELABEL(pllsai), div_divr, 1)
247#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pllsai1), st_stm32l4_pllsai_clock, okay)
248#define STM32_PLLSAI1_ENABLED 1
249#define STM32_PLLSAI1_M_DIVISOR DT_PROP(DT_NODELABEL(pllsai1), div_m)
250#define STM32_PLLSAI1_N_MULTIPLIER DT_PROP(DT_NODELABEL(pllsai1), mul_n)
251#define STM32_PLLSAI1_P_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pllsai1), div_p)
252#define STM32_PLLSAI1_P_DIVISOR DT_PROP_OR(DT_NODELABEL(pllsai1), div_p, 1)
253#define STM32_PLLSAI1_Q_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pllsai1), div_q)
254#define STM32_PLLSAI1_Q_DIVISOR DT_PROP_OR(DT_NODELABEL(pllsai1), div_q, 1)
255#define STM32_PLLSAI1_R_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pllsai1), div_r)
256#define STM32_PLLSAI1_R_DIVISOR DT_PROP_OR(DT_NODELABEL(pllsai1), div_r, 1)
259#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pllsai2), st_stm32l4_pllsai_clock, okay)
260#define STM32_PLLSAI2_ENABLED 1
261#define STM32_PLLSAI2_M_DIVISOR DT_PROP(DT_NODELABEL(pllsai2), div_m)
262#define STM32_PLLSAI2_N_MULTIPLIER DT_PROP(DT_NODELABEL(pllsai2), mul_n)
263#define STM32_PLLSAI2_P_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pllsai2), div_p)
264#define STM32_PLLSAI2_P_DIVISOR DT_PROP_OR(DT_NODELABEL(pllsai2), div_p, 1)
265#define STM32_PLLSAI2_Q_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pllsai2), div_q)
266#define STM32_PLLSAI2_Q_DIVISOR DT_PROP_OR(DT_NODELABEL(pllsai2), div_q, 1)
267#define STM32_PLLSAI2_R_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pllsai2), div_r)
268#define STM32_PLLSAI2_R_DIVISOR DT_PROP_OR(DT_NODELABEL(pllsai2), div_r, 1)
269#define STM32_PLLSAI2_DIVR_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pllsai2), div_divr)
270#define STM32_PLLSAI2_DIVR_DIVISOR DT_PROP_OR(DT_NODELABEL(pllsai2), div_divr, 1)
273#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll2), st_stm32u5_pll_clock, okay) || \
274 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll2), st_stm32h7_pll_clock, okay) || \
275 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll2), st_stm32h7rs_pll_clock, okay) || \
276 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll2), st_stm32mp13_pll_clock, okay)
277#define STM32_PLL2_ENABLED 1
278#define STM32_PLL2_M_DIVISOR DT_PROP(DT_NODELABEL(pll2), div_m)
279#define STM32_PLL2_N_MULTIPLIER DT_PROP(DT_NODELABEL(pll2), mul_n)
280#define STM32_PLL2_P_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll2), div_p)
281#define STM32_PLL2_P_DIVISOR DT_PROP_OR(DT_NODELABEL(pll2), div_p, 1)
282#define STM32_PLL2_Q_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll2), div_q)
283#define STM32_PLL2_Q_DIVISOR DT_PROP_OR(DT_NODELABEL(pll2), div_q, 1)
284#define STM32_PLL2_R_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll2), div_r)
285#define STM32_PLL2_R_DIVISOR DT_PROP_OR(DT_NODELABEL(pll2), div_r, 1)
286#define STM32_PLL2_S_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll2), div_s)
287#define STM32_PLL2_S_DIVISOR DT_PROP_OR(DT_NODELABEL(pll2), div_s, 1)
288#define STM32_PLL2_T_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll2), div_t)
289#define STM32_PLL2_T_DIVISOR DT_PROP_OR(DT_NODELABEL(pll2), div_t, 1)
290#define STM32_PLL2_FRACN_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll2), fracn)
291#define STM32_PLL2_FRACN_VALUE DT_PROP_OR(DT_NODELABEL(pll2), fracn, 1)
294#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll3), st_stm32h7_pll_clock, okay) || \
295 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll3), st_stm32u5_pll_clock, okay) || \
296 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll3), st_stm32h7rs_pll_clock, okay) || \
297 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll3), st_stm32mp13_pll_clock, okay)
298#define STM32_PLL3_ENABLED 1
299#define STM32_PLL3_M_DIVISOR DT_PROP(DT_NODELABEL(pll3), div_m)
300#define STM32_PLL3_N_MULTIPLIER DT_PROP(DT_NODELABEL(pll3), mul_n)
301#define STM32_PLL3_P_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll3), div_p)
302#define STM32_PLL3_P_DIVISOR DT_PROP_OR(DT_NODELABEL(pll3), div_p, 1)
303#define STM32_PLL3_Q_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll3), div_q)
304#define STM32_PLL3_Q_DIVISOR DT_PROP_OR(DT_NODELABEL(pll3), div_q, 1)
305#define STM32_PLL3_R_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll3), div_r)
306#define STM32_PLL3_R_DIVISOR DT_PROP_OR(DT_NODELABEL(pll3), div_r, 1)
307#define STM32_PLL3_S_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll3), div_s)
308#define STM32_PLL3_S_DIVISOR DT_PROP_OR(DT_NODELABEL(pll3), div_s, 1)
309#define STM32_PLL3_FRACN_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll3), fracn)
310#define STM32_PLL3_FRACN_VALUE DT_PROP_OR(DT_NODELABEL(pll3), fracn, 1)
313#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll4), st_stm32mp13_pll_clock, okay)
314#define STM32_PLL4_ENABLED 1
315#define STM32_PLL4_M_DIVISOR DT_PROP(DT_NODELABEL(pll4), div_m)
316#define STM32_PLL4_N_MULTIPLIER DT_PROP(DT_NODELABEL(pll4), mul_n)
317#define STM32_PLL4_P_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll4), div_p)
318#define STM32_PLL4_P_DIVISOR DT_PROP_OR(DT_NODELABEL(pll4), div_p, 1)
319#define STM32_PLL4_Q_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll4), div_q)
320#define STM32_PLL4_Q_DIVISOR DT_PROP_OR(DT_NODELABEL(pll4), div_q, 1)
321#define STM32_PLL4_R_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll4), div_r)
322#define STM32_PLL4_R_DIVISOR DT_PROP_OR(DT_NODELABEL(pll4), div_r, 1)
323#define STM32_PLL4_FRACN_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll4), fracn)
324#define STM32_PLL4_FRACN_VALUE DT_PROP_OR(DT_NODELABEL(pll4), fracn, 1)
327#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f1_pll_clock, okay)
328#define STM32_PLL_ENABLED 1
329#define STM32_PLL_XTPRE DT_PROP(DT_NODELABEL(pll), xtpre)
330#define STM32_PLL_MULTIPLIER DT_PROP(DT_NODELABEL(pll), mul)
331#define STM32_PLL_USBPRE DT_PROP(DT_NODELABEL(pll), usbpre)
332#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f0_pll_clock, okay) || \
333 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f100_pll_clock, okay) || \
334 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f105_pll_clock, okay)
335#define STM32_PLL_ENABLED 1
336#define STM32_PLL_MULTIPLIER DT_PROP(DT_NODELABEL(pll), mul)
337#define STM32_PLL_PREDIV DT_PROP(DT_NODELABEL(pll), prediv)
338#define STM32_PLL_USBPRE DT_PROP(DT_NODELABEL(pll), otgfspre)
339#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32l0_pll_clock, okay)
340#define STM32_PLL_ENABLED 1
341#define STM32_PLL_DIVISOR DT_PROP(DT_NODELABEL(pll), div)
342#define STM32_PLL_MULTIPLIER DT_PROP(DT_NODELABEL(pll), mul)
345#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll2), st_stm32f105_pll2_clock, okay)
346#define STM32_PLL2_ENABLED 1
347#define STM32_PLL2_MULTIPLIER DT_PROP(DT_NODELABEL(pll2), mul)
348#define STM32_PLL2_PREDIV DT_PROP(DT_NODELABEL(pll2), prediv)
351#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll1), st_stm32n6_pll_clock, okay)
352#define STM32_PLL1_ENABLED 1
353#define STM32_PLL1_M_DIVISOR DT_PROP(DT_NODELABEL(pll1), div_m)
354#define STM32_PLL1_N_MULTIPLIER DT_PROP(DT_NODELABEL(pll1), mul_n)
355#define STM32_PLL1_P1_DIVISOR DT_PROP(DT_NODELABEL(pll1), div_p1)
356#define STM32_PLL1_P2_DIVISOR DT_PROP(DT_NODELABEL(pll1), div_p2)
359#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll2), st_stm32n6_pll_clock, okay)
360#define STM32_PLL2_ENABLED 1
361#define STM32_PLL2_M_DIVISOR DT_PROP(DT_NODELABEL(pll2), div_m)
362#define STM32_PLL2_N_MULTIPLIER DT_PROP(DT_NODELABEL(pll2), mul_n)
363#define STM32_PLL2_P1_DIVISOR DT_PROP(DT_NODELABEL(pll2), div_p1)
364#define STM32_PLL2_P2_DIVISOR DT_PROP(DT_NODELABEL(pll2), div_p2)
367#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll3), st_stm32n6_pll_clock, okay)
368#define STM32_PLL3_ENABLED 1
369#define STM32_PLL3_M_DIVISOR DT_PROP(DT_NODELABEL(pll3), div_m)
370#define STM32_PLL3_N_MULTIPLIER DT_PROP(DT_NODELABEL(pll3), mul_n)
371#define STM32_PLL3_P1_DIVISOR DT_PROP(DT_NODELABEL(pll3), div_p1)
372#define STM32_PLL3_P2_DIVISOR DT_PROP(DT_NODELABEL(pll3), div_p2)
375#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll4), st_stm32n6_pll_clock, okay)
376#define STM32_PLL4_ENABLED 1
377#define STM32_PLL4_M_DIVISOR DT_PROP(DT_NODELABEL(pll4), div_m)
378#define STM32_PLL4_N_MULTIPLIER DT_PROP(DT_NODELABEL(pll4), mul_n)
379#define STM32_PLL4_P1_DIVISOR DT_PROP(DT_NODELABEL(pll4), div_p1)
380#define STM32_PLL4_P2_DIVISOR DT_PROP(DT_NODELABEL(pll4), div_p2)
384#if DT_NODE_HAS_STATUS_OKAY(DT_NODELABEL(pll)) && \
385 DT_NODE_HAS_PROP(DT_NODELABEL(pll), clocks)
386#define DT_PLL_CLOCKS_CTRL DT_CLOCKS_CTLR(DT_NODELABEL(pll))
387#if DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(clk_msi))
388#define STM32_PLL_SRC_MSI 1
390#if DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(clk_msis))
391#define STM32_PLL_SRC_MSIS 1
393#if DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(clk_hsi))
394#define STM32_PLL_SRC_HSI 1
396#if DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(clk_csi))
397#define STM32_PLL_SRC_CSI 1
399#if DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(clk_hse))
400#define STM32_PLL_SRC_HSE 1
402#if DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(pll2))
403#define STM32_PLL_SRC_PLL2 1
409#if DT_NODE_HAS_STATUS_OKAY(DT_NODELABEL(pll2)) && \
410 DT_NODE_HAS_PROP(DT_NODELABEL(pll2), clocks)
411#define DT_PLL2_CLOCKS_CTRL DT_CLOCKS_CTLR(DT_NODELABEL(pll2))
412#if DT_SAME_NODE(DT_PLL2_CLOCKS_CTRL, DT_NODELABEL(clk_msi))
413#define STM32_PLL2_SRC_MSI 1
415#if DT_SAME_NODE(DT_PLL2_CLOCKS_CTRL, DT_NODELABEL(clk_msis))
416#define STM32_PLL2_SRC_MSIS 1
418#if DT_SAME_NODE(DT_PLL2_CLOCKS_CTRL, DT_NODELABEL(clk_hsi))
419#define STM32_PLL2_SRC_HSI 1
421#if DT_SAME_NODE(DT_PLL2_CLOCKS_CTRL, DT_NODELABEL(clk_hse))
422#define STM32_PLL2_SRC_HSE 1
428#if DT_NODE_HAS_STATUS_OKAY(DT_NODELABEL(pll3)) && \
429 DT_NODE_HAS_PROP(DT_NODELABEL(pll3), clocks)
430#define DT_PLL3_CLOCKS_CTRL DT_CLOCKS_CTLR(DT_NODELABEL(pll3))
431#if DT_SAME_NODE(DT_PLL3_CLOCKS_CTRL, DT_NODELABEL(clk_msi))
432#define STM32_PLL3_SRC_MSI 1
434#if DT_SAME_NODE(DT_PLL3_CLOCKS_CTRL, DT_NODELABEL(clk_msis))
435#define STM32_PLL3_SRC_MSIS 1
437#if DT_SAME_NODE(DT_PLL3_CLOCKS_CTRL, DT_NODELABEL(clk_hsi))
438#define STM32_PLL3_SRC_HSI 1
440#if DT_SAME_NODE(DT_PLL3_CLOCKS_CTRL, DT_NODELABEL(clk_hse))
441#define STM32_PLL3_SRC_HSE 1
447#if DT_NODE_HAS_STATUS(DT_NODELABEL(pll4), okay) && \
448 DT_NODE_HAS_PROP(DT_NODELABEL(pll4), clocks)
449#define DT_PLL4_CLOCKS_CTRL DT_CLOCKS_CTLR(DT_NODELABEL(pll4))
450#if DT_SAME_NODE(DT_PLL4_CLOCKS_CTRL, DT_NODELABEL(clk_msi))
451#define STM32_PLL4_SRC_MSI 1
453#if DT_SAME_NODE(DT_PLL4_CLOCKS_CTRL, DT_NODELABEL(clk_hsi))
454#define STM32_PLL4_SRC_HSI 1
456#if DT_SAME_NODE(DT_PLL4_CLOCKS_CTRL, DT_NODELABEL(clk_hse))
457#define STM32_PLL4_SRC_HSE 1
463#if DT_NODE_HAS_STATUS(DT_NODELABEL(pllsai), okay) && \
464 DT_NODE_HAS_PROP(DT_NODELABEL(pllsai), clocks)
465#define DT_PLLSAI_CLOCKS_CTRL DT_CLOCKS_CTLR(DT_NODELABEL(pllsai))
466#if DT_SAME_NODE(DT_PLLSAI_CLOCKS_CTRL, DT_NODELABEL(clk_hsi))
467#define STM32_PLLSAI_SRC_HSI 1
469#if DT_SAME_NODE(DT_PLLSAI_CLOCKS_CTRL, DT_NODELABEL(clk_hse))
470#define STM32_PLLSAI_SRC_HSE 1
476#if DT_NODE_HAS_STATUS(DT_NODELABEL(pllsai1), okay) && \
477 DT_NODE_HAS_PROP(DT_NODELABEL(pllsai1), clocks)
478#define DT_PLLSAI1_CLOCKS_CTRL DT_CLOCKS_CTLR(DT_NODELABEL(pllsai1))
479#if DT_SAME_NODE(DT_PLLSAI1_CLOCKS_CTRL, DT_NODELABEL(clk_msi))
480#define STM32_PLLSAI1_SRC_MSI 1
482#if DT_SAME_NODE(DT_PLLSAI1_CLOCKS_CTRL, DT_NODELABEL(clk_hsi))
483#define STM32_PLLSAI1_SRC_HSI 1
485#if DT_SAME_NODE(DT_PLLSAI1_CLOCKS_CTRL, DT_NODELABEL(clk_hse))
486#define STM32_PLLSAI1_SRC_HSE 1
492#if DT_NODE_HAS_STATUS(DT_NODELABEL(pllsai2), okay) && \
493 DT_NODE_HAS_PROP(DT_NODELABEL(pllsai2), clocks)
494#define DT_PLLSAI2_CLOCKS_CTRL DT_CLOCKS_CTLR(DT_NODELABEL(pllsai2))
495#if DT_SAME_NODE(DT_PLLSAI2_CLOCKS_CTRL, DT_NODELABEL(clk_msi))
496#define STM32_PLLSAI2_SRC_MSI 1
498#if DT_SAME_NODE(DT_PLLSAI2_CLOCKS_CTRL, DT_NODELABEL(clk_hsi))
499#define STM32_PLLSAI2_SRC_HSI 1
501#if DT_SAME_NODE(DT_PLLSAI2_CLOCKS_CTRL, DT_NODELABEL(clk_hse))
502#define STM32_PLLSAI2_SRC_HSE 1
508#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f4_pll_clock, okay) && \
509 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pllsai), st_stm32fx_pllsai_clock, okay) && \
510 !DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_PLLSAI_CLOCKS_CTRL)
511#error "On STM32F4 series, PLL and PLLSAI must have the same source"
515#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f7_pll_clock, okay) && \
516 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pllsai), st_stm32fx_pllsai_clock, okay) && \
517 !DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_PLLSAI_CLOCKS_CTRL)
518#error "On STM32F7 series, PLL and PLLSAI must have the same source"
522#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32l4_pll_clock, okay) && \
523 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pllsai1), st_stm32l4_pllsai_clock, okay) && \
524 !DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_PLLSAI1_CLOCKS_CTRL)
525#error "On STM32L4 series, PLL / PLLSAI1 must have the same source"
527#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32l4_pll_clock, okay) && \
528 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pllsai2), st_stm32l4_pllsai_clock, okay) && \
529 !DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_PLLSAI2_CLOCKS_CTRL)
530#error "On STM32L4 series, PLL / PLLSAI2 must have the same source"
532#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pllsai1), st_stm32l4_pllsai_clock, okay) && \
533 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pllsai2), st_stm32l4_pllsai_clock, okay) && \
534 !DT_SAME_NODE(DT_PLLSAI1_CLOCKS_CTRL, DT_PLLSAI2_CLOCKS_CTRL)
535#error "On STM32L4 series, PLLSAI1 / PLLSAI2 must have the same source"
540#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_lse), fixed_clock, okay)
541#define STM32_LSE_ENABLED 1
542#define STM32_LSE_FREQ DT_PROP(DT_NODELABEL(clk_lse), clock_frequency)
543#define STM32_LSE_DRIVING 0
544#define STM32_LSE_BYPASS DT_PROP(DT_NODELABEL(clk_lse), lse_bypass)
545#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_lse), st_stm32_lse_clock, okay)
546#define STM32_LSE_ENABLED 1
547#define STM32_LSE_FREQ DT_PROP(DT_NODELABEL(clk_lse), clock_frequency)
548#define STM32_LSE_DRIVING DT_PROP(DT_NODELABEL(clk_lse), driving_capability)
549#define STM32_LSE_BYPASS DT_PROP(DT_NODELABEL(clk_lse), lse_bypass)
551#define STM32_LSE_ENABLED 0
552#define STM32_LSE_FREQ 0
553#define STM32_LSE_DRIVING 0
554#define STM32_LSE_BYPASS 0
557#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msi), st_stm32_msi_clock, okay) || \
558 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msi), st_stm32l0_msi_clock, okay)
559#define STM32_MSI_ENABLED 1
560#define STM32_MSI_RANGE DT_PROP(DT_NODELABEL(clk_msi), msi_range)
563#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msi), st_stm32_msi_clock, okay)
564#define STM32_MSI_ENABLED 1
565#define STM32_MSI_PLL_MODE DT_PROP(DT_NODELABEL(clk_msi), msi_pll_mode)
568#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msis), st_stm32u5_msi_clock, okay) || \
569 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msis), st_stm32u3_msi_clock, okay)
570#define STM32_MSIS_ENABLED 1
571#define STM32_MSIS_RANGE DT_PROP(DT_NODELABEL(clk_msis), msi_range)
572#define STM32_MSIS_PLL_MODE DT_PROP(DT_NODELABEL(clk_msis), msi_pll_mode)
574#define STM32_MSIS_ENABLED 0
575#define STM32_MSIS_RANGE 0
576#define STM32_MSIS_PLL_MODE 0
579#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msik), st_stm32u5_msi_clock, okay) || \
580 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msik), st_stm32u3_msi_clock, okay)
581#define STM32_MSIK_ENABLED 1
582#define STM32_MSIK_RANGE DT_PROP(DT_NODELABEL(clk_msik), msi_range)
583#define STM32_MSIK_PLL_MODE DT_PROP(DT_NODELABEL(clk_msik), msi_pll_mode)
585#define STM32_MSIK_ENABLED 0
586#define STM32_MSIK_RANGE 0
587#define STM32_MSIK_PLL_MODE 0
590#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_csi), fixed_clock, okay)
591#define STM32_CSI_ENABLED 1
592#define STM32_CSI_FREQ DT_PROP(DT_NODELABEL(clk_csi), clock_frequency)
594#define STM32_CSI_FREQ 0
597#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_lsi), fixed_clock, okay)
598#define STM32_LSI_ENABLED 1
599#define STM32_LSI_FREQ DT_PROP(DT_NODELABEL(clk_lsi), clock_frequency)
600#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_lsi1), fixed_clock, okay)
601#define STM32_LSI_ENABLED 1
602#define STM32_LSI_FREQ DT_PROP(DT_NODELABEL(clk_lsi1), clock_frequency)
603#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_lsi2), fixed_clock, okay)
604#define STM32_LSI_ENABLED 1
605#define STM32_LSI_FREQ DT_PROP(DT_NODELABEL(clk_lsi2), clock_frequency)
607#define STM32_LSI_FREQ 0
610#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hsi), fixed_clock, okay)
611#define STM32_HSI_DIV_ENABLED 0
612#define STM32_HSI_ENABLED 1
613#define STM32_HSI_FREQ DT_PROP(DT_NODELABEL(clk_hsi), clock_frequency)
614#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hsi), st_stm32h7_hsi_clock, okay) \
615 || DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hsi), st_stm32l0_hsi_clock, okay) \
616 || DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hsi), st_stm32g0_hsi_clock, okay) \
617 || DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hsi), st_stm32c0_hsi_clock, okay) \
618 || DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hsi), st_stm32n6_hsi_clock, okay)
619#define STM32_HSI_DIV_ENABLED 1
620#define STM32_HSI_ENABLED 1
621#define STM32_HSI_DIVISOR DT_PROP(DT_NODELABEL(clk_hsi), hsi_div)
622#define STM32_HSI_FREQ DT_PROP(DT_NODELABEL(clk_hsi), clock_frequency)
624#define STM32_HSI_DIV_ENABLED 0
625#define STM32_HSI_DIVISOR 1
626#define STM32_HSI_FREQ 0
629#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hse), fixed_clock, okay)
630#define STM32_HSE_ENABLED 1
631#define STM32_HSE_FREQ DT_PROP(DT_NODELABEL(clk_hse), clock_frequency)
632#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hse), st_stm32_hse_clock, okay)
633#define STM32_HSE_ENABLED 1
634#define STM32_HSE_BYPASS DT_PROP(DT_NODELABEL(clk_hse), hse_bypass)
635#define STM32_HSE_FREQ DT_PROP(DT_NODELABEL(clk_hse), clock_frequency)
636#define STM32_HSE_CSS DT_PROP(DT_NODELABEL(clk_hse), css_enabled)
637#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hse), st_stm32wl_hse_clock, okay)
638#define STM32_HSE_ENABLED 1
639#define STM32_HSE_TCXO DT_PROP(DT_NODELABEL(clk_hse), hse_tcxo)
640#define STM32_HSE_DIV2 DT_PROP(DT_NODELABEL(clk_hse), hse_div2)
641#define STM32_HSE_FREQ DT_PROP(DT_NODELABEL(clk_hse), clock_frequency)
642#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hse), st_stm32wba_hse_clock, okay)
643#define STM32_HSE_ENABLED 1
644#define STM32_HSE_DIV2 DT_PROP(DT_NODELABEL(clk_hse), hse_div2)
645#define STM32_HSE_FREQ DT_PROP(DT_NODELABEL(clk_hse), clock_frequency)
646#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hse), st_stm32n6_hse_clock, okay)
647#define STM32_HSE_ENABLED 1
648#define STM32_HSE_BYPASS DT_PROP(DT_NODELABEL(clk_hse), hse_bypass)
649#define STM32_HSE_DIV2 DT_PROP(DT_NODELABEL(clk_hse), hse_div2)
650#define STM32_HSE_FREQ DT_PROP(DT_NODELABEL(clk_hse), clock_frequency)
652#define STM32_HSE_FREQ 0
655#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hsi48), fixed_clock, okay)
656#define STM32_HSI48_ENABLED 1
657#define STM32_HSI48_FREQ DT_PROP(DT_NODELABEL(clk_hsi48), clock_frequency)
658#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hsi48), st_stm32_hsi48_clock, okay)
659#define STM32_HSI48_ENABLED 1
660#define STM32_HSI48_FREQ DT_PROP(DT_NODELABEL(clk_hsi48), clock_frequency)
661#define STM32_HSI48_CRS_USB_SOF DT_PROP(DT_NODELABEL(clk_hsi48), crs_usb_sof)
664#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(perck), st_stm32_clock_mux, okay)
665#define STM32_CKPER_ENABLED 1
668#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(cpusw), st_stm32_clock_mux, okay)
669#define STM32_CPUSW_ENABLED 1
672#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic1), st_stm32n6_ic_clock_mux, okay)
673#define STM32_IC1_ENABLED 1
674#define STM32_IC1_PLL_SRC DT_PROP(DT_NODELABEL(ic1), pll_src)
675#define STM32_IC1_DIV DT_PROP(DT_NODELABEL(ic1), ic_div)
678#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic2), st_stm32n6_ic_clock_mux, okay)
679#define STM32_IC2_ENABLED 1
680#define STM32_IC2_PLL_SRC DT_PROP(DT_NODELABEL(ic2), pll_src)
681#define STM32_IC2_DIV DT_PROP(DT_NODELABEL(ic2), ic_div)
684#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic3), st_stm32n6_ic_clock_mux, okay)
685#define STM32_IC3_ENABLED 1
686#define STM32_IC3_PLL_SRC DT_PROP(DT_NODELABEL(ic3), pll_src)
687#define STM32_IC3_DIV DT_PROP(DT_NODELABEL(ic3), ic_div)
690#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic4), st_stm32n6_ic_clock_mux, okay)
691#define STM32_IC4_ENABLED 1
692#define STM32_IC4_PLL_SRC DT_PROP(DT_NODELABEL(ic4), pll_src)
693#define STM32_IC4_DIV DT_PROP(DT_NODELABEL(ic4), ic_div)
696#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic5), st_stm32n6_ic_clock_mux, okay)
697#define STM32_IC5_ENABLED 1
698#define STM32_IC5_PLL_SRC DT_PROP(DT_NODELABEL(ic5), pll_src)
699#define STM32_IC5_DIV DT_PROP(DT_NODELABEL(ic5), ic_div)
702#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic6), st_stm32n6_ic_clock_mux, okay)
703#define STM32_IC6_ENABLED 1
704#define STM32_IC6_PLL_SRC DT_PROP(DT_NODELABEL(ic6), pll_src)
705#define STM32_IC6_DIV DT_PROP(DT_NODELABEL(ic6), ic_div)
708#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic7), st_stm32n6_ic_clock_mux, okay)
709#define STM32_IC7_ENABLED 1
710#define STM32_IC7_PLL_SRC DT_PROP(DT_NODELABEL(ic7), pll_src)
711#define STM32_IC7_DIV DT_PROP(DT_NODELABEL(ic7), ic_div)
714#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic8), st_stm32n6_ic_clock_mux, okay)
715#define STM32_IC8_ENABLED 1
716#define STM32_IC8_PLL_SRC DT_PROP(DT_NODELABEL(ic8), pll_src)
717#define STM32_IC8_DIV DT_PROP(DT_NODELABEL(ic8), ic_div)
720#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic9), st_stm32n6_ic_clock_mux, okay)
721#define STM32_IC9_ENABLED 1
722#define STM32_IC9_PLL_SRC DT_PROP(DT_NODELABEL(ic9), pll_src)
723#define STM32_IC9_DIV DT_PROP(DT_NODELABEL(ic9), ic_div)
726#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic10), st_stm32n6_ic_clock_mux, okay)
727#define STM32_IC10_ENABLED 1
728#define STM32_IC10_PLL_SRC DT_PROP(DT_NODELABEL(ic10), pll_src)
729#define STM32_IC10_DIV DT_PROP(DT_NODELABEL(ic10), ic_div)
732#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic11), st_stm32n6_ic_clock_mux, okay)
733#define STM32_IC11_ENABLED 1
734#define STM32_IC11_PLL_SRC DT_PROP(DT_NODELABEL(ic11), pll_src)
735#define STM32_IC11_DIV DT_PROP(DT_NODELABEL(ic11), ic_div)
738#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic12), st_stm32n6_ic_clock_mux, okay)
739#define STM32_IC12_ENABLED 1
740#define STM32_IC12_PLL_SRC DT_PROP(DT_NODELABEL(ic12), pll_src)
741#define STM32_IC12_DIV DT_PROP(DT_NODELABEL(ic12), ic_div)
744#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic13), st_stm32n6_ic_clock_mux, okay)
745#define STM32_IC13_ENABLED 1
746#define STM32_IC13_PLL_SRC DT_PROP(DT_NODELABEL(ic13), pll_src)
747#define STM32_IC13_DIV DT_PROP(DT_NODELABEL(ic13), ic_div)
750#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic14), st_stm32n6_ic_clock_mux, okay)
751#define STM32_IC14_ENABLED 1
752#define STM32_IC14_PLL_SRC DT_PROP(DT_NODELABEL(ic14), pll_src)
753#define STM32_IC14_DIV DT_PROP(DT_NODELABEL(ic14), ic_div)
756#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic15), st_stm32n6_ic_clock_mux, okay)
757#define STM32_IC15_ENABLED 1
758#define STM32_IC15_PLL_SRC DT_PROP(DT_NODELABEL(ic15), pll_src)
759#define STM32_IC15_DIV DT_PROP(DT_NODELABEL(ic15), ic_div)
762#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic16), st_stm32n6_ic_clock_mux, okay)
763#define STM32_IC16_ENABLED 1
764#define STM32_IC16_PLL_SRC DT_PROP(DT_NODELABEL(ic16), pll_src)
765#define STM32_IC16_DIV DT_PROP(DT_NODELABEL(ic16), ic_div)
768#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic17), st_stm32n6_ic_clock_mux, okay)
769#define STM32_IC17_ENABLED 1
770#define STM32_IC17_PLL_SRC DT_PROP(DT_NODELABEL(ic17), pll_src)
771#define STM32_IC17_DIV DT_PROP(DT_NODELABEL(ic17), ic_div)
774#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic18), st_stm32n6_ic_clock_mux, okay)
775#define STM32_IC18_ENABLED 1
776#define STM32_IC18_PLL_SRC DT_PROP(DT_NODELABEL(ic18), pll_src)
777#define STM32_IC18_DIV DT_PROP(DT_NODELABEL(ic18), ic_div)
780#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic19), st_stm32n6_ic_clock_mux, okay)
781#define STM32_IC19_ENABLED 1
782#define STM32_IC19_PLL_SRC DT_PROP(DT_NODELABEL(ic19), pll_src)
783#define STM32_IC19_DIV DT_PROP(DT_NODELABEL(ic19), ic_div)
786#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic20), st_stm32n6_ic_clock_mux, okay)
787#define STM32_IC20_ENABLED 1
788#define STM32_IC20_PLL_SRC DT_PROP(DT_NODELABEL(ic20), pll_src)
789#define STM32_IC20_DIV DT_PROP(DT_NODELABEL(ic20), ic_div)
802#define STM32_CLOCK_INFO(clk_index, node_id) \
804 .enr = DT_CLOCKS_CELL_BY_IDX(node_id, clk_index, bits), \
805 .bus = DT_CLOCKS_CELL_BY_IDX(node_id, clk_index, bus) & \
806 GENMASK(STM32_CLOCK_DIV_SHIFT - 1, 0), \
807 .div = DT_CLOCKS_CELL_BY_IDX(node_id, clk_index, bus) >> \
808 STM32_CLOCK_DIV_SHIFT, \
810#define STM32_DT_CLOCKS(node_id) \
812 LISTIFY(DT_NUM_CLOCKS(node_id), \
813 STM32_CLOCK_INFO, (,), node_id) \
816#define STM32_DT_INST_CLOCKS(inst) \
817 STM32_DT_CLOCKS(DT_DRV_INST(inst))
819#define STM32_DOMAIN_CLOCK_INST_SUPPORT(inst) DT_INST_CLOCKS_HAS_IDX(inst, 1) ||
820#define STM32_DT_INST_DEV_DOMAIN_CLOCK_SUPPORT \
821 (DT_INST_FOREACH_STATUS_OKAY(STM32_DOMAIN_CLOCK_INST_SUPPORT) 0)
823#define STM32_DOMAIN_CLOCK_SUPPORT(id) DT_CLOCKS_HAS_IDX(DT_NODELABEL(id), 1) ||
824#define STM32_DT_DEV_DOMAIN_CLOCK_SUPPORT \
825 (DT_FOREACH_STATUS_OKAY(STM32_DOMAIN_CLOCK_SUPPORT) 0)
834#define STM32_DT_CLKSEL_REG_GET(clock) \
835 (((clock) >> STM32_DT_CLKSEL_REG_SHIFT) & STM32_DT_CLKSEL_REG_MASK)
842#define STM32_DT_CLKSEL_SHIFT_GET(clock) \
843 (((clock) >> STM32_DT_CLKSEL_SHIFT_SHIFT) & STM32_DT_CLKSEL_SHIFT_MASK)
850#define STM32_DT_CLKSEL_MASK_GET(clock) \
851 (((clock) >> STM32_DT_CLKSEL_MASK_SHIFT) & STM32_DT_CLKSEL_MASK_MASK)
858#define STM32_DT_CLKSEL_VAL_GET(clock) \
859 (((clock) >> STM32_DT_CLKSEL_VAL_SHIFT) & STM32_DT_CLKSEL_VAL_MASK)
861#if defined(STM32_HSE_CSS)
870void stm32_hse_css_callback(
void);
873#ifdef CONFIG_SOC_SERIES_STM32WB0X
878typedef void (*lsi_update_cb_t)(
uint32_t new_lsi_frequency);
891int stm32wb0_register_lsi_update_callback(lsi_update_cb_t cb);
Main header file for clock control driver API.
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
#define STM32_CLOCK_DIV_SHIFT
Definition stm32_clock.h:27
Driver structure definition.
Definition stm32_clock_control.h:794
uint32_t div
Definition stm32_clock_control.h:796
uint32_t bus
Definition stm32_clock_control.h:795
uint32_t enr
Definition stm32_clock_control.h:797