stm32_clock_control.h 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326
  1. /*
  2. * Copyright (c) 2016 Open-RnD Sp. z o.o.
  3. * Copyright (c) 2016 BayLibre, SAS
  4. * Copyright (c) 2017 Linaro Limited.
  5. * Copyright (c) 2017 RnDity Sp. z o.o.
  6. *
  7. * SPDX-License-Identifier: Apache-2.0
  8. */
  9. #ifndef ZEPHYR_INCLUDE_DRIVERS_CLOCK_CONTROL_STM32_CLOCK_CONTROL_H_
  10. #define ZEPHYR_INCLUDE_DRIVERS_CLOCK_CONTROL_STM32_CLOCK_CONTROL_H_
  11. #include <drivers/clock_control.h>
  12. #include <dt-bindings/clock/stm32_clock.h>
  13. /* common clock control device node for all STM32 chips */
  14. #define STM32_CLOCK_CONTROL_NODE DT_NODELABEL(rcc)
  15. /*
  16. * Kconfig to device tree transition for clocks on STM32 targets:
  17. *
  18. * Following definitions are provided to allow a smooth transition
  19. * between Kconfig based to dts based clocks configuration.
  20. * These symbols allow to have both configuration schemes used simultaneoulsy
  21. * while giving precedence to dts based configuration once available on a
  22. * target.
  23. * Finally, once all in-tree users are converted to dts based configuration,
  24. * we'll be able to generate deprecation warnings for out of tree users of
  25. * Kconfig related symbols.
  26. */
  27. #if defined(STM32_AHB_PRESCALER) || \
  28. defined(CONFIG_CLOCK_STM32_APB1_PRESCALER) || \
  29. defined(CONFIG_CLOCK_STM32_APB2_PRESCALER) || \
  30. defined(CONFIG_CLOCK_STM32_AHB3_PRESCALER) || \
  31. defined(CONFIG_CLOCK_STM32_AHB4_PRESCALER) || \
  32. defined(CONFIG_CLOCK_STM32_CPU1_PRESCALER) || \
  33. defined(CONFIG_CLOCK_STM32_CPU2_PRESCALER) || \
  34. defined(CONFIG_CLOCK_STM32_PLL_M_DIVISOR) || \
  35. defined(CONFIG_CLOCK_STM32_PLL_N_MULTIPLIER) || \
  36. defined(CONFIG_CLOCK_STM32_PLL_P_DIVISOR) || \
  37. defined(CONFIG_CLOCK_STM32_PLL_Q_DIVISOR) || \
  38. defined(CONFIG_CLOCK_STM32_PLL_R_DIVISOR) || \
  39. defined(CONFIG_CLOCK_STM32_PLL_XTPRE) || \
  40. defined(CONFIG_CLOCK_STM32_PLL_MULTIPLIER) || \
  41. defined(CONFIG_CLOCK_STM32_PLL_PREDIV1) || \
  42. defined(CONFIG_CLOCK_STM32_PLL_PREDIV) || \
  43. defined(CONFIG_CLOCK_STM32_PLL_DIVISOR) || \
  44. defined(CONFIG_CLOCK_STM32_SYSCLK_SRC_PLL) || \
  45. defined(CONFIG_CLOCK_STM32_SYSCLK_SRC_HSI) || \
  46. defined(CONFIG_CLOCK_STM32_SYSCLK_SRC_HSE) || \
  47. defined(CONFIG_CLOCK_STM32_SYSCLK_SRC_MSI) || \
  48. defined(CONFIG_CLOCK_STM32_PLL_SRC_MSI) || \
  49. defined(CONFIG_CLOCK_STM32_PLL_SRC_HSI) || \
  50. defined(CONFIG_CLOCK_STM32_PLL_SRC_HSE) || \
  51. defined(CONFIG_CLOCK_STM32_PLL_SRC_PLL2) || \
  52. defined(CONFIG_CLOCK_STM32_LSE) || \
  53. defined(CONFIG_CLOCK_STM32_MSI_RANGE) || \
  54. defined(CONFIG_CLOCK_STM32_MSI_PLL_MODE) || \
  55. defined(CONFIG_CLOCK_STM32_HSE_BYPASS) || \
  56. defined(CONFIG_CLOCK_STM32_D1CPRE) || \
  57. defined(CONFIG_CLOCK_STM32_HPRE) || \
  58. defined(CONFIG_CLOCK_STM32_D2PPRE1) || \
  59. defined(CONFIG_CLOCK_STM32_D2PPRE2) || \
  60. defined(CONFIG_CLOCK_STM32_D1PPRE) || \
  61. defined(CONFIG_CLOCK_STM32_D3PPRE) || \
  62. defined(CONFIG_CLOCK_STM32_PLL3_ENABLE) || \
  63. defined(CONFIG_CLOCK_STM32_PLL3_M_DIVISOR) || \
  64. defined(CONFIG_CLOCK_STM32_PLL3_N_MULTIPLIER) || \
  65. defined(CONFIG_CLOCK_STM32_PLL3_P_ENABLE) || \
  66. defined(CONFIG_CLOCK_STM32_PLL3_P_DIVISOR) || \
  67. defined(CONFIG_CLOCK_STM32_PLL3_Q_ENABLE) || \
  68. defined(CONFIG_CLOCK_STM32_PLL3_Q_DIVISOR) || \
  69. defined(CONFIG_CLOCK_STM32_PLL3_R_ENABLE) || \
  70. defined(CONFIG_CLOCK_STM32_PLL3_R_DIVISOR) || \
  71. defined(CONFIG_CLOCK_STM32_SYSCLK_SRC_CSI) || \
  72. defined(CONFIG_CLOCK_STM32_HSI_DIVISOR)
  73. #warning "Deprecated: Please use device tree for STM32 clock_control configuration"
  74. /*
  75. * Use of Kconfig for STM32 clock_control configuration is deprecated.
  76. * It is replaced by use of device tree.
  77. * For more information, see:
  78. * https://github.com/zephyrproject-rtos/zephyr/pull/34120
  79. * https://github.com/zephyrproject-rtos/zephyr/pull/34609
  80. * https://github.com/zephyrproject-rtos/zephyr/pull/34701
  81. * and
  82. * https://github.com/zephyrproject-rtos/zephyr/issues/34633
  83. */
  84. #endif
  85. #if DT_NODE_HAS_PROP(DT_INST(0, st_stm32_rcc), ahb_prescaler) || \
  86. DT_NODE_HAS_PROP(DT_INST(0, st_stm32f0_rcc), ahb_prescaler) || \
  87. DT_NODE_HAS_PROP(DT_INST(0, st_stm32u5_rcc), ahb_prescaler)
  88. #define STM32_AHB_PRESCALER DT_PROP(DT_NODELABEL(rcc), ahb_prescaler)
  89. #else
  90. #define STM32_AHB_PRESCALER CONFIG_CLOCK_STM32_AHB_PRESCALER
  91. #endif
  92. #if DT_NODE_HAS_PROP(DT_INST(0, st_stm32_rcc), apb1_prescaler) || \
  93. DT_NODE_HAS_PROP(DT_INST(0, st_stm32f0_rcc), apb1_prescaler) || \
  94. DT_NODE_HAS_PROP(DT_INST(0, st_stm32u5_rcc), apb1_prescaler) || \
  95. DT_NODE_HAS_PROP(DT_INST(0, st_stm32wb_rcc), apb1_prescaler) || \
  96. DT_NODE_HAS_PROP(DT_INST(0, st_stm32wl_rcc), apb1_prescaler)
  97. #define STM32_APB1_PRESCALER DT_PROP(DT_NODELABEL(rcc), apb1_prescaler)
  98. #else
  99. #define STM32_APB1_PRESCALER CONFIG_CLOCK_STM32_APB1_PRESCALER
  100. #endif
  101. #if DT_NODE_HAS_PROP(DT_INST(0, st_stm32_rcc), apb2_prescaler) || \
  102. DT_NODE_HAS_PROP(DT_INST(0, st_stm32u5_rcc), apb2_prescaler) || \
  103. DT_NODE_HAS_PROP(DT_INST(0, st_stm32wb_rcc), apb2_prescaler) || \
  104. DT_NODE_HAS_PROP(DT_INST(0, st_stm32wl_rcc), apb2_prescaler)
  105. #define STM32_APB2_PRESCALER DT_PROP(DT_NODELABEL(rcc), apb2_prescaler)
  106. #elif !DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(rcc), st_stm32f0_rcc, okay)
  107. /* This should not be defined in F0 binding case */
  108. #define STM32_APB2_PRESCALER CONFIG_CLOCK_STM32_APB2_PRESCALER
  109. #endif
  110. #if DT_NODE_HAS_PROP(DT_INST(0, st_stm32u5_rcc), apb3_prescaler)
  111. #define STM32_APB3_PRESCALER DT_PROP(DT_NODELABEL(rcc), apb3_prescaler)
  112. #endif
  113. #if DT_NODE_HAS_PROP(DT_INST(0, st_stm32wl_rcc), ahb3_prescaler)
  114. #define STM32_AHB3_PRESCALER DT_PROP(DT_NODELABEL(rcc), ahb3_prescaler)
  115. #else
  116. #define STM32_AHB3_PRESCALER CONFIG_CLOCK_STM32_AHB3_PRESCALER
  117. #endif
  118. #if DT_NODE_HAS_PROP(DT_INST(0, st_stm32wb_rcc), ahb4_prescaler)
  119. #define STM32_AHB4_PRESCALER DT_PROP(DT_NODELABEL(rcc), ahb4_prescaler)
  120. #else
  121. #define STM32_AHB4_PRESCALER CONFIG_CLOCK_STM32_AHB4_PRESCALER
  122. #endif
  123. #if DT_NODE_HAS_PROP(DT_INST(0, st_stm32wb_rcc), cpu1_prescaler) || \
  124. DT_NODE_HAS_PROP(DT_INST(0, st_stm32wl_rcc), cpu1_prescaler)
  125. #define STM32_CPU1_PRESCALER DT_PROP(DT_NODELABEL(rcc), cpu1_prescaler)
  126. #else
  127. #define STM32_CPU1_PRESCALER CONFIG_CLOCK_STM32_CPU1_PRESCALER
  128. #endif
  129. #if DT_NODE_HAS_PROP(DT_INST(0, st_stm32wb_rcc), cpu2_prescaler) || \
  130. DT_NODE_HAS_PROP(DT_INST(0, st_stm32wl_rcc), cpu2_prescaler)
  131. #define STM32_CPU2_PRESCALER DT_PROP(DT_NODELABEL(rcc), cpu2_prescaler)
  132. #else
  133. #define STM32_CPU2_PRESCALER CONFIG_CLOCK_STM32_CPU2_PRESCALER
  134. #endif
  135. #if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(rcc), st_stm32h7_rcc, okay) && \
  136. DT_NODE_HAS_PROP(DT_NODELABEL(rcc), d1cpre)
  137. #define STM32_D1CPRE DT_PROP(DT_NODELABEL(rcc), d1cpre)
  138. #define STM32_HPRE DT_PROP(DT_NODELABEL(rcc), hpre)
  139. #define STM32_D2PPRE1 DT_PROP(DT_NODELABEL(rcc), d2ppre1)
  140. #define STM32_D2PPRE2 DT_PROP(DT_NODELABEL(rcc), d2ppre2)
  141. #define STM32_D1PPRE DT_PROP(DT_NODELABEL(rcc), d1ppre)
  142. #define STM32_D3PPRE DT_PROP(DT_NODELABEL(rcc), d3ppre)
  143. #else
  144. #define STM32_D1CPRE CONFIG_CLOCK_STM32_D1CPRE
  145. #define STM32_HPRE CONFIG_CLOCK_STM32_HPRE
  146. #define STM32_D2PPRE1 CONFIG_CLOCK_STM32_D2PPRE1
  147. #define STM32_D2PPRE2 CONFIG_CLOCK_STM32_D2PPRE2
  148. #define STM32_D1PPRE CONFIG_CLOCK_STM32_D1PPRE
  149. #define STM32_D3PPRE CONFIG_CLOCK_STM32_D3PPRE
  150. #endif
  151. #if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f2_pll_clock, okay) || \
  152. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f4_pll_clock, okay) || \
  153. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f7_pll_clock, okay) || \
  154. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32g0_pll_clock, okay) || \
  155. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32g4_pll_clock, okay) || \
  156. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32l4_pll_clock, okay) || \
  157. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32u5_pll_clock, okay) || \
  158. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32wb_pll_clock, okay) || \
  159. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32h7_pll_clock, okay)
  160. #define STM32_PLL_M_DIVISOR DT_PROP(DT_NODELABEL(pll), div_m)
  161. #define STM32_PLL_N_MULTIPLIER DT_PROP(DT_NODELABEL(pll), mul_n)
  162. #define STM32_PLL_P_DIVISOR DT_PROP(DT_NODELABEL(pll), div_p)
  163. #define STM32_PLL_Q_DIVISOR DT_PROP(DT_NODELABEL(pll), div_q)
  164. #define STM32_PLL_R_DIVISOR DT_PROP(DT_NODELABEL(pll), div_r)
  165. #else
  166. #define STM32_PLL_M_DIVISOR CONFIG_CLOCK_STM32_PLL_M_DIVISOR
  167. #define STM32_PLL_N_MULTIPLIER CONFIG_CLOCK_STM32_PLL_N_MULTIPLIER
  168. #define STM32_PLL_P_DIVISOR CONFIG_CLOCK_STM32_PLL_P_DIVISOR
  169. #define STM32_PLL_Q_DIVISOR CONFIG_CLOCK_STM32_PLL_Q_DIVISOR
  170. #define STM32_PLL_R_DIVISOR CONFIG_CLOCK_STM32_PLL_R_DIVISOR
  171. #endif
  172. #if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll3), st_stm32h7_pll_clock, okay)
  173. #define STM32_PLL3_ENABLE 1
  174. #define STM32_PLL3_M_DIVISOR DT_PROP(DT_NODELABEL(pll3), div_m)
  175. #define STM32_PLL3_N_MULTIPLIER DT_PROP(DT_NODELABEL(pll3), mul_n)
  176. #define STM32_PLL3_P_ENABLE DT_NODE_HAS_PROP(DT_NODELABEL(pll3), div_p)
  177. #define STM32_PLL3_P_DIVISOR DT_PROP(DT_NODELABEL(pll3), div_p)
  178. #define STM32_PLL3_Q_ENABLE DT_NODE_HAS_PROP(DT_NODELABEL(pll3), div_q)
  179. #define STM32_PLL3_Q_DIVISOR DT_PROP(DT_NODELABEL(pll3), div_q)
  180. #define STM32_PLL3_R_ENABLE DT_NODE_HAS_PROP(DT_NODELABEL(pll3), div_r)
  181. #define STM32_PLL3_R_DIVISOR DT_PROP(DT_NODELABEL(pll3), div_r)
  182. #else
  183. #define STM32_PLL3_ENABLE CONFIG_CLOCK_STM32_PLL3_ENABLE
  184. #define STM32_PLL3_M_DIVISOR CONFIG_CLOCK_STM32_PLL3_M_DIVISOR
  185. #define STM32_PLL3_N_MULTIPLIER CONFIG_CLOCK_STM32_PLL3_N_MULTIPLIER
  186. #define STM32_PLL3_P_ENABLE CONFIG_CLOCK_STM32_PLL3_P_ENABLE
  187. #define STM32_PLL3_P_DIVISOR CONFIG_CLOCK_STM32_PLL3_P_DIVISOR
  188. #define STM32_PLL3_Q_ENABLE CONFIG_CLOCK_STM32_PLL3_Q_ENABLE
  189. #define STM32_PLL3_Q_DIVISOR CONFIG_CLOCK_STM32_PLL3_Q_DIVISOR
  190. #define STM32_PLL3_R_ENABLE CONFIG_CLOCK_STM32_PLL3_R_ENABLE
  191. #define STM32_PLL3_R_DIVISOR CONFIG_CLOCK_STM32_PLL3_R_DIVISOR
  192. #endif
  193. #if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f1_pll_clock, okay)
  194. #define STM32_PLL_XTPRE DT_PROP(DT_NODELABEL(pll), xtre)
  195. #define STM32_PLL_MULTIPLIER DT_PROP(DT_NODELABEL(pll), mul)
  196. #elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f0_pll_clock, okay) || \
  197. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f100_pll_clock, okay) || \
  198. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f105_pll_clock, okay)
  199. #define STM32_PLL_MULTIPLIER DT_PROP(DT_NODELABEL(pll), mul)
  200. #define STM32_PLL_PREDIV1 DT_PROP(DT_NODELABEL(pll), prediv)
  201. /* We don't need to make a disctinction between PREDIV and PREDIV1 in dts */
  202. /* As PREDIV and PREDIV1 have the same description we can use prop prediv for both */
  203. #define STM32_PLL_PREDIV STM32_PLL_PREDIV1
  204. #elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32l0_pll_clock, okay)
  205. #define STM32_PLL_DIVISOR DT_PROP(DT_NODELABEL(pll), div)
  206. #define STM32_PLL_MULTIPLIER DT_PROP(DT_NODELABEL(pll), mul)
  207. #else
  208. #define STM32_PLL_XTPRE CONFIG_CLOCK_STM32_PLL_XTPRE
  209. #define STM32_PLL_MULTIPLIER CONFIG_CLOCK_STM32_PLL_MULTIPLIER
  210. #define STM32_PLL_PREDIV1 CONFIG_CLOCK_STM32_PLL_PREDIV1
  211. #define STM32_PLL_PREDIV CONFIG_CLOCK_STM32_PLL_PREDIV
  212. #define STM32_PLL_DIVISOR CONFIG_CLOCK_STM32_PLL_DIVISOR
  213. #endif
  214. #if (DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(rcc), st_stm32_rcc, okay) || \
  215. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(rcc), st_stm32f0_rcc, okay) || \
  216. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(rcc), st_stm32h7_rcc, okay) || \
  217. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(rcc), st_stm32u5_rcc, okay) || \
  218. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(rcc), st_stm32wb_rcc, okay) || \
  219. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(rcc), st_stm32wl_rcc, okay)) && \
  220. DT_NODE_HAS_PROP(DT_NODELABEL(rcc), clocks)
  221. #define DT_RCC_CLOCKS_CTRL DT_CLOCKS_CTLR(DT_NODELABEL(rcc))
  222. #define STM32_SYSCLK_SRC_PLL DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(pll))
  223. #define STM32_SYSCLK_SRC_HSI DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(clk_hsi))
  224. #define STM32_SYSCLK_SRC_HSE DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(clk_hse))
  225. #define STM32_SYSCLK_SRC_MSI DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(clk_msi))
  226. #define STM32_SYSCLK_SRC_CSI DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(clk_csi))
  227. #else
  228. #define STM32_SYSCLK_SRC_PLL CONFIG_CLOCK_STM32_SYSCLK_SRC_PLL
  229. #define STM32_SYSCLK_SRC_HSI CONFIG_CLOCK_STM32_SYSCLK_SRC_HSI
  230. #define STM32_SYSCLK_SRC_HSE CONFIG_CLOCK_STM32_SYSCLK_SRC_HSE
  231. #define STM32_SYSCLK_SRC_MSI CONFIG_CLOCK_STM32_SYSCLK_SRC_MSI
  232. #define STM32_SYSCLK_SRC_CSI CONFIG_CLOCK_STM32_SYSCLK_SRC_CSI
  233. #endif
  234. #if (DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f0_pll_clock, okay) || \
  235. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f1_pll_clock, okay) || \
  236. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f100_pll_clock, okay) || \
  237. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f105_pll_clock, okay) || \
  238. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f2_pll_clock, okay) || \
  239. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f4_pll_clock, okay) || \
  240. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f7_pll_clock, okay) || \
  241. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32g0_pll_clock, okay) || \
  242. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32g4_pll_clock, okay) || \
  243. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32h7_pll_clock, okay) || \
  244. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32l0_pll_clock, okay) || \
  245. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32l4_pll_clock, okay) || \
  246. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32u5_pll_clock, okay) || \
  247. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32wb_pll_clock, okay)) && \
  248. DT_NODE_HAS_PROP(DT_NODELABEL(pll), clocks)
  249. #define DT_PLL_CLOCKS_CTRL DT_CLOCKS_CTLR(DT_NODELABEL(pll))
  250. #define STM32_PLL_SRC_MSI DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(clk_msi))
  251. #define STM32_PLL_SRC_MSIS DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(clk_msis))
  252. #define STM32_PLL_SRC_HSI DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(clk_hsi))
  253. #define STM32_PLL_SRC_HSE DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(clk_hse))
  254. #define STM32_PLL_SRC_PLL2 DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(pll2))
  255. #else
  256. #define STM32_PLL_SRC_MSI CONFIG_CLOCK_STM32_PLL_SRC_MSI
  257. #define STM32_PLL_SRC_HSI CONFIG_CLOCK_STM32_PLL_SRC_HSI
  258. #define STM32_PLL_SRC_HSE CONFIG_CLOCK_STM32_PLL_SRC_HSE
  259. #define STM32_PLL_SRC_PLL2 CONFIG_CLOCK_STM32_PLL_SRC_PLL2
  260. #endif
  261. #if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_lse), fixed_clock, okay)
  262. #define STM32_LSE_CLOCK DT_PROP(DT_NODELABEL(clk_lse), clock_frequency)
  263. #else
  264. #define STM32_LSE_CLOCK CONFIG_CLOCK_STM32_LSE
  265. #endif
  266. #if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msi), st_stm32_msi_clock, okay) || \
  267. DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msi), st_stm32l0_msi_clock, okay)
  268. #define STM32_MSI_RANGE DT_PROP(DT_NODELABEL(clk_msi), msi_range)
  269. #elif !DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msis), st_stm32u5_msi_clock, okay)
  270. #define STM32_MSI_RANGE CONFIG_CLOCK_STM32_MSI_RANGE
  271. #endif
  272. #if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msi), st_stm32_msi_clock, okay)
  273. #define STM32_MSI_PLL_MODE DT_PROP(DT_NODELABEL(clk_msi), msi_pll_mode)
  274. #elif !DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msis), st_stm32u5_msi_clock, okay)
  275. #define STM32_MSI_PLL_MODE CONFIG_CLOCK_STM32_MSI_PLL_MODE
  276. #endif
  277. #if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msis), st_stm32u5_msi_clock, okay)
  278. #define STM32_MSIS_RANGE DT_PROP(DT_NODELABEL(clk_msis), msi_range)
  279. #define STM32_MSIS_PLL_MODE DT_PROP(DT_NODELABEL(clk_msis), msi_pll_mode)
  280. #endif
  281. #if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hsi), st_stm32h7_hsi_clock, okay)
  282. #define STM32_HSI_DIVISOR DT_PROP(DT_NODELABEL(clk_hsi), hsi_div)
  283. #else
  284. #define STM32_HSI_DIVISOR CONFIG_CLOCK_STM32_HSI_DIVISOR
  285. #endif
  286. #if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hse), st_stm32_hse_clock, okay)
  287. #define STM32_HSE_BYPASS DT_PROP(DT_NODELABEL(clk_hse), hse_bypass)
  288. #elif !DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hse), st_stm32wl_hse_clock, okay)
  289. #define STM32_HSE_BYPASS CONFIG_CLOCK_STM32_HSE_BYPASS
  290. #endif
  291. #if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hse), st_stm32wl_hse_clock, okay)
  292. #define STM32_HSE_TCXO DT_PROP(DT_NODELABEL(clk_hse), hse_tcxo)
  293. #define STM32_HSE_DIV2 DT_PROP(DT_NODELABEL(clk_hse), hse_div2)
  294. #endif
  295. struct stm32_pclken {
  296. uint32_t bus;
  297. uint32_t enr;
  298. };
  299. #endif /* ZEPHYR_INCLUDE_DRIVERS_CLOCK_CONTROL_STM32_CLOCK_CONTROL_H_ */