Thomas Gleixner | ec8f24b | 2019-05-19 13:07:45 +0100 | [diff] [blame] | 1 | # SPDX-License-Identifier: GPL-2.0-only |
Kukjin Kim | f7d7707 | 2011-06-01 14:18:22 -0700 | [diff] [blame] | 2 | # |
| 3 | # ARM CPU Frequency scaling drivers |
| 4 | # |
| 5 | |
Gregory CLEMENT | b17d2f8 | 2017-12-13 18:05:35 +0100 | [diff] [blame] | 6 | config 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 Li | f328584 | 2019-06-12 12:28:15 -0400 | [diff] [blame] | 22 | config 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 CLEMENT | 92ce45f | 2017-12-14 16:00:05 +0100 | [diff] [blame] | 34 | config ARM_ARMADA_37XX_CPUFREQ |
| 35 | tristate "Armada 37xx CPUFreq support" |
Miquel Raynal | 0cf442c | 2018-04-24 17:45:06 +0200 | [diff] [blame] | 36 | depends on ARCH_MVEBU && CPUFREQ_DT |
Gregory CLEMENT | 92ce45f | 2017-12-14 16:00:05 +0100 | [diff] [blame] | 37 | 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 CLEMENT | f525a67 | 2019-01-18 15:51:01 +0100 | [diff] [blame] | 41 | config ARM_ARMADA_8K_CPUFREQ |
| 42 | tristate "Armada 8K CPUFreq driver" |
| 43 | depends on ARCH_MVEBU && CPUFREQ_DT |
Sven Auhagen | 8c37ad2 | 2020-06-22 14:01:23 +0200 | [diff] [blame] | 44 | select ARMADA_AP_CPU_CLK |
Gregory CLEMENT | f525a67 | 2019-01-18 15:51:01 +0100 | [diff] [blame] | 45 | 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 CLEMENT | b17d2f8 | 2017-12-13 18:05:35 +0100 | [diff] [blame] | 53 | config ARM_SCPI_CPUFREQ |
| 54 | tristate "SCPI based CPUfreq driver" |
Sudeep Holla | 5c8b262 | 2018-02-23 15:54:42 +0000 | [diff] [blame] | 55 | depends on ARM_SCPI_PROTOCOL && COMMON_CLK_SCPI |
Gregory CLEMENT | b17d2f8 | 2017-12-13 18:05:35 +0100 | [diff] [blame] | 56 | help |
Sudeep Holla | 5c8b262 | 2018-02-23 15:54:42 +0000 | [diff] [blame] | 57 | This adds the CPUfreq driver support for ARM platforms using SCPI |
| 58 | protocol for CPU power management. |
Gregory CLEMENT | b17d2f8 | 2017-12-13 18:05:35 +0100 | [diff] [blame] | 59 | |
| 60 | This driver uses SCPI Message Protocol driver to interact with the |
| 61 | firmware providing the CPU DVFS functionality. |
| 62 | |
| 63 | config ARM_VEXPRESS_SPC_CPUFREQ |
| 64 | tristate "Versatile Express SPC based CPUfreq driver" |
Sudeep Holla | a0f950d | 2019-10-21 11:20:34 +0100 | [diff] [blame] | 65 | depends on ARM_CPU_TOPOLOGY && HAVE_CLK |
| 66 | depends on ARCH_VEXPRESS_SPC |
| 67 | select PM_OPP |
Gregory CLEMENT | b17d2f8 | 2017-12-13 18:05:35 +0100 | [diff] [blame] | 68 | help |
| 69 | This add the CPUfreq driver support for Versatile Express |
| 70 | big.LITTLE platforms using SPC for power management. |
| 71 | |
Markus Mayer | de322e0 | 2016-10-27 14:05:35 -0700 | [diff] [blame] | 72 | config 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 Kumar | a0ea048 | 2013-04-04 12:54:09 +0000 | [diff] [blame] | 83 | config ARM_HIGHBANK_CPUFREQ |
| 84 | tristate "Calxeda Highbank-based" |
Viresh Kumar | bbcf071 | 2014-09-09 19:58:03 +0530 | [diff] [blame] | 85 | depends on ARCH_HIGHBANK && CPUFREQ_DT && REGULATOR |
Viresh Kumar | a0ea048 | 2013-04-04 12:54:09 +0000 | [diff] [blame] | 86 | 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 | |
| 93 | config ARM_IMX6Q_CPUFREQ |
Shawn Guo | 1d0eaae | 2013-12-20 10:12:16 +0800 | [diff] [blame] | 94 | tristate "Freescale i.MX6 cpufreq support" |
| 95 | depends on ARCH_MXC |
Viresh Kumar | a0ea048 | 2013-04-04 12:54:09 +0000 | [diff] [blame] | 96 | depends on REGULATOR_ANATOP |
Walter Lozano | 2782ef3 | 2020-07-14 15:43:56 -0300 | [diff] [blame] | 97 | select NVMEM_IMX_OCOTP |
Nicolas Del Piano | 7e02168 | 2014-07-13 18:59:00 -0300 | [diff] [blame] | 98 | select PM_OPP |
Viresh Kumar | a0ea048 | 2013-04-04 12:54:09 +0000 | [diff] [blame] | 99 | help |
Shawn Guo | 1d0eaae | 2013-12-20 10:12:16 +0800 | [diff] [blame] | 100 | This adds cpufreq driver support for Freescale i.MX6 series SoCs. |
Viresh Kumar | a0ea048 | 2013-04-04 12:54:09 +0000 | [diff] [blame] | 101 | |
| 102 | If in doubt, say N. |
| 103 | |
Leonard Crestez | 4d28ba1 | 2019-05-13 11:01:38 +0000 | [diff] [blame] | 104 | config 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 Kumar | a0ea048 | 2013-04-04 12:54:09 +0000 | [diff] [blame] | 113 | config ARM_KIRKWOOD_CPUFREQ |
Andrew Lunn | 6c8df11 | 2014-08-30 18:46:12 +0200 | [diff] [blame] | 114 | def_bool MACH_KIRKWOOD |
Viresh Kumar | a0ea048 | 2013-04-04 12:54:09 +0000 | [diff] [blame] | 115 | help |
| 116 | This adds the CPUFreq driver for Marvell Kirkwood |
| 117 | SoCs. |
| 118 | |
Sean Wang | 501c574 | 2017-07-18 14:01:43 +0800 | [diff] [blame] | 119 | config ARM_MEDIATEK_CPUFREQ |
| 120 | tristate "CPU Frequency scaling support for MediaTek SoCs" |
Pi-Cheng Chen | 1453863 | 2015-08-19 10:05:06 +0800 | [diff] [blame] | 121 | depends on ARCH_MEDIATEK && REGULATOR |
| 122 | select PM_OPP |
| 123 | help |
Sean Wang | 501c574 | 2017-07-18 14:01:43 +0800 | [diff] [blame] | 124 | This adds the CPUFreq driver support for MediaTek SoCs. |
Pi-Cheng Chen | 1453863 | 2015-08-19 10:05:06 +0800 | [diff] [blame] | 125 | |
Russell King | b09db45 | 2012-02-15 11:01:11 -0800 | [diff] [blame] | 126 | config ARM_OMAP2PLUS_CPUFREQ |
| 127 | bool "TI OMAP2+" |
Kevin Hilman | 2d59dcf | 2012-04-13 13:32:30 -0700 | [diff] [blame] | 128 | depends on ARCH_OMAP2PLUS |
Russell King | b09db45 | 2012-02-15 11:01:11 -0800 | [diff] [blame] | 129 | default ARCH_OMAP2PLUS |
Russell King | b09db45 | 2012-02-15 11:01:11 -0800 | [diff] [blame] | 130 | |
Sricharan R | 7d12709 | 2019-07-25 12:41:31 +0200 | [diff] [blame] | 131 | config ARM_QCOM_CPUFREQ_NVMEM |
| 132 | tristate "Qualcomm nvmem based CPUFreq" |
Ansuel Smith | a8811ec | 2020-03-13 18:52:13 +0100 | [diff] [blame] | 133 | depends on ARCH_QCOM |
Ilia Lin | 46e2856 | 2018-05-30 05:39:28 +0300 | [diff] [blame] | 134 | 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 Das | 2849dd8 | 2018-12-14 09:40:24 +0530 | [diff] [blame] | 142 | config 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 Julienne | d3df18a | 2019-06-12 20:24:56 +0200 | [diff] [blame] | 153 | config 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 Kumar | f023f8d | 2013-04-04 12:54:15 +0000 | [diff] [blame] | 161 | config ARM_S3C_CPUFREQ |
| 162 | bool |
| 163 | help |
| 164 | Internal configuration node for common cpufreq on Samsung SoC |
| 165 | |
| 166 | config 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 | |
| 178 | config 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 | |
| 184 | config 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 | |
| 190 | config 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 | |
| 196 | config 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 | |
| 203 | config 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übner | 34ee5507 | 2012-02-16 11:42:32 +0100 | [diff] [blame] | 211 | config 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 Karafotis | 735dc24 | 2014-04-22 22:40:10 +0300 | [diff] [blame] | 219 | core voltage of the CPU. |
Heiko Stübner | 34ee5507 | 2012-02-16 11:42:32 +0100 | [diff] [blame] | 220 | |
| 221 | If in doubt, say N. |
| 222 | |
| 223 | config ARM_S3C2416_CPUFREQ_VCORESCALE |
Kees Cook | 0f194b56 | 2012-10-02 11:16:53 -0700 | [diff] [blame] | 224 | bool "Allow voltage scaling for S3C2416 arm core" |
| 225 | depends on ARM_S3C2416_CPUFREQ && REGULATOR |
Heiko Stübner | 34ee5507 | 2012-02-16 11:42:32 +0100 | [diff] [blame] | 226 | 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 Kumar | f023f8d | 2013-04-04 12:54:15 +0000 | [diff] [blame] | 233 | config 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 Kim | 15964d3 | 2011-06-06 18:43:01 -0700 | [diff] [blame] | 241 | config 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 Kim | f7d7707 | 2011-06-01 14:18:22 -0700 | [diff] [blame] | 250 | config 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 Kumar | 59a2e61 | 2013-04-04 12:54:16 +0000 | [diff] [blame] | 260 | config ARM_SA1100_CPUFREQ |
| 261 | bool |
| 262 | |
| 263 | config ARM_SA1110_CPUFREQ |
| 264 | bool |
| 265 | |
Sudeep Holla | 99d6bdf | 2017-06-18 09:38:11 +0100 | [diff] [blame] | 266 | config 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 Sikri | 4209932 | 2012-11-27 14:05:26 +0100 | [diff] [blame] | 277 | config 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 Kumar | dbb8d76 | 2013-06-12 12:05:48 +0530 | [diff] [blame] | 283 | |
Lee Jones | ab0ea25 | 2015-12-10 09:42:16 +0000 | [diff] [blame] | 284 | config 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 Gonzalez | 9dbd224 | 2017-07-18 18:48:39 +0200 | [diff] [blame] | 294 | config ARM_TANGO_CPUFREQ |
| 295 | bool |
| 296 | depends on CPUFREQ_DT && ARCH_TANGO |
| 297 | default y |
| 298 | |
Tuomas Tynkkynen | 109e13e | 2015-05-13 17:58:47 +0300 | [diff] [blame] | 299 | config ARM_TEGRA20_CPUFREQ |
Dmitry Osipenko | 9ce2746 | 2020-03-19 22:02:26 +0300 | [diff] [blame] | 300 | tristate "Tegra20/30 CPUFreq support" |
| 301 | depends on ARCH_TEGRA && CPUFREQ_DT |
Viresh Kumar | dbb8d76 | 2013-06-12 12:05:48 +0530 | [diff] [blame] | 302 | default y |
| 303 | help |
Dmitry Osipenko | 9ce2746 | 2020-03-19 22:02:26 +0300 | [diff] [blame] | 304 | This adds the CPUFreq driver support for Tegra20/30 SOCs. |
Petr Cvek | 608eab2 | 2014-11-24 04:59:26 +0100 | [diff] [blame] | 305 | |
Tuomas Tynkkynen | 9eb15db | 2015-05-13 17:58:48 +0300 | [diff] [blame] | 306 | config ARM_TEGRA124_CPUFREQ |
Joseph Lo | 9f5ed5f | 2019-01-04 11:06:53 +0800 | [diff] [blame] | 307 | bool "Tegra124 CPUFreq support" |
| 308 | depends on ARCH_TEGRA && CPUFREQ_DT |
Tuomas Tynkkynen | 9eb15db | 2015-05-13 17:58:48 +0300 | [diff] [blame] | 309 | default y |
| 310 | help |
| 311 | This adds the CPUFreq driver support for Tegra124 SOCs. |
| 312 | |
Mikko Perttunen | 939dc6f | 2017-04-11 11:09:15 +0300 | [diff] [blame] | 313 | config 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 Gupta | df320f8 | 2020-07-16 14:00:01 +0530 | [diff] [blame] | 319 | config 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 Gerlach | e13cf04 | 2017-02-03 11:29:28 -0600 | [diff] [blame] | 326 | config ARM_TI_CPUFREQ |
| 327 | bool "Texas Instruments CPUFreq support" |
| 328 | depends on ARCH_OMAP2PLUS |
Anders Roxell | 59b55c1 | 2020-04-15 10:15:59 +0200 | [diff] [blame] | 329 | default ARCH_OMAP2PLUS |
Dave Gerlach | e13cf04 | 2017-02-03 11:29:28 -0600 | [diff] [blame] | 330 | 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 Cvek | 608eab2 | 2014-11-24 04:59:26 +0100 | [diff] [blame] | 338 | config 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. |