tools: fw_env: use erasesize from MEMGETINFO ioctl
[oweals/u-boot.git] / drivers / clk / Kconfig
1 menu "Clock"
2
3 config CLK
4         bool "Enable clock driver support"
5         depends on DM
6         help
7           This allows drivers to be provided for clock generators, including
8           oscillators and PLLs. Devices can use a common clock API to request
9           a particular clock rate and check on available clocks. Clocks can
10           feed into other clocks in a tree structure, with multiplexers to
11           choose the source for each clock.
12
13 config SPL_CLK
14         bool "Enable clock support in SPL"
15         depends on CLK && SPL && SPL_DM
16         help
17           The clock subsystem adds a small amount of overhead to the image.
18           If this is acceptable and you have a need to use clock drivers in
19           SPL, enable this option. It might provide a cleaner interface to
20           setting up clocks within SPL, and allows the same drivers to be
21           used as U-Boot proper.
22
23 config TPL_CLK
24         bool "Enable clock support in TPL"
25         depends on CLK && TPL_DM
26         help
27           The clock subsystem adds a small amount of overhead to the image.
28           If this is acceptable and you have a need to use clock drivers in
29           SPL, enable this option. It might provide a cleaner interface to
30           setting up clocks within TPL, and allows the same drivers to be
31           used as U-Boot proper.
32
33 config CLK_BCM6345
34         bool "Clock controller driver for BCM6345"
35         depends on CLK && ARCH_BMIPS
36         default y
37         help
38           This clock driver adds support for enabling and disabling peripheral
39           clocks on BCM6345 SoCs. HW has no rate changing capabilities.
40
41 config CLK_BOSTON
42         def_bool y if TARGET_BOSTON
43         depends on CLK
44         select REGMAP
45         select SYSCON
46         help
47           Enable this to support the clocks
48
49 config SPL_CLK_CCF
50         bool "SPL Common Clock Framework [CCF] support "
51         depends on SPL
52         help
53           Enable this option if you want to (re-)use the Linux kernel's Common
54           Clock Framework [CCF] code in U-Boot's SPL.
55
56 config SPL_CLK_COMPOSITE_CCF
57         bool "SPL Common Clock Framework [CCF] composite clk support "
58         depends on SPL_CLK_CCF
59         help
60           Enable this option if you want to (re-)use the Linux kernel's Common
61           Clock Framework [CCF] composite code in U-Boot's SPL.
62
63 config CLK_CCF
64         bool "Common Clock Framework [CCF] support "
65         help
66           Enable this option if you want to (re-)use the Linux kernel's Common
67           Clock Framework [CCF] code in U-Boot's clock driver.
68
69 config CLK_COMPOSITE_CCF
70         bool "Common Clock Framework [CCF] composite clk support "
71         depends on CLK_CCF
72         help
73           Enable this option if you want to (re-)use the Linux kernel's Common
74           Clock Framework [CCF] composite code in U-Boot's clock driver.
75
76 config CLK_INTEL
77         bool "Enable clock driver for Intel x86"
78         depends on CLK && X86
79         help
80           This provides very basic support for clocks on Intel SoCs. The driver
81           is barely used at present but could be expanded as needs arise.
82           Much clock configuration in U-Boot is either set up by the FSP, or
83           set up by U-Boot itself but only statically. Thus the driver does not
84           support changing clock rates, only querying them.
85
86 config CLK_STM32F
87         bool "Enable clock driver support for STM32F family"
88         depends on CLK && (STM32F7 || STM32F4)
89         default y
90         help
91           This clock driver adds support for RCC clock management
92           for STM32F4 and STM32F7 SoCs.
93
94 config CLK_TI_SCI
95         bool "TI System Control Interface (TI SCI) clock driver"
96         depends on CLK && TI_SCI_PROTOCOL && OF_CONTROL
97         help
98           This enables the clock driver support over TI System Control Interface
99           available on some new TI's SoCs. If you wish to use clock resources
100           managed by the TI System Controller, say Y here. Otherwise, say N.
101
102 config CLK_HSDK
103         bool "Enable cgu clock driver for HSDK"
104         depends on CLK
105         help
106           Enable this to support the cgu clocks on Synopsys ARC HSDK
107
108 config CLK_VERSAL
109         bool "Enable clock driver support for Versal"
110         depends on ARCH_VERSAL
111         select ZYNQMP_FIRMWARE
112         help
113           This clock driver adds support for clock realted settings for
114           Versal platform.
115
116 config CLK_VEXPRESS_OSC
117         bool "Enable driver for Arm Versatile Express OSC clock generators"
118         depends on CLK && VEXPRESS_CONFIG
119         help
120           This clock driver adds support for clock generators present on
121           Arm Versatile Express platforms.
122
123 config CLK_ZYNQ
124         bool "Enable clock driver support for Zynq"
125         depends on CLK && ARCH_ZYNQ
126         default y
127         help
128           This clock driver adds support for clock realted settings for
129           Zynq platform.
130
131 config CLK_ZYNQMP
132         bool "Enable clock driver support for ZynqMP"
133         depends on ARCH_ZYNQMP
134         select ZYNQMP_FIRMWARE
135         help
136           This clock driver adds support for clock realted settings for
137           ZynqMP platform.
138
139 config CLK_STM32MP1
140         bool "Enable RCC clock driver for STM32MP1"
141         depends on ARCH_STM32MP && CLK
142         default y
143         help
144           Enable the STM32 clock (RCC) driver. Enable support for
145           manipulating STM32MP1's on-SoC clocks.
146
147 config CLK_CDCE9XX
148         bool "Enable CDCD9XX clock driver"
149         depends on CLK
150         help
151            Enable the clock synthesizer driver for CDCE913/925/937/949
152            series of chips.
153
154 source "drivers/clk/analogbits/Kconfig"
155 source "drivers/clk/at91/Kconfig"
156 source "drivers/clk/exynos/Kconfig"
157 source "drivers/clk/imx/Kconfig"
158 source "drivers/clk/meson/Kconfig"
159 source "drivers/clk/mvebu/Kconfig"
160 source "drivers/clk/owl/Kconfig"
161 source "drivers/clk/renesas/Kconfig"
162 source "drivers/clk/sunxi/Kconfig"
163 source "drivers/clk/sifive/Kconfig"
164 source "drivers/clk/tegra/Kconfig"
165 source "drivers/clk/uniphier/Kconfig"
166
167 config ICS8N3QV01
168         bool "Enable ICS8N3QV01 VCXO driver"
169         depends on CLK
170         help
171           Support for the ICS8N3QV01 Quad-Frequency VCXO (Voltage-Controlled
172           Crystal Oscillator). The output frequency can be programmed via an
173           I2C interface.
174
175 config CLK_MPC83XX
176         bool "Enable MPC83xx clock driver"
177         depends on CLK
178         help
179           Support for the clock driver of the MPC83xx series of SoCs.
180
181 config SANDBOX_CLK_CCF
182         bool "Sandbox Common Clock Framework [CCF] support "
183         depends on SANDBOX
184         select CLK_CCF
185         help
186           Enable this option if you want to test the Linux kernel's Common
187           Clock Framework [CCF] code in U-Boot's Sandbox clock driver.
188
189 endmenu