1 /*
2  * Copyright (c) 2024 Silicon Laboratories Inc.
3  *
4  * SPDX-License-Identifier: Apache-2.0
5  */
6 
7 #ifndef ZEPHYR_INCLUDE_DRIVERS_CLOCK_CONTROL_SILABS_H_
8 #define ZEPHYR_INCLUDE_DRIVERS_CLOCK_CONTROL_SILABS_H_
9 
10 #include <zephyr/drivers/clock_control.h>
11 
12 #if defined(CONFIG_SOC_SERIES_EFR32MG21)
13 #include <zephyr/dt-bindings/clock/silabs/xg21-clock.h>
14 #elif defined(CONFIG_SOC_SERIES_EFR32BG22)
15 #include <zephyr/dt-bindings/clock/silabs/xg22-clock.h>
16 #elif defined(CONFIG_SOC_SERIES_EFR32ZG23)
17 #include <zephyr/dt-bindings/clock/silabs/xg23-clock.h>
18 #elif defined(CONFIG_SOC_SERIES_EFR32MG24)
19 #include <zephyr/dt-bindings/clock/silabs/xg24-clock.h>
20 #elif defined(CONFIG_SOC_SERIES_EFR32BG27)
21 #include <zephyr/dt-bindings/clock/silabs/xg27-clock.h>
22 #endif
23 
24 struct silabs_clock_control_cmu_config {
25 	uint32_t bus_clock;
26 	uint8_t branch;
27 };
28 
29 #define SILABS_DT_CLOCK_CFG(node_id)                                                               \
30 	{                                                                                          \
31 		.bus_clock = DT_CLOCKS_CELL(node_id, enable),                                      \
32 		.branch = DT_CLOCKS_CELL(node_id, branch),                                         \
33 	}
34 
35 #define SILABS_DT_INST_CLOCK_CFG(inst)                                                             \
36 	{                                                                                          \
37 		.bus_clock = DT_INST_CLOCKS_CELL(inst, enable),                                    \
38 		.branch = DT_INST_CLOCKS_CELL(inst, branch),                                       \
39 	}
40 
41 #endif /* ZEPHYR_INCLUDE_DRIVERS_CLOCK_CONTROL_SILABS_H_ */
42