9#ifndef ZEPHYR_INCLUDE_DRIVERS_CLOCK_CONTROL_STM32_CLOCK_CONTROL_H_ 
   10#define ZEPHYR_INCLUDE_DRIVERS_CLOCK_CONTROL_STM32_CLOCK_CONTROL_H_ 
   14#if defined(CONFIG_SOC_SERIES_STM32F0X) 
   16#elif defined(CONFIG_SOC_SERIES_STM32F1X) 
   18#elif defined(CONFIG_SOC_SERIES_STM32F3X) 
   20#elif defined(CONFIG_SOC_SERIES_STM32F2X) || \ 
   21        defined(CONFIG_SOC_SERIES_STM32F4X) || \ 
   22        defined(CONFIG_SOC_SERIES_STM32F7X) 
   24#elif defined(CONFIG_SOC_SERIES_STM32G0X) 
   26#elif defined(CONFIG_SOC_SERIES_STM32G4X) 
   28#elif defined(CONFIG_SOC_SERIES_STM32L0X) 
   30#elif defined(CONFIG_SOC_SERIES_STM32L1X) 
   32#elif defined(CONFIG_SOC_SERIES_STM32L4X) || \ 
   33        defined(CONFIG_SOC_SERIES_STM32L5X) 
   35#elif defined(CONFIG_SOC_SERIES_STM32WBX) 
   37#elif defined(CONFIG_SOC_SERIES_STM32WLX) 
   39#elif defined(CONFIG_SOC_SERIES_STM32H7X) 
   41#elif defined(CONFIG_SOC_SERIES_STM32U5X) 
   48#define STM32_CLOCK_CONTROL_NODE DT_NODELABEL(rcc) 
   52#define STM32_AHB_PRESCALER     DT_PROP(DT_NODELABEL(rcc), ahb_prescaler) 
   53#define STM32_APB1_PRESCALER    DT_PROP(DT_NODELABEL(rcc), apb1_prescaler) 
   54#define STM32_APB2_PRESCALER    DT_PROP(DT_NODELABEL(rcc), apb2_prescaler) 
   55#define STM32_APB3_PRESCALER    DT_PROP(DT_NODELABEL(rcc), apb3_prescaler) 
   56#define STM32_AHB3_PRESCALER    DT_PROP(DT_NODELABEL(rcc), ahb3_prescaler) 
   57#define STM32_AHB4_PRESCALER    DT_PROP(DT_NODELABEL(rcc), ahb4_prescaler) 
   58#define STM32_CPU1_PRESCALER    DT_PROP(DT_NODELABEL(rcc), cpu1_prescaler) 
   59#define STM32_CPU2_PRESCALER    DT_PROP(DT_NODELABEL(rcc), cpu2_prescaler) 
   61#if DT_NODE_HAS_PROP(DT_NODELABEL(rcc), ahb_prescaler) 
   62#define STM32_CORE_PRESCALER    STM32_AHB_PRESCALER 
   63#elif DT_NODE_HAS_PROP(DT_NODELABEL(rcc), cpu1_prescaler) 
   64#define STM32_CORE_PRESCALER    STM32_CPU1_PRESCALER 
   67#if DT_NODE_HAS_PROP(DT_NODELABEL(rcc), ahb3_prescaler) 
   68#define STM32_FLASH_PRESCALER   STM32_AHB3_PRESCALER 
   69#elif DT_NODE_HAS_PROP(DT_NODELABEL(rcc), ahb4_prescaler) 
   70#define STM32_FLASH_PRESCALER   STM32_AHB4_PRESCALER 
   72#define STM32_FLASH_PRESCALER   STM32_CORE_PRESCALER 
   75#define STM32_D1CPRE    DT_PROP(DT_NODELABEL(rcc), d1cpre) 
   76#define STM32_HPRE      DT_PROP(DT_NODELABEL(rcc), hpre) 
   77#define STM32_D2PPRE1   DT_PROP(DT_NODELABEL(rcc), d2ppre1) 
   78#define STM32_D2PPRE2   DT_PROP(DT_NODELABEL(rcc), d2ppre2) 
   79#define STM32_D1PPRE    DT_PROP(DT_NODELABEL(rcc), d1ppre) 
   80#define STM32_D3PPRE    DT_PROP(DT_NODELABEL(rcc), d3ppre) 
   82#define DT_RCC_CLOCKS_CTRL      DT_CLOCKS_CTLR(DT_NODELABEL(rcc)) 
   87#if DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(pll)) 
   88#define STM32_SYSCLK_SRC_PLL    1 
   90#if DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(clk_hsi)) 
   91#define STM32_SYSCLK_SRC_HSI    1 
   93#if DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(clk_hse)) 
   94#define STM32_SYSCLK_SRC_HSE    1 
   96#if DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(clk_msi)) 
   97#define STM32_SYSCLK_SRC_MSI    1 
   99#if DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(clk_msis)) 
  100#define STM32_SYSCLK_SRC_MSIS   1 
  102#if DT_SAME_NODE(DT_RCC_CLOCKS_CTRL, DT_NODELABEL(clk_csi)) 
  103#define STM32_SYSCLK_SRC_CSI    1 
  109#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f2_pll_clock, okay) || \ 
  110        DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f4_pll_clock, okay) || \ 
  111        DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f7_pll_clock, okay) || \ 
  112        DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32g0_pll_clock, okay) || \ 
  113        DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32g4_pll_clock, okay) || \ 
  114        DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32l4_pll_clock, okay) || \ 
  115        DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32u5_pll_clock, okay) || \ 
  116        DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32wb_pll_clock, okay) || \ 
  117        DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32h7_pll_clock, okay) 
  118#define STM32_PLL_ENABLED       1 
  119#define STM32_PLL_M_DIVISOR     DT_PROP(DT_NODELABEL(pll), div_m) 
  120#define STM32_PLL_N_MULTIPLIER  DT_PROP(DT_NODELABEL(pll), mul_n) 
  121#define STM32_PLL_P_ENABLED     DT_NODE_HAS_PROP(DT_NODELABEL(pll), div_p) 
  122#define STM32_PLL_P_DIVISOR     DT_PROP_OR(DT_NODELABEL(pll), div_p, 1) 
  123#define STM32_PLL_Q_ENABLED     DT_NODE_HAS_PROP(DT_NODELABEL(pll), div_q) 
  124#define STM32_PLL_Q_DIVISOR     DT_PROP_OR(DT_NODELABEL(pll), div_q, 1) 
  125#define STM32_PLL_R_ENABLED     DT_NODE_HAS_PROP(DT_NODELABEL(pll), div_r) 
  126#define STM32_PLL_R_DIVISOR     DT_PROP_OR(DT_NODELABEL(pll), div_r, 1) 
  129#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll2), st_stm32u5_pll_clock, okay) || \ 
  130        DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll2), st_stm32h7_pll_clock, okay) 
  131#define STM32_PLL2_ENABLED      1 
  132#define STM32_PLL2_M_DIVISOR    DT_PROP(DT_NODELABEL(pll2), div_m) 
  133#define STM32_PLL2_N_MULTIPLIER DT_PROP(DT_NODELABEL(pll2), mul_n) 
  134#define STM32_PLL2_P_ENABLED    DT_NODE_HAS_PROP(DT_NODELABEL(pll2), div_p) 
  135#define STM32_PLL2_P_DIVISOR    DT_PROP_OR(DT_NODELABEL(pll2), div_p, 1) 
  136#define STM32_PLL2_Q_ENABLED    DT_NODE_HAS_PROP(DT_NODELABEL(pll2), div_q) 
  137#define STM32_PLL2_Q_DIVISOR    DT_PROP_OR(DT_NODELABEL(pll2), div_q, 1) 
  138#define STM32_PLL2_R_ENABLED    DT_NODE_HAS_PROP(DT_NODELABEL(pll2), div_r) 
  139#define STM32_PLL2_R_DIVISOR    DT_PROP_OR(DT_NODELABEL(pll2), div_r, 1) 
  142#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll3), st_stm32h7_pll_clock, okay) || \ 
  143        DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll3), st_stm32u5_pll_clock, okay) 
  144#define STM32_PLL3_ENABLED      1 
  145#define STM32_PLL3_M_DIVISOR    DT_PROP(DT_NODELABEL(pll3), div_m) 
  146#define STM32_PLL3_N_MULTIPLIER DT_PROP(DT_NODELABEL(pll3), mul_n) 
  147#define STM32_PLL3_P_ENABLED    DT_NODE_HAS_PROP(DT_NODELABEL(pll3), div_p) 
  148#define STM32_PLL3_P_DIVISOR    DT_PROP_OR(DT_NODELABEL(pll3), div_p, 1) 
  149#define STM32_PLL3_Q_ENABLED    DT_NODE_HAS_PROP(DT_NODELABEL(pll3), div_q) 
  150#define STM32_PLL3_Q_DIVISOR    DT_PROP_OR(DT_NODELABEL(pll3), div_q, 1) 
  151#define STM32_PLL3_R_ENABLED    DT_NODE_HAS_PROP(DT_NODELABEL(pll3), div_r) 
  152#define STM32_PLL3_R_DIVISOR    DT_PROP_OR(DT_NODELABEL(pll3), div_r, 1) 
  155#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f1_pll_clock, okay) 
  156#define STM32_PLL_ENABLED       1 
  157#define STM32_PLL_XTPRE         DT_PROP(DT_NODELABEL(pll), xtpre) 
  158#define STM32_PLL_MULTIPLIER    DT_PROP(DT_NODELABEL(pll), mul) 
  159#define STM32_PLL_USBPRE        DT_PROP(DT_NODELABEL(pll), usbpre) 
  160#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f0_pll_clock, okay) || \ 
  161        DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f100_pll_clock, okay) || \ 
  162        DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32f105_pll_clock, okay) 
  163#define STM32_PLL_ENABLED       1 
  164#define STM32_PLL_MULTIPLIER    DT_PROP(DT_NODELABEL(pll), mul) 
  165#define STM32_PLL_PREDIV        DT_PROP(DT_NODELABEL(pll), prediv) 
  166#define STM32_PLL_USBPRE        DT_PROP(DT_NODELABEL(pll), otgfspre) 
  167#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll), st_stm32l0_pll_clock, okay) 
  168#define STM32_PLL_ENABLED       1 
  169#define STM32_PLL_DIVISOR       DT_PROP(DT_NODELABEL(pll), div) 
  170#define STM32_PLL_MULTIPLIER    DT_PROP(DT_NODELABEL(pll), mul) 
  173#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(pll2), st_stm32f105_pll2_clock, okay) 
  174#define STM32_PLL2_ENABLED      1 
  175#define STM32_PLL2_MULTIPLIER   DT_PROP(DT_NODELABEL(pll2), mul) 
  176#define STM32_PLL2_PREDIV       DT_PROP(DT_NODELABEL(pll2), prediv) 
  180#if DT_NODE_HAS_STATUS(DT_NODELABEL(pll), okay) && \ 
  181        DT_NODE_HAS_PROP(DT_NODELABEL(pll), clocks) 
  182#define DT_PLL_CLOCKS_CTRL      DT_CLOCKS_CTLR(DT_NODELABEL(pll)) 
  183#if DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(clk_msi)) 
  184#define STM32_PLL_SRC_MSI       1 
  186#if DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(clk_msis)) 
  187#define STM32_PLL_SRC_MSIS      1 
  189#if DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(clk_hsi)) 
  190#define STM32_PLL_SRC_HSI       1 
  192#if DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(clk_csi)) 
  193#define STM32_PLL_SRC_CSI       1 
  195#if DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(clk_hse)) 
  196#define STM32_PLL_SRC_HSE       1 
  198#if DT_SAME_NODE(DT_PLL_CLOCKS_CTRL, DT_NODELABEL(pll2)) 
  199#define STM32_PLL_SRC_PLL2      1 
  205#if DT_NODE_HAS_STATUS(DT_NODELABEL(pll2), okay) && \ 
  206        DT_NODE_HAS_PROP(DT_NODELABEL(pll2), clocks) 
  207#define DT_PLL2_CLOCKS_CTRL     DT_CLOCKS_CTLR(DT_NODELABEL(pll2)) 
  208#if DT_SAME_NODE(DT_PLL2_CLOCKS_CTRL, DT_NODELABEL(clk_msis)) 
  209#define STM32_PLL2_SRC_MSIS     1 
  211#if DT_SAME_NODE(DT_PLL2_CLOCKS_CTRL, DT_NODELABEL(clk_hsi)) 
  212#define STM32_PLL2_SRC_HSI      1 
  214#if DT_SAME_NODE(DT_PLL2_CLOCKS_CTRL, DT_NODELABEL(clk_hse)) 
  215#define STM32_PLL2_SRC_HSE      1 
  221#if DT_NODE_HAS_STATUS(DT_NODELABEL(pll3), okay) && \ 
  222        DT_NODE_HAS_PROP(DT_NODELABEL(pll3), clocks) 
  223#define DT_PLL3_CLOCKS_CTRL     DT_CLOCKS_CTLR(DT_NODELABEL(pll3)) 
  224#if DT_SAME_NODE(DT_PLL3_CLOCKS_CTRL, DT_NODELABEL(clk_msis)) 
  225#define STM32_PLL3_SRC_MSIS     1 
  227#if DT_SAME_NODE(DT_PLL3_CLOCKS_CTRL, DT_NODELABEL(clk_hsi)) 
  228#define STM32_PLL3_SRC_HSI      1 
  230#if DT_SAME_NODE(DT_PLL3_CLOCKS_CTRL, DT_NODELABEL(clk_hse)) 
  231#define STM32_PLL3_SRC_HSE      1 
  239#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_lse), fixed_clock, okay) 
  240#define STM32_LSE_ENABLED       1 
  241#define STM32_LSE_FREQ          DT_PROP(DT_NODELABEL(clk_lse), clock_frequency) 
  242#define STM32_LSE_DRIVING       0 
  243#define STM32_LSE_BYPASS        DT_PROP(DT_NODELABEL(clk_lse), lse_bypass) 
  244#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_lse), st_stm32_lse_clock, okay) 
  245#define STM32_LSE_ENABLED       1 
  246#define STM32_LSE_FREQ          DT_PROP(DT_NODELABEL(clk_lse), clock_frequency) 
  247#define STM32_LSE_DRIVING       DT_PROP(DT_NODELABEL(clk_lse), driving_capability) 
  248#define STM32_LSE_BYPASS        DT_PROP(DT_NODELABEL(clk_lse), lse_bypass) 
  250#define STM32_LSE_ENABLED       0 
  251#define STM32_LSE_FREQ          0 
  252#define STM32_LSE_DRIVING       0 
  253#define STM32_LSE_BYPASS        0 
  256#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msi), st_stm32_msi_clock, okay) || \ 
  257        DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msi), st_stm32l0_msi_clock, okay) 
  258#define STM32_MSI_ENABLED       1 
  259#define STM32_MSI_RANGE         DT_PROP(DT_NODELABEL(clk_msi), msi_range) 
  262#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msi), st_stm32_msi_clock, okay) 
  263#define STM32_MSI_ENABLED       1 
  264#define STM32_MSI_PLL_MODE      DT_PROP(DT_NODELABEL(clk_msi), msi_pll_mode) 
  267#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msis), st_stm32u5_msi_clock, okay) 
  268#define STM32_MSIS_ENABLED      1 
  269#define STM32_MSIS_RANGE        DT_PROP(DT_NODELABEL(clk_msis), msi_range) 
  270#define STM32_MSIS_PLL_MODE     DT_PROP(DT_NODELABEL(clk_msis), msi_pll_mode) 
  272#define STM32_MSIS_ENABLED      0 
  273#define STM32_MSIS_RANGE        0 
  274#define STM32_MSIS_PLL_MODE     0 
  277#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_msik), st_stm32u5_msi_clock, okay) 
  278#define STM32_MSIK_ENABLED      1 
  279#define STM32_MSIK_RANGE        DT_PROP(DT_NODELABEL(clk_msik), msi_range) 
  280#define STM32_MSIK_PLL_MODE     DT_PROP(DT_NODELABEL(clk_msik), msi_pll_mode) 
  282#define STM32_MSIK_ENABLED      0 
  283#define STM32_MSIK_RANGE        0 
  284#define STM32_MSIK_PLL_MODE     0 
  287#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_csi), fixed_clock, okay) 
  288#define STM32_CSI_ENABLED       1 
  289#define STM32_CSI_FREQ          DT_PROP(DT_NODELABEL(clk_csi), clock_frequency) 
  291#define STM32_CSI_FREQ          0 
  294#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_lsi), fixed_clock, okay) 
  295#define STM32_LSI_ENABLED       1 
  296#define STM32_LSI_FREQ          DT_PROP(DT_NODELABEL(clk_lsi), clock_frequency) 
  297#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_lsi1), fixed_clock, okay) 
  298#define STM32_LSI_ENABLED       1 
  299#define STM32_LSI_FREQ          DT_PROP(DT_NODELABEL(clk_lsi1), clock_frequency) 
  300#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_lsi2), fixed_clock, okay) 
  301#define STM32_LSI_ENABLED       1 
  302#define STM32_LSI_FREQ          DT_PROP(DT_NODELABEL(clk_lsi2), clock_frequency) 
  304#define STM32_LSI_FREQ          0 
  307#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hsi), fixed_clock, okay) 
  308#define STM32_HSI_DIV_ENABLED   0 
  309#define STM32_HSI_ENABLED       1 
  310#define STM32_HSI_FREQ          DT_PROP(DT_NODELABEL(clk_hsi), clock_frequency) 
  311#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hsi), st_stm32h7_hsi_clock, okay) \ 
  312        || DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hsi), st_stm32g0_hsi_clock, okay) 
  313#define STM32_HSI_DIV_ENABLED   1 
  314#define STM32_HSI_ENABLED       1 
  315#define STM32_HSI_DIVISOR       DT_PROP(DT_NODELABEL(clk_hsi), hsi_div) 
  316#define STM32_HSI_FREQ          DT_PROP(DT_NODELABEL(clk_hsi), clock_frequency) 
  318#define STM32_HSI_DIV_ENABLED   0 
  319#define STM32_HSI_DIVISOR       1 
  320#define STM32_HSI_FREQ          0 
  323#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hse), fixed_clock, okay) 
  324#define STM32_HSE_ENABLED       1 
  325#define STM32_HSE_FREQ          DT_PROP(DT_NODELABEL(clk_hse), clock_frequency) 
  326#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hse), st_stm32_hse_clock, okay) 
  327#define STM32_HSE_ENABLED       1 
  328#define STM32_HSE_BYPASS        DT_PROP(DT_NODELABEL(clk_hse), hse_bypass) 
  329#define STM32_HSE_FREQ          DT_PROP(DT_NODELABEL(clk_hse), clock_frequency) 
  330#elif DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hse), st_stm32wl_hse_clock, okay) 
  331#define STM32_HSE_ENABLED       1 
  332#define STM32_HSE_TCXO          DT_PROP(DT_NODELABEL(clk_hse), hse_tcxo) 
  333#define STM32_HSE_DIV2          DT_PROP(DT_NODELABEL(clk_hse), hse_div2) 
  334#define STM32_HSE_FREQ          DT_PROP(DT_NODELABEL(clk_hse), clock_frequency) 
  336#define STM32_HSE_FREQ          0 
  339#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(clk_hsi48), fixed_clock, okay) 
  340#define STM32_HSI48_ENABLED     1 
  341#define STM32_HSI48_FREQ        DT_PROP(DT_NODELABEL(clk_hsi48), clock_frequency) 
  344#if DT_NODE_HAS_COMPAT_STATUS(DT_NODELABEL(perck), st_stm32_clock_mux, okay) 
  345#define STM32_CKPER_ENABLED     1 
  357#define STM32_CLOCK_INFO(clk_index, node_id)                            \ 
  359        .enr = DT_CLOCKS_CELL_BY_IDX(node_id, clk_index, bits),         \ 
  360        .bus = DT_CLOCKS_CELL_BY_IDX(node_id, clk_index, bus)           \ 
  362#define STM32_DT_CLOCKS(node_id)                                        \ 
  364                LISTIFY(DT_NUM_CLOCKS(node_id),                         \ 
  365                        STM32_CLOCK_INFO, (,), node_id)                 \ 
  368#define STM32_DT_INST_CLOCKS(inst)                                      \ 
  369        STM32_DT_CLOCKS(DT_DRV_INST(inst)) 
  371#define STM32_DOMAIN_CLOCK_INST_SUPPORT(inst) DT_INST_CLOCKS_HAS_IDX(inst, 1) || 
  372#define STM32_DT_INST_DEV_DOMAIN_CLOCK_SUPPORT                          \ 
  373                (DT_INST_FOREACH_STATUS_OKAY(STM32_DOMAIN_CLOCK_INST_SUPPORT) 0) 
  375#define STM32_DOMAIN_CLOCK_SUPPORT(id) DT_CLOCKS_HAS_IDX(DT_NODELABEL(id), 1) || 
  376#define STM32_DT_DEV_DOMAIN_CLOCK_SUPPORT                                       \ 
  377                (DT_FOREACH_STATUS_OKAY(STM32_DOMAIN_CLOCK_SUPPORT) 0) 
  386#define STM32_CLOCK_REG_GET(clock) \ 
  387        (((clock) >> STM32_CLOCK_REG_SHIFT) & STM32_CLOCK_REG_MASK) 
  394#define STM32_CLOCK_SHIFT_GET(clock) \ 
  395        (((clock) >> STM32_CLOCK_SHIFT_SHIFT) & STM32_CLOCK_SHIFT_MASK) 
  402#define STM32_CLOCK_MASK_GET(clock) \ 
  403        (((clock) >> STM32_CLOCK_MASK_SHIFT) & STM32_CLOCK_MASK_MASK) 
  410#define STM32_CLOCK_VAL_GET(clock) \ 
  411        (((clock) >> STM32_CLOCK_VAL_SHIFT) & STM32_CLOCK_VAL_MASK) 
Public Clock Control APIs.
 
__UINT32_TYPE__ uint32_t
Definition: stdint.h:90
 
Definition: stm32_clock_control.h:350
 
uint32_t bus
Definition: stm32_clock_control.h:351
 
uint32_t enr
Definition: stm32_clock_control.h:352