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_STM32WBX)
46#elif defined(CONFIG_SOC_SERIES_STM32WB0X)
48#elif defined(CONFIG_SOC_SERIES_STM32WLX)
50#elif defined(CONFIG_SOC_SERIES_STM32H5X)
52#elif defined(CONFIG_SOC_SERIES_STM32H7X)
54#elif defined(CONFIG_SOC_SERIES_STM32H7RSX)
56#elif defined(CONFIG_SOC_SERIES_STM32N6X)
58#elif defined(CONFIG_SOC_SERIES_STM32U0X)
60#elif defined(CONFIG_SOC_SERIES_STM32U5X)
62#elif defined(CONFIG_SOC_SERIES_STM32WBAX)
69#define STM32_CLOCK_CONTROL_NODE DT_NODELABEL(rcc)
73#define STM32_AHB_PRESCALER DT_PROP(DT_NODELABEL(rcc), ahb_prescaler)
74#define STM32_APB1_PRESCALER DT_PROP(DT_NODELABEL(rcc), apb1_prescaler)
75#define STM32_APB2_PRESCALER DT_PROP(DT_NODELABEL(rcc), apb2_prescaler)
76#define STM32_APB3_PRESCALER DT_PROP(DT_NODELABEL(rcc), apb3_prescaler)
77#define STM32_APB4_PRESCALER DT_PROP(DT_NODELABEL(rcc), apb4_prescaler)
78#define STM32_APB5_PRESCALER DT_PROP(DT_NODELABEL(rcc), apb5_prescaler)
79#define STM32_APB7_PRESCALER DT_PROP(DT_NODELABEL(rcc), apb7_prescaler)
80#define STM32_AHB3_PRESCALER DT_PROP(DT_NODELABEL(rcc), ahb3_prescaler)
81#define STM32_AHB4_PRESCALER DT_PROP(DT_NODELABEL(rcc), ahb4_prescaler)
82#define STM32_AHB5_PRESCALER DT_PROP_OR(DT_NODELABEL(rcc), ahb5_prescaler, 1)
83#define STM32_CPU1_PRESCALER DT_PROP(DT_NODELABEL(rcc), cpu1_prescaler)
84#define STM32_CPU2_PRESCALER DT_PROP(DT_NODELABEL(rcc), cpu2_prescaler)
86#if DT_NODE_HAS_PROP(DT_NODELABEL(rcc), ahb_prescaler)
87#define STM32_CORE_PRESCALER STM32_AHB_PRESCALER
88#elif DT_NODE_HAS_PROP(DT_NODELABEL(rcc), cpu1_prescaler)
89#define STM32_CORE_PRESCALER STM32_CPU1_PRESCALER
92#if DT_NODE_HAS_PROP(DT_NODELABEL(rcc), ahb3_prescaler)
93#define STM32_FLASH_PRESCALER STM32_AHB3_PRESCALER
94#elif DT_NODE_HAS_PROP(DT_NODELABEL(rcc), ahb4_prescaler)
95#define STM32_FLASH_PRESCALER STM32_AHB4_PRESCALER
97#define STM32_FLASH_PRESCALER STM32_CORE_PRESCALER
100#define STM32_ADC_PRESCALER DT_PROP(DT_NODELABEL(rcc), adc_prescaler)
101#define STM32_ADC12_PRESCALER DT_PROP(DT_NODELABEL(rcc), adc12_prescaler)
102#define STM32_ADC34_PRESCALER DT_PROP(DT_NODELABEL(rcc), adc34_prescaler)
105#if defined(CONFIG_SOC_SERIES_STM32H7RSX)
106#define STM32_D1CPRE DT_PROP(DT_NODELABEL(rcc), dcpre)
107#define STM32_HPRE DT_PROP(DT_NODELABEL(rcc), hpre)
108#define STM32_PPRE1 DT_PROP(DT_NODELABEL(rcc), ppre1)
109#define STM32_PPRE2 DT_PROP(DT_NODELABEL(rcc), ppre2)
110#define STM32_PPRE4 DT_PROP(DT_NODELABEL(rcc), ppre4)
111#define STM32_PPRE5 DT_PROP(DT_NODELABEL(rcc), ppre5)
113#define STM32_D1CPRE DT_PROP(DT_NODELABEL(rcc), d1cpre)
114#define STM32_HPRE DT_PROP(DT_NODELABEL(rcc), hpre)
115#define STM32_D2PPRE1 DT_PROP(DT_NODELABEL(rcc), d2ppre1)
116#define STM32_D2PPRE2 DT_PROP(DT_NODELABEL(rcc), d2ppre2)
117#define STM32_D1PPRE DT_PROP(DT_NODELABEL(rcc), d1ppre)
118#define STM32_D3PPRE DT_PROP(DT_NODELABEL(rcc), d3ppre)
122#define STM32_AHB5_DIV DT_PROP(DT_NODELABEL(rcc), ahb5_div)
124#define DT_RCC_CLOCKS_CTRL DT_CLOCKS_CTLR(DT_NODELABEL(rcc))
129#if DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(pll))
130#define STM32_SYSCLK_SRC_PLL 1
132#if DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(clk_hsi))
133#define STM32_SYSCLK_SRC_HSI 1
135#if DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(clk_hse))
136#define STM32_SYSCLK_SRC_HSE 1
138#if DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(clk_msi))
139#define STM32_SYSCLK_SRC_MSI 1
141#if DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(clk_msis))
142#define STM32_SYSCLK_SRC_MSIS 1
144#if DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(clk_csi))
145#define STM32_SYSCLK_SRC_CSI 1
147#if DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(ic2))
148#define STM32_SYSCLK_SRC_IC2 1
154#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f2_pll_clock, okay) || \
155 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f4_pll_clock, okay) || \
156 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f7_pll_clock, okay) || \
157 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32g0_pll_clock, okay) || \
158 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32g4_pll_clock, okay) || \
159 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32l4_pll_clock, okay) || \
160 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32u0_pll_clock, okay) || \
161 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32u5_pll_clock, okay) || \
162 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32wb_pll_clock, okay) || \
163 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32wba_pll_clock, okay) || \
164 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32h7_pll_clock, okay) || \
165 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32h7rs_pll_clock, okay)
166#define STM32_PLL_ENABLED 1
167#define STM32_PLL_M_DIVISOR DT_PROP(DT_NODELABEL(pll), div_m)
168#define STM32_PLL_N_MULTIPLIER DT_PROP(DT_NODELABEL(pll), mul_n)
169#define STM32_PLL_P_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll), div_p)
170#define STM32_PLL_P_DIVISOR DT_PROP_OR(DT_NODELABEL(pll), div_p, 1)
171#define STM32_PLL_Q_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll), div_q)
172#define STM32_PLL_Q_DIVISOR DT_PROP_OR(DT_NODELABEL(pll), div_q, 1)
173#define STM32_PLL_R_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll), div_r)
174#define STM32_PLL_R_DIVISOR DT_PROP_OR(DT_NODELABEL(pll), div_r, 1)
175#define STM32_PLL_S_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll), div_s)
176#define STM32_PLL_S_DIVISOR DT_PROP_OR(DT_NODELABEL(pll), div_s, 1)
177#define STM32_PLL_FRACN_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll), fracn)
178#define STM32_PLL_FRACN_VALUE DT_PROP_OR(DT_NODELABEL(pll), fracn, 1)
181#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(plli2s), st_stm32f4_plli2s_clock, okay)
182#define STM32_PLLI2S_ENABLED 1
183#define STM32_PLLI2S_M_DIVISOR STM32_PLL_M_DIVISOR
184#define STM32_PLLI2S_N_MULTIPLIER DT_PROP(DT_NODELABEL(plli2s), mul_n)
185#define STM32_PLLI2S_R_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(plli2s), div_r)
186#define STM32_PLLI2S_R_DIVISOR DT_PROP_OR(DT_NODELABEL(plli2s), div_r, 1)
189#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(plli2s), st_stm32f411_plli2s_clock, okay)
190#define STM32_PLLI2S_ENABLED 1
191#define STM32_PLLI2S_M_DIVISOR DT_PROP(DT_NODELABEL(plli2s), div_m)
192#define STM32_PLLI2S_N_MULTIPLIER DT_PROP(DT_NODELABEL(plli2s), mul_n)
193#define STM32_PLLI2S_Q_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(plli2s), div_q)
194#define STM32_PLLI2S_Q_DIVISOR DT_PROP_OR(DT_NODELABEL(plli2s), div_q, 1)
195#define STM32_PLLI2S_R_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(plli2s), div_r)
196#define STM32_PLLI2S_R_DIVISOR DT_PROP_OR(DT_NODELABEL(plli2s), div_r, 1)
199#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll2), st_stm32u5_pll_clock, okay) || \
200 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll2), st_stm32h7_pll_clock, okay) || \
201 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll2), st_stm32h7rs_pll_clock, okay)
202#define STM32_PLL2_ENABLED 1
203#define STM32_PLL2_M_DIVISOR DT_PROP(DT_NODELABEL(pll2), div_m)
204#define STM32_PLL2_N_MULTIPLIER DT_PROP(DT_NODELABEL(pll2), mul_n)
205#define STM32_PLL2_P_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll2), div_p)
206#define STM32_PLL2_P_DIVISOR DT_PROP_OR(DT_NODELABEL(pll2), div_p, 1)
207#define STM32_PLL2_Q_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll2), div_q)
208#define STM32_PLL2_Q_DIVISOR DT_PROP_OR(DT_NODELABEL(pll2), div_q, 1)
209#define STM32_PLL2_R_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll2), div_r)
210#define STM32_PLL2_R_DIVISOR DT_PROP_OR(DT_NODELABEL(pll2), div_r, 1)
211#define STM32_PLL2_S_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll2), div_s)
212#define STM32_PLL2_S_DIVISOR DT_PROP_OR(DT_NODELABEL(pll2), div_s, 1)
213#define STM32_PLL2_T_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll2), div_t)
214#define STM32_PLL2_T_DIVISOR DT_PROP_OR(DT_NODELABEL(pll2), div_t, 1)
215#define STM32_PLL2_FRACN_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll2), fracn)
216#define STM32_PLL2_FRACN_VALUE DT_PROP_OR(DT_NODELABEL(pll2), fracn, 1)
219#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll3), st_stm32h7_pll_clock, okay) || \
220 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll3), st_stm32u5_pll_clock, okay) || \
221 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll3), st_stm32h7rs_pll_clock, okay)
222#define STM32_PLL3_ENABLED 1
223#define STM32_PLL3_M_DIVISOR DT_PROP(DT_NODELABEL(pll3), div_m)
224#define STM32_PLL3_N_MULTIPLIER DT_PROP(DT_NODELABEL(pll3), mul_n)
225#define STM32_PLL3_P_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll3), div_p)
226#define STM32_PLL3_P_DIVISOR DT_PROP_OR(DT_NODELABEL(pll3), div_p, 1)
227#define STM32_PLL3_Q_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll3), div_q)
228#define STM32_PLL3_Q_DIVISOR DT_PROP_OR(DT_NODELABEL(pll3), div_q, 1)
229#define STM32_PLL3_R_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll3), div_r)
230#define STM32_PLL3_R_DIVISOR DT_PROP_OR(DT_NODELABEL(pll3), div_r, 1)
231#define STM32_PLL3_S_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll3), div_s)
232#define STM32_PLL3_S_DIVISOR DT_PROP_OR(DT_NODELABEL(pll3), div_s, 1)
233#define STM32_PLL3_FRACN_ENABLED DT_NODE_HAS_PROP(DT_NODELABEL(pll3), fracn)
234#define STM32_PLL3_FRACN_VALUE DT_PROP_OR(DT_NODELABEL(pll3), fracn, 1)
237#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f1_pll_clock, okay)
238#define STM32_PLL_ENABLED 1
239#define STM32_PLL_XTPRE DT_PROP(DT_NODELABEL(pll), xtpre)
240#define STM32_PLL_MULTIPLIER DT_PROP(DT_NODELABEL(pll), mul)
241#define STM32_PLL_USBPRE DT_PROP(DT_NODELABEL(pll), usbpre)
242#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f0_pll_clock, okay) || \
243 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f100_pll_clock, okay) || \
244 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f105_pll_clock, okay)
245#define STM32_PLL_ENABLED 1
246#define STM32_PLL_MULTIPLIER DT_PROP(DT_NODELABEL(pll), mul)
247#define STM32_PLL_PREDIV DT_PROP(DT_NODELABEL(pll), prediv)
248#define STM32_PLL_USBPRE DT_PROP(DT_NODELABEL(pll), otgfspre)
249#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32l0_pll_clock, okay)
250#define STM32_PLL_ENABLED 1
251#define STM32_PLL_DIVISOR DT_PROP(DT_NODELABEL(pll), div)
252#define STM32_PLL_MULTIPLIER DT_PROP(DT_NODELABEL(pll), mul)
255#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll2), st_stm32f105_pll2_clock, okay)
256#define STM32_PLL2_ENABLED 1
257#define STM32_PLL2_MULTIPLIER DT_PROP(DT_NODELABEL(pll2), mul)
258#define STM32_PLL2_PREDIV DT_PROP(DT_NODELABEL(pll2), prediv)
261#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll1), st_stm32n6_pll_clock, okay)
262#define STM32_PLL1_ENABLED 1
263#define STM32_PLL1_M_DIVISOR DT_PROP(DT_NODELABEL(pll1), div_m)
264#define STM32_PLL1_N_MULTIPLIER DT_PROP(DT_NODELABEL(pll1), mul_n)
265#define STM32_PLL1_P1_DIVISOR DT_PROP(DT_NODELABEL(pll1), div_p1)
266#define STM32_PLL1_P2_DIVISOR DT_PROP(DT_NODELABEL(pll1), div_p2)
269#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll2), st_stm32n6_pll_clock, okay)
270#define STM32_PLL2_ENABLED 1
271#define STM32_PLL2_M_DIVISOR DT_PROP(DT_NODELABEL(pll2), div_m)
272#define STM32_PLL2_N_MULTIPLIER DT_PROP(DT_NODELABEL(pll2), mul_n)
273#define STM32_PLL2_P1_DIVISOR DT_PROP(DT_NODELABEL(pll2), div_p1)
274#define STM32_PLL2_P2_DIVISOR DT_PROP(DT_NODELABEL(pll2), div_p2)
277#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll3), st_stm32n6_pll_clock, okay)
278#define STM32_PLL3_ENABLED 1
279#define STM32_PLL3_M_DIVISOR DT_PROP(DT_NODELABEL(pll3), div_m)
280#define STM32_PLL3_N_MULTIPLIER DT_PROP(DT_NODELABEL(pll3), mul_n)
281#define STM32_PLL3_P1_DIVISOR DT_PROP(DT_NODELABEL(pll3), div_p1)
282#define STM32_PLL3_P2_DIVISOR DT_PROP(DT_NODELABEL(pll3), div_p2)
285#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll4), st_stm32n6_pll_clock, okay)
286#define STM32_PLL4_ENABLED 1
287#define STM32_PLL4_M_DIVISOR DT_PROP(DT_NODELABEL(pll4), div_m)
288#define STM32_PLL4_N_MULTIPLIER DT_PROP(DT_NODELABEL(pll4), mul_n)
289#define STM32_PLL4_P1_DIVISOR DT_PROP(DT_NODELABEL(pll4), div_p1)
290#define STM32_PLL4_P2_DIVISOR DT_PROP(DT_NODELABEL(pll4), div_p2)
294#if DT_NODE_HAS_STATUS_OKAY(DT_NODELABEL(pll)) && \
295 DT_NODE_HAS_PROP(DT_NODELABEL(pll), clocks)
296#define DT_PLL_CLOCKS_CTRL DT_CLOCKS_CTLR(DT_NODELABEL(pll))
297#if DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(clk_msi))
298#define STM32_PLL_SRC_MSI 1
300#if DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(clk_msis))
301#define STM32_PLL_SRC_MSIS 1
303#if DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(clk_hsi))
304#define STM32_PLL_SRC_HSI 1
306#if DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(clk_csi))
307#define STM32_PLL_SRC_CSI 1
309#if DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(clk_hse))
310#define STM32_PLL_SRC_HSE 1
312#if DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(pll2))
313#define STM32_PLL_SRC_PLL2 1
319#if DT_NODE_HAS_STATUS_OKAY(DT_NODELABEL(pll2)) && \
320 DT_NODE_HAS_PROP(DT_NODELABEL(pll2), clocks)
321#define DT_PLL2_CLOCKS_CTRL DT_CLOCKS_CTLR(DT_NODELABEL(pll2))
322#if DT_SAME_NODE(DT_PLL2_CLOCKS_CTRL, DT_NODELABEL(clk_msi))
323#define STM32_PLL2_SRC_MSI 1
325#if DT_SAME_NODE(DT_PLL2_CLOCKS_CTRL, DT_NODELABEL(clk_msis))
326#define STM32_PLL2_SRC_MSIS 1
328#if DT_SAME_NODE(DT_PLL2_CLOCKS_CTRL, DT_NODELABEL(clk_hsi))
329#define STM32_PLL2_SRC_HSI 1
331#if DT_SAME_NODE(DT_PLL2_CLOCKS_CTRL, DT_NODELABEL(clk_hse))
332#define STM32_PLL2_SRC_HSE 1
338#if DT_NODE_HAS_STATUS_OKAY(DT_NODELABEL(pll3)) && \
339 DT_NODE_HAS_PROP(DT_NODELABEL(pll3), clocks)
340#define DT_PLL3_CLOCKS_CTRL DT_CLOCKS_CTLR(DT_NODELABEL(pll3))
341#if DT_SAME_NODE(DT_PLL3_CLOCKS_CTRL, DT_NODELABEL(clk_msi))
342#define STM32_PLL3_SRC_MSI 1
344#if DT_SAME_NODE(DT_PLL3_CLOCKS_CTRL, DT_NODELABEL(clk_msis))
345#define STM32_PLL3_SRC_MSIS 1
347#if DT_SAME_NODE(DT_PLL3_CLOCKS_CTRL, DT_NODELABEL(clk_hsi))
348#define STM32_PLL3_SRC_HSI 1
350#if DT_SAME_NODE(DT_PLL3_CLOCKS_CTRL, DT_NODELABEL(clk_hse))
351#define STM32_PLL3_SRC_HSE 1
357#if DT_NODE_HAS_STATUS(DT_NODELABEL(pll4), okay) && \
358 DT_NODE_HAS_PROP(DT_NODELABEL(pll4), clocks)
359#define DT_PLL4_CLOCKS_CTRL DT_CLOCKS_CTLR(DT_NODELABEL(pll4))
360#if DT_SAME_NODE(DT_PLL4_CLOCKS_CTRL, DT_NODELABEL(clk_msi))
361#define STM32_PLL4_SRC_MSI 1
363#if DT_SAME_NODE(DT_PLL4_CLOCKS_CTRL, DT_NODELABEL(clk_hsi))
364#define STM32_PLL4_SRC_HSI 1
366#if DT_SAME_NODE(DT_PLL4_CLOCKS_CTRL, DT_NODELABEL(clk_hse))
367#define STM32_PLL4_SRC_HSE 1
375#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_lse), fixed_clock, okay)
376#define STM32_LSE_ENABLED 1
377#define STM32_LSE_FREQ DT_PROP(DT_NODELABEL(clk_lse), clock_frequency)
378#define STM32_LSE_DRIVING 0
379#define STM32_LSE_BYPASS DT_PROP(DT_NODELABEL(clk_lse), lse_bypass)
380#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_lse), st_stm32_lse_clock, okay)
381#define STM32_LSE_ENABLED 1
382#define STM32_LSE_FREQ DT_PROP(DT_NODELABEL(clk_lse), clock_frequency)
383#define STM32_LSE_DRIVING DT_PROP(DT_NODELABEL(clk_lse), driving_capability)
384#define STM32_LSE_BYPASS DT_PROP(DT_NODELABEL(clk_lse), lse_bypass)
386#define STM32_LSE_ENABLED 0
387#define STM32_LSE_FREQ 0
388#define STM32_LSE_DRIVING 0
389#define STM32_LSE_BYPASS 0
392#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msi), st_stm32_msi_clock, okay) || \
393 DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msi), st_stm32l0_msi_clock, okay)
394#define STM32_MSI_ENABLED 1
395#define STM32_MSI_RANGE DT_PROP(DT_NODELABEL(clk_msi), msi_range)
398#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msi), st_stm32_msi_clock, okay)
399#define STM32_MSI_ENABLED 1
400#define STM32_MSI_PLL_MODE DT_PROP(DT_NODELABEL(clk_msi), msi_pll_mode)
403#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msis), st_stm32u5_msi_clock, okay)
404#define STM32_MSIS_ENABLED 1
405#define STM32_MSIS_RANGE DT_PROP(DT_NODELABEL(clk_msis), msi_range)
406#define STM32_MSIS_PLL_MODE DT_PROP(DT_NODELABEL(clk_msis), msi_pll_mode)
408#define STM32_MSIS_ENABLED 0
409#define STM32_MSIS_RANGE 0
410#define STM32_MSIS_PLL_MODE 0
413#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msik), st_stm32u5_msi_clock, okay)
414#define STM32_MSIK_ENABLED 1
415#define STM32_MSIK_RANGE DT_PROP(DT_NODELABEL(clk_msik), msi_range)
416#define STM32_MSIK_PLL_MODE DT_PROP(DT_NODELABEL(clk_msik), msi_pll_mode)
418#define STM32_MSIK_ENABLED 0
419#define STM32_MSIK_RANGE 0
420#define STM32_MSIK_PLL_MODE 0
423#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_csi), fixed_clock, okay)
424#define STM32_CSI_ENABLED 1
425#define STM32_CSI_FREQ DT_PROP(DT_NODELABEL(clk_csi), clock_frequency)
427#define STM32_CSI_FREQ 0
430#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_lsi), fixed_clock, okay)
431#define STM32_LSI_ENABLED 1
432#define STM32_LSI_FREQ DT_PROP(DT_NODELABEL(clk_lsi), clock_frequency)
433#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_lsi1), fixed_clock, okay)
434#define STM32_LSI_ENABLED 1
435#define STM32_LSI_FREQ DT_PROP(DT_NODELABEL(clk_lsi1), clock_frequency)
436#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_lsi2), fixed_clock, okay)
437#define STM32_LSI_ENABLED 1
438#define STM32_LSI_FREQ DT_PROP(DT_NODELABEL(clk_lsi2), clock_frequency)
440#define STM32_LSI_FREQ 0
443#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hsi), fixed_clock, okay)
444#define STM32_HSI_DIV_ENABLED 0
445#define STM32_HSI_ENABLED 1
446#define STM32_HSI_FREQ DT_PROP(DT_NODELABEL(clk_hsi), clock_frequency)
447#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hsi), st_stm32h7_hsi_clock, okay) \
448 || DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hsi), st_stm32g0_hsi_clock, okay) \
449 || DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hsi), st_stm32c0_hsi_clock, okay)
450#define STM32_HSI_DIV_ENABLED 1
451#define STM32_HSI_ENABLED 1
452#define STM32_HSI_DIVISOR DT_PROP(DT_NODELABEL(clk_hsi), hsi_div)
453#define STM32_HSI_FREQ DT_PROP(DT_NODELABEL(clk_hsi), clock_frequency)
455#define STM32_HSI_DIV_ENABLED 0
456#define STM32_HSI_DIVISOR 1
457#define STM32_HSI_FREQ 0
460#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hse), fixed_clock, okay)
461#define STM32_HSE_ENABLED 1
462#define STM32_HSE_FREQ DT_PROP(DT_NODELABEL(clk_hse), clock_frequency)
463#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hse), st_stm32_hse_clock, okay)
464#define STM32_HSE_ENABLED 1
465#define STM32_HSE_BYPASS DT_PROP(DT_NODELABEL(clk_hse), hse_bypass)
466#define STM32_HSE_FREQ DT_PROP(DT_NODELABEL(clk_hse), clock_frequency)
467#define STM32_HSE_CSS DT_PROP(DT_NODELABEL(clk_hse), css_enabled)
468#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hse), st_stm32wl_hse_clock, okay)
469#define STM32_HSE_ENABLED 1
470#define STM32_HSE_TCXO DT_PROP(DT_NODELABEL(clk_hse), hse_tcxo)
471#define STM32_HSE_DIV2 DT_PROP(DT_NODELABEL(clk_hse), hse_div2)
472#define STM32_HSE_FREQ DT_PROP(DT_NODELABEL(clk_hse), clock_frequency)
473#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hse), st_stm32wba_hse_clock, okay)
474#define STM32_HSE_ENABLED 1
475#define STM32_HSE_DIV2 DT_PROP(DT_NODELABEL(clk_hse), hse_div2)
476#define STM32_HSE_FREQ DT_PROP(DT_NODELABEL(clk_hse), clock_frequency)
477#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hse), st_stm32n6_hse_clock, okay)
478#define STM32_HSE_ENABLED 1
479#define STM32_HSE_BYPASS DT_PROP(DT_NODELABEL(clk_hse), hse_bypass)
480#define STM32_HSE_DIV2 DT_PROP(DT_NODELABEL(clk_hse), hse_div2)
481#define STM32_HSE_FREQ DT_PROP(DT_NODELABEL(clk_hse), clock_frequency)
483#define STM32_HSE_FREQ 0
486#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hsi48), fixed_clock, okay)
487#define STM32_HSI48_ENABLED 1
488#define STM32_HSI48_FREQ DT_PROP(DT_NODELABEL(clk_hsi48), clock_frequency)
489#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hsi48), st_stm32_hsi48_clock, okay)
490#define STM32_HSI48_ENABLED 1
491#define STM32_HSI48_FREQ DT_PROP(DT_NODELABEL(clk_hsi48), clock_frequency)
492#define STM32_HSI48_CRS_USB_SOF DT_PROP(DT_NODELABEL(clk_hsi48), crs_usb_sof)
495#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(perck), st_stm32_clock_mux, okay)
496#define STM32_CKPER_ENABLED 1
499#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(cpusw), st_stm32_clock_mux, okay)
500#define STM32_CPUSW_ENABLED 1
503#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic1), st_stm32n6_ic_clock_mux, okay)
504#define STM32_IC1_ENABLED 1
505#define STM32_IC1_PLL_SRC DT_PROP(DT_NODELABEL(ic1), pll_src)
506#define STM32_IC1_DIV DT_PROP(DT_NODELABEL(ic1), ic_div)
509#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic2), st_stm32n6_ic_clock_mux, okay)
510#define STM32_IC2_ENABLED 1
511#define STM32_IC2_PLL_SRC DT_PROP(DT_NODELABEL(ic2), pll_src)
512#define STM32_IC2_DIV DT_PROP(DT_NODELABEL(ic2), ic_div)
515#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic3), st_stm32n6_ic_clock_mux, okay)
516#define STM32_IC3_ENABLED 1
517#define STM32_IC3_PLL_SRC DT_PROP(DT_NODELABEL(ic3), pll_src)
518#define STM32_IC3_DIV DT_PROP(DT_NODELABEL(ic3), ic_div)
521#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic4), st_stm32n6_ic_clock_mux, okay)
522#define STM32_IC4_ENABLED 1
523#define STM32_IC4_PLL_SRC DT_PROP(DT_NODELABEL(ic4), pll_src)
524#define STM32_IC4_DIV DT_PROP(DT_NODELABEL(ic4), ic_div)
527#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic5), st_stm32n6_ic_clock_mux, okay)
528#define STM32_IC5_ENABLED 1
529#define STM32_IC5_PLL_SRC DT_PROP(DT_NODELABEL(ic5), pll_src)
530#define STM32_IC5_DIV DT_PROP(DT_NODELABEL(ic5), ic_div)
533#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic6), st_stm32n6_ic_clock_mux, okay)
534#define STM32_IC6_ENABLED 1
535#define STM32_IC6_PLL_SRC DT_PROP(DT_NODELABEL(ic6), pll_src)
536#define STM32_IC6_DIV DT_PROP(DT_NODELABEL(ic6), ic_div)
539#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic7), st_stm32n6_ic_clock_mux, okay)
540#define STM32_IC7_ENABLED 1
541#define STM32_IC7_PLL_SRC DT_PROP(DT_NODELABEL(ic7), pll_src)
542#define STM32_IC7_DIV DT_PROP(DT_NODELABEL(ic7), ic_div)
545#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic8), st_stm32n6_ic_clock_mux, okay)
546#define STM32_IC8_ENABLED 1
547#define STM32_IC8_PLL_SRC DT_PROP(DT_NODELABEL(ic8), pll_src)
548#define STM32_IC8_DIV DT_PROP(DT_NODELABEL(ic8), ic_div)
551#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic9), st_stm32n6_ic_clock_mux, okay)
552#define STM32_IC9_ENABLED 1
553#define STM32_IC9_PLL_SRC DT_PROP(DT_NODELABEL(ic9), pll_src)
554#define STM32_IC9_DIV DT_PROP(DT_NODELABEL(ic9), ic_div)
557#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic10), st_stm32n6_ic_clock_mux, okay)
558#define STM32_IC10_ENABLED 1
559#define STM32_IC10_PLL_SRC DT_PROP(DT_NODELABEL(ic10), pll_src)
560#define STM32_IC10_DIV DT_PROP(DT_NODELABEL(ic10), ic_div)
563#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic11), st_stm32n6_ic_clock_mux, okay)
564#define STM32_IC11_ENABLED 1
565#define STM32_IC11_PLL_SRC DT_PROP(DT_NODELABEL(ic11), pll_src)
566#define STM32_IC11_DIV DT_PROP(DT_NODELABEL(ic11), ic_div)
569#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic12), st_stm32n6_ic_clock_mux, okay)
570#define STM32_IC12_ENABLED 1
571#define STM32_IC12_PLL_SRC DT_PROP(DT_NODELABEL(ic12), pll_src)
572#define STM32_IC12_DIV DT_PROP(DT_NODELABEL(ic12), ic_div)
575#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic13), st_stm32n6_ic_clock_mux, okay)
576#define STM32_IC13_ENABLED 1
577#define STM32_IC13_PLL_SRC DT_PROP(DT_NODELABEL(ic13), pll_src)
578#define STM32_IC13_DIV DT_PROP(DT_NODELABEL(ic13), ic_div)
581#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic14), st_stm32n6_ic_clock_mux, okay)
582#define STM32_IC14_ENABLED 1
583#define STM32_IC14_PLL_SRC DT_PROP(DT_NODELABEL(ic14), pll_src)
584#define STM32_IC14_DIV DT_PROP(DT_NODELABEL(ic14), ic_div)
587#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic15), st_stm32n6_ic_clock_mux, okay)
588#define STM32_IC15_ENABLED 1
589#define STM32_IC15_PLL_SRC DT_PROP(DT_NODELABEL(ic15), pll_src)
590#define STM32_IC15_DIV DT_PROP(DT_NODELABEL(ic15), ic_div)
593#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic16), st_stm32n6_ic_clock_mux, okay)
594#define STM32_IC16_ENABLED 1
595#define STM32_IC16_PLL_SRC DT_PROP(DT_NODELABEL(ic16), pll_src)
596#define STM32_IC16_DIV DT_PROP(DT_NODELABEL(ic16), ic_div)
599#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic17), st_stm32n6_ic_clock_mux, okay)
600#define STM32_IC17_ENABLED 1
601#define STM32_IC17_PLL_SRC DT_PROP(DT_NODELABEL(ic17), pll_src)
602#define STM32_IC17_DIV DT_PROP(DT_NODELABEL(ic17), ic_div)
605#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic18), st_stm32n6_ic_clock_mux, okay)
606#define STM32_IC18_ENABLED 1
607#define STM32_IC18_PLL_SRC DT_PROP(DT_NODELABEL(ic18), pll_src)
608#define STM32_IC18_DIV DT_PROP(DT_NODELABEL(ic18), ic_div)
611#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic19), st_stm32n6_ic_clock_mux, okay)
612#define STM32_IC19_ENABLED 1
613#define STM32_IC19_PLL_SRC DT_PROP(DT_NODELABEL(ic19), pll_src)
614#define STM32_IC19_DIV DT_PROP(DT_NODELABEL(ic19), ic_div)
617#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(ic20), st_stm32n6_ic_clock_mux, okay)
618#define STM32_IC20_ENABLED 1
619#define STM32_IC20_PLL_SRC DT_PROP(DT_NODELABEL(ic20), pll_src)
620#define STM32_IC20_DIV DT_PROP(DT_NODELABEL(ic20), ic_div)
633#define STM32_CLOCK_INFO(clk_index, node_id) \
635 .enr = DT_CLOCKS_CELL_BY_IDX(node_id, clk_index, bits), \
636 .bus = DT_CLOCKS_CELL_BY_IDX(node_id, clk_index, bus) & \
637 GENMASK(STM32_CLOCK_DIV_SHIFT - 1, 0), \
638 .div = DT_CLOCKS_CELL_BY_IDX(node_id, clk_index, bus) >> \
639 STM32_CLOCK_DIV_SHIFT, \
641#define STM32_DT_CLOCKS(node_id) \
643 LISTIFY(DT_NUM_CLOCKS(node_id), \
644 STM32_CLOCK_INFO, (,), node_id) \
647#define STM32_DT_INST_CLOCKS(inst) \
648 STM32_DT_CLOCKS(DT_DRV_INST(inst))
650#define STM32_DOMAIN_CLOCK_INST_SUPPORT(inst) DT_INST_CLOCKS_HAS_IDX(inst, 1) ||
651#define STM32_DT_INST_DEV_DOMAIN_CLOCK_SUPPORT \
652 (DT_INST_FOREACH_STATUS_OKAY(STM32_DOMAIN_CLOCK_INST_SUPPORT) 0)
654#define STM32_DOMAIN_CLOCK_SUPPORT(id) DT_CLOCKS_HAS_IDX(DT_NODELABEL(id), 1) ||
655#define STM32_DT_DEV_DOMAIN_CLOCK_SUPPORT \
656 (DT_FOREACH_STATUS_OKAY(STM32_DOMAIN_CLOCK_SUPPORT) 0)
665#define STM32_CLOCK_REG_GET(clock) \
666 (((clock) >> STM32_CLOCK_REG_SHIFT) & STM32_CLOCK_REG_MASK)
673#define STM32_CLOCK_SHIFT_GET(clock) \
674 (((clock) >> STM32_CLOCK_SHIFT_SHIFT) & STM32_CLOCK_SHIFT_MASK)
681#define STM32_CLOCK_MASK_GET(clock) \
682 (((clock) >> STM32_CLOCK_MASK_SHIFT) & STM32_CLOCK_MASK_MASK)
689#define STM32_CLOCK_VAL_GET(clock) \
690 (((clock) >> STM32_CLOCK_VAL_SHIFT) & STM32_CLOCK_VAL_MASK)
697#define STM32_MCO_CFGR_REG_GET(mco_cfgr) \
698 (((mco_cfgr) >> STM32_MCO_CFGR_REG_SHIFT) & STM32_MCO_CFGR_REG_MASK)
705#define STM32_MCO_CFGR_SHIFT_GET(mco_cfgr) \
706 (((mco_cfgr) >> STM32_MCO_CFGR_SHIFT_SHIFT) & STM32_MCO_CFGR_SHIFT_MASK)
713#define STM32_MCO_CFGR_MASK_GET(mco_cfgr) \
714 (((mco_cfgr) >> STM32_MCO_CFGR_MASK_SHIFT) & STM32_MCO_CFGR_MASK_MASK)
721#define STM32_MCO_CFGR_VAL_GET(mco_cfgr) \
722 (((mco_cfgr) >> STM32_MCO_CFGR_VAL_SHIFT) & STM32_MCO_CFGR_VAL_MASK)
724#if defined(STM32_HSE_CSS)
733void stm32_hse_css_callback(
void);
736#ifdef CONFIG_SOC_SERIES_STM32WB0X
741typedef void (*lsi_update_cb_t)(
uint32_t new_lsi_frequency);
754int stm32wb0_register_lsi_update_callback(lsi_update_cb_t cb);
Public Clock Control APIs.
__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:625
uint32_t div
Definition stm32_clock_control.h:627
uint32_t bus
Definition stm32_clock_control.h:626
uint32_t enr
Definition stm32_clock_control.h:628