blob: cb72fb507d5740f9b6a3113735d1a64271419321 [file] [log] [blame]
Thomas Gleixnerec8f24b2019-05-19 13:07:45 +01001# SPDX-License-Identifier: GPL-2.0-only
Kukjin Kimf7d77072011-06-01 14:18:22 -07002#
3# ARM CPU Frequency scaling drivers
4#
5
Gregory CLEMENTb17d2f82017-12-13 18:05:35 +01006config ACPI_CPPC_CPUFREQ
7 tristate "CPUFreq driver based on the ACPI CPPC spec"
8 depends on ACPI_PROCESSOR
9 select ACPI_CPPC_LIB
10 help
11 This adds a CPUFreq driver which uses CPPC methods
12 as described in the ACPIv5.1 spec. CPPC stands for
13 Collaborative Processor Performance Controls. It
14 is based on an abstract continuous scale of CPU
15 performance values which allows the remote power
16 processor to flexibly optimize for power and
17 performance. CPPC relies on power management firmware
18 support for its operation.
19
20 If in doubt, say N.
21
Yangtao Lif3285842019-06-12 12:28:15 -040022config ARM_ALLWINNER_SUN50I_CPUFREQ_NVMEM
23 tristate "Allwinner nvmem based SUN50I CPUFreq driver"
24 depends on ARCH_SUNXI
25 depends on NVMEM_SUNXI_SID
26 select PM_OPP
27 help
28 This adds the nvmem based CPUFreq driver for Allwinner
29 h6 SoC.
30
31 To compile this driver as a module, choose M here: the
32 module will be called sun50i-cpufreq-nvmem.
33
Gregory CLEMENT92ce45f2017-12-14 16:00:05 +010034config ARM_ARMADA_37XX_CPUFREQ
35 tristate "Armada 37xx CPUFreq support"
Miquel Raynal0cf442c2018-04-24 17:45:06 +020036 depends on ARCH_MVEBU && CPUFREQ_DT
Gregory CLEMENT92ce45f2017-12-14 16:00:05 +010037 help
38 This adds the CPUFreq driver support for Marvell Armada 37xx SoCs.
39 The Armada 37xx PMU supports 4 frequency and VDD levels.
40
Gregory CLEMENTf525a672019-01-18 15:51:01 +010041config ARM_ARMADA_8K_CPUFREQ
42 tristate "Armada 8K CPUFreq driver"
43 depends on ARCH_MVEBU && CPUFREQ_DT
Sven Auhagen8c37ad22020-06-22 14:01:23 +020044 select ARMADA_AP_CPU_CLK
Gregory CLEMENTf525a672019-01-18 15:51:01 +010045 help
46 This enables the CPUFreq driver support for Marvell
47 Armada8k SOCs.
48 Armada8K device has the AP806 which supports scaling
49 to any full integer divider.
50
51 If in doubt, say N.
52
Gregory CLEMENTb17d2f82017-12-13 18:05:35 +010053config ARM_SCPI_CPUFREQ
54 tristate "SCPI based CPUfreq driver"
Sudeep Holla5c8b2622018-02-23 15:54:42 +000055 depends on ARM_SCPI_PROTOCOL && COMMON_CLK_SCPI
Gregory CLEMENTb17d2f82017-12-13 18:05:35 +010056 help
Sudeep Holla5c8b2622018-02-23 15:54:42 +000057 This adds the CPUfreq driver support for ARM platforms using SCPI
58 protocol for CPU power management.
Gregory CLEMENTb17d2f82017-12-13 18:05:35 +010059
60 This driver uses SCPI Message Protocol driver to interact with the
61 firmware providing the CPU DVFS functionality.
62
63config ARM_VEXPRESS_SPC_CPUFREQ
64 tristate "Versatile Express SPC based CPUfreq driver"
Sudeep Hollaa0f950d2019-10-21 11:20:34 +010065 depends on ARM_CPU_TOPOLOGY && HAVE_CLK
66 depends on ARCH_VEXPRESS_SPC
67 select PM_OPP
Gregory CLEMENTb17d2f82017-12-13 18:05:35 +010068 help
69 This add the CPUfreq driver support for Versatile Express
70 big.LITTLE platforms using SPC for power management.
71
Markus Mayerde322e02016-10-27 14:05:35 -070072config ARM_BRCMSTB_AVS_CPUFREQ
73 tristate "Broadcom STB AVS CPUfreq driver"
74 depends on ARCH_BRCMSTB || COMPILE_TEST
75 default y
76 help
77 Some Broadcom STB SoCs use a co-processor running proprietary firmware
78 ("AVS") to handle voltage and frequency scaling. This driver provides
79 a standard CPUfreq interface to to the firmware.
80
81 Say Y, if you have a Broadcom SoC with AVS support for DFS or DVFS.
82
Viresh Kumara0ea0482013-04-04 12:54:09 +000083config ARM_HIGHBANK_CPUFREQ
84 tristate "Calxeda Highbank-based"
Viresh Kumarbbcf0712014-09-09 19:58:03 +053085 depends on ARCH_HIGHBANK && CPUFREQ_DT && REGULATOR
Viresh Kumara0ea0482013-04-04 12:54:09 +000086 default m
87 help
88 This adds the CPUFreq driver for Calxeda Highbank SoC
89 based boards.
90
91 If in doubt, say N.
92
93config ARM_IMX6Q_CPUFREQ
Shawn Guo1d0eaae2013-12-20 10:12:16 +080094 tristate "Freescale i.MX6 cpufreq support"
95 depends on ARCH_MXC
Viresh Kumara0ea0482013-04-04 12:54:09 +000096 depends on REGULATOR_ANATOP
Walter Lozano2782ef32020-07-14 15:43:56 -030097 select NVMEM_IMX_OCOTP
Nicolas Del Piano7e021682014-07-13 18:59:00 -030098 select PM_OPP
Viresh Kumara0ea0482013-04-04 12:54:09 +000099 help
Shawn Guo1d0eaae2013-12-20 10:12:16 +0800100 This adds cpufreq driver support for Freescale i.MX6 series SoCs.
Viresh Kumara0ea0482013-04-04 12:54:09 +0000101
102 If in doubt, say N.
103
Leonard Crestez4d28ba12019-05-13 11:01:38 +0000104config ARM_IMX_CPUFREQ_DT
105 tristate "Freescale i.MX8M cpufreq support"
106 depends on ARCH_MXC && CPUFREQ_DT
107 help
108 This adds cpufreq driver support for Freescale i.MX8M series SoCs,
109 based on cpufreq-dt.
110
111 If in doubt, say N.
112
Viresh Kumara0ea0482013-04-04 12:54:09 +0000113config ARM_KIRKWOOD_CPUFREQ
Andrew Lunn6c8df112014-08-30 18:46:12 +0200114 def_bool MACH_KIRKWOOD
Viresh Kumara0ea0482013-04-04 12:54:09 +0000115 help
116 This adds the CPUFreq driver for Marvell Kirkwood
117 SoCs.
118
Sean Wang501c5742017-07-18 14:01:43 +0800119config ARM_MEDIATEK_CPUFREQ
120 tristate "CPU Frequency scaling support for MediaTek SoCs"
Pi-Cheng Chen14538632015-08-19 10:05:06 +0800121 depends on ARCH_MEDIATEK && REGULATOR
122 select PM_OPP
123 help
Sean Wang501c5742017-07-18 14:01:43 +0800124 This adds the CPUFreq driver support for MediaTek SoCs.
Pi-Cheng Chen14538632015-08-19 10:05:06 +0800125
Russell Kingb09db452012-02-15 11:01:11 -0800126config ARM_OMAP2PLUS_CPUFREQ
127 bool "TI OMAP2+"
Kevin Hilman2d59dcf2012-04-13 13:32:30 -0700128 depends on ARCH_OMAP2PLUS
Russell Kingb09db452012-02-15 11:01:11 -0800129 default ARCH_OMAP2PLUS
Russell Kingb09db452012-02-15 11:01:11 -0800130
Sricharan R7d127092019-07-25 12:41:31 +0200131config ARM_QCOM_CPUFREQ_NVMEM
132 tristate "Qualcomm nvmem based CPUFreq"
Ansuel Smitha8811ec2020-03-13 18:52:13 +0100133 depends on ARCH_QCOM
Ilia Lin46e28562018-05-30 05:39:28 +0300134 depends on QCOM_QFPROM
135 depends on QCOM_SMEM
136 select PM_OPP
137 help
138 This adds the CPUFreq driver for Qualcomm Kryo SoC based boards.
139
140 If in doubt, say N.
141
Taniya Das2849dd82018-12-14 09:40:24 +0530142config ARM_QCOM_CPUFREQ_HW
143 tristate "QCOM CPUFreq HW driver"
144 depends on ARCH_QCOM || COMPILE_TEST
145 help
146 Support for the CPUFreq HW driver.
147 Some QCOM chipsets have a HW engine to offload the steps
148 necessary for changing the frequency of the CPUs. Firmware loaded
149 in this engine exposes a programming interface to the OS.
150 The driver implements the cpufreq interface for this HW engine.
151 Say Y if you want to support CPUFreq HW.
152
Nicolas Saenz Julienned3df18a2019-06-12 20:24:56 +0200153config ARM_RASPBERRYPI_CPUFREQ
154 tristate "Raspberry Pi cpufreq support"
155 depends on CLK_RASPBERRYPI || COMPILE_TEST
156 help
157 This adds the CPUFreq driver for Raspberry Pi
158
159 If in doubt, say N.
160
Viresh Kumarf023f8d2013-04-04 12:54:15 +0000161config ARM_S3C_CPUFREQ
162 bool
163 help
164 Internal configuration node for common cpufreq on Samsung SoC
165
166config ARM_S3C24XX_CPUFREQ
167 bool "CPUfreq driver for Samsung S3C24XX series CPUs (EXPERIMENTAL)"
168 depends on ARCH_S3C24XX
169 select ARM_S3C_CPUFREQ
170 help
171 This enables the CPUfreq driver for the Samsung S3C24XX family
172 of CPUs.
173
174 For details, take a look at <file:Documentation/cpu-freq>.
175
176 If in doubt, say N.
177
178config ARM_S3C24XX_CPUFREQ_DEBUG
179 bool "Debug CPUfreq Samsung driver core"
180 depends on ARM_S3C24XX_CPUFREQ
181 help
182 Enable s3c_freq_dbg for the Samsung S3C CPUfreq core
183
184config ARM_S3C24XX_CPUFREQ_IODEBUG
185 bool "Debug CPUfreq Samsung driver IO timing"
186 depends on ARM_S3C24XX_CPUFREQ
187 help
188 Enable s3c_freq_iodbg for the Samsung S3C CPUfreq core
189
190config ARM_S3C24XX_CPUFREQ_DEBUGFS
191 bool "Export debugfs for CPUFreq"
192 depends on ARM_S3C24XX_CPUFREQ && DEBUG_FS
193 help
194 Export status information via debugfs.
195
196config ARM_S3C2410_CPUFREQ
197 bool
198 depends on ARM_S3C24XX_CPUFREQ && CPU_S3C2410
199 select S3C2410_CPUFREQ_UTILS
200 help
201 CPU Frequency scaling support for S3C2410
202
203config ARM_S3C2412_CPUFREQ
204 bool
205 depends on ARM_S3C24XX_CPUFREQ && CPU_S3C2412
206 default y
207 select S3C2412_IOTIMING
208 help
209 CPU Frequency scaling support for S3C2412 and S3C2413 SoC CPUs.
210
Heiko Stübner34ee55072012-02-16 11:42:32 +0100211config ARM_S3C2416_CPUFREQ
212 bool "S3C2416 CPU Frequency scaling support"
213 depends on CPU_S3C2416
214 help
215 This adds the CPUFreq driver for the Samsung S3C2416 and
216 S3C2450 SoC. The S3C2416 supports changing the rate of the
217 armdiv clock source and also entering a so called dynamic
218 voltage scaling mode in which it is possible to reduce the
Stratos Karafotis735dc242014-04-22 22:40:10 +0300219 core voltage of the CPU.
Heiko Stübner34ee55072012-02-16 11:42:32 +0100220
221 If in doubt, say N.
222
223config ARM_S3C2416_CPUFREQ_VCORESCALE
Kees Cook0f194b562012-10-02 11:16:53 -0700224 bool "Allow voltage scaling for S3C2416 arm core"
225 depends on ARM_S3C2416_CPUFREQ && REGULATOR
Heiko Stübner34ee55072012-02-16 11:42:32 +0100226 help
227 Enable CPU voltage scaling when entering the dvs mode.
228 It uses information gathered through existing hardware and
229 tests but not documented in any datasheet.
230
231 If in doubt, say N.
232
Viresh Kumarf023f8d2013-04-04 12:54:15 +0000233config ARM_S3C2440_CPUFREQ
234 bool "S3C2440/S3C2442 CPU Frequency scaling support"
235 depends on ARM_S3C24XX_CPUFREQ && (CPU_S3C2440 || CPU_S3C2442)
236 select S3C2410_CPUFREQ_UTILS
237 default y
238 help
239 CPU Frequency scaling support for S3C2440 and S3C2442 SoC CPUs.
240
Kukjin Kim15964d32011-06-06 18:43:01 -0700241config ARM_S3C64XX_CPUFREQ
242 bool "Samsung S3C64XX"
243 depends on CPU_S3C6410
244 default y
245 help
246 This adds the CPUFreq driver for Samsung S3C6410 SoC.
247
248 If in doubt, say N.
249
Kukjin Kimf7d77072011-06-01 14:18:22 -0700250config ARM_S5PV210_CPUFREQ
251 bool "Samsung S5PV210 and S5PC110"
252 depends on CPU_S5PV210
253 default y
254 help
255 This adds the CPUFreq driver for Samsung S5PV210 and
256 S5PC110 SoCs.
257
258 If in doubt, say N.
259
Viresh Kumar59a2e612013-04-04 12:54:16 +0000260config ARM_SA1100_CPUFREQ
261 bool
262
263config ARM_SA1110_CPUFREQ
264 bool
265
Sudeep Holla99d6bdf2017-06-18 09:38:11 +0100266config ARM_SCMI_CPUFREQ
267 tristate "SCMI based CPUfreq driver"
268 depends on ARM_SCMI_PROTOCOL || COMPILE_TEST
269 select PM_OPP
270 help
271 This adds the CPUfreq driver support for ARM platforms using SCMI
272 protocol for CPU power management.
273
274 This driver uses SCMI Message Protocol driver to interact with the
275 firmware providing the CPU DVFS functionality.
276
Deepak Sikri42099322012-11-27 14:05:26 +0100277config ARM_SPEAR_CPUFREQ
278 bool "SPEAr CPUFreq support"
279 depends on PLAT_SPEAR
280 default y
281 help
282 This adds the CPUFreq driver support for SPEAr SOCs.
Viresh Kumardbb8d762013-06-12 12:05:48 +0530283
Lee Jonesab0ea252015-12-10 09:42:16 +0000284config ARM_STI_CPUFREQ
285 tristate "STi CPUFreq support"
286 depends on SOC_STIH407
287 help
288 This driver uses the generic OPP framework to match the running
289 platform with a predefined set of suitable values. If not provided
290 we will fall-back so safe-values contained in Device Tree. Enable
291 this config option if you wish to add CPUFreq support for STi based
292 SoCs.
293
Marc Gonzalez9dbd2242017-07-18 18:48:39 +0200294config ARM_TANGO_CPUFREQ
295 bool
296 depends on CPUFREQ_DT && ARCH_TANGO
297 default y
298
Tuomas Tynkkynen109e13e2015-05-13 17:58:47 +0300299config ARM_TEGRA20_CPUFREQ
Dmitry Osipenko9ce27462020-03-19 22:02:26 +0300300 tristate "Tegra20/30 CPUFreq support"
301 depends on ARCH_TEGRA && CPUFREQ_DT
Viresh Kumardbb8d762013-06-12 12:05:48 +0530302 default y
303 help
Dmitry Osipenko9ce27462020-03-19 22:02:26 +0300304 This adds the CPUFreq driver support for Tegra20/30 SOCs.
Petr Cvek608eab22014-11-24 04:59:26 +0100305
Tuomas Tynkkynen9eb15db2015-05-13 17:58:48 +0300306config ARM_TEGRA124_CPUFREQ
Joseph Lo9f5ed5f2019-01-04 11:06:53 +0800307 bool "Tegra124 CPUFreq support"
308 depends on ARCH_TEGRA && CPUFREQ_DT
Tuomas Tynkkynen9eb15db2015-05-13 17:58:48 +0300309 default y
310 help
311 This adds the CPUFreq driver support for Tegra124 SOCs.
312
Mikko Perttunen939dc6f2017-04-11 11:09:15 +0300313config ARM_TEGRA186_CPUFREQ
314 tristate "Tegra186 CPUFreq support"
315 depends on ARCH_TEGRA && TEGRA_BPMP
316 help
317 This adds the CPUFreq driver support for Tegra186 SOCs.
318
Sumit Guptadf320f82020-07-16 14:00:01 +0530319config ARM_TEGRA194_CPUFREQ
320 tristate "Tegra194 CPUFreq support"
321 depends on ARCH_TEGRA_194_SOC && TEGRA_BPMP
322 default y
323 help
324 This adds CPU frequency driver support for Tegra194 SOCs.
325
Dave Gerlache13cf042017-02-03 11:29:28 -0600326config ARM_TI_CPUFREQ
327 bool "Texas Instruments CPUFreq support"
328 depends on ARCH_OMAP2PLUS
Anders Roxell59b55c12020-04-15 10:15:59 +0200329 default ARCH_OMAP2PLUS
Dave Gerlache13cf042017-02-03 11:29:28 -0600330 help
331 This driver enables valid OPPs on the running platform based on
332 values contained within the SoC in use. Enable this in order to
333 use the cpufreq-dt driver on all Texas Instruments platforms that
334 provide dt based operating-points-v2 tables with opp-supported-hw
335 data provided. Required for cpufreq support on AM335x, AM437x,
336 DRA7x, and AM57x platforms.
337
Petr Cvek608eab22014-11-24 04:59:26 +0100338config ARM_PXA2xx_CPUFREQ
339 tristate "Intel PXA2xx CPUfreq driver"
340 depends on PXA27x || PXA25x
341 help
342 This add the CPUFreq driver support for Intel PXA2xx SOCs.
343
344 If in doubt, say N.