Kukjin Kim | f7d7707 | 2011-06-01 14:18:22 -0700 | [diff] [blame] | 1 | # |
| 2 | # ARM CPU Frequency scaling drivers |
| 3 | # |
| 4 | |
viresh kumar | 3b84d58 | 2014-03-14 12:10:54 +0530 | [diff] [blame] | 5 | # big LITTLE core layer and glue drivers |
Viresh Kumar | 8a67f0e | 2013-04-01 12:57:49 +0000 | [diff] [blame] | 6 | config ARM_BIG_LITTLE_CPUFREQ |
Viresh Kumar | 99af771 | 2013-05-04 12:03:54 +0530 | [diff] [blame] | 7 | tristate "Generic ARM big LITTLE CPUfreq driver" |
Sudeep Holla | 1473014 | 2015-05-13 13:35:52 +0100 | [diff] [blame] | 8 | depends on (ARM_CPU_TOPOLOGY || ARM64) && HAVE_CLK |
Punit Agrawal | 2f7e8a1 | 2015-11-17 12:06:23 +0000 | [diff] [blame] | 9 | # if CPU_THERMAL is on and THERMAL=m, ARM_BIT_LITTLE_CPUFREQ cannot be =y |
| 10 | depends on !CPU_THERMAL || THERMAL |
Mark Brown | 109df08 | 2013-12-11 22:12:27 +0000 | [diff] [blame] | 11 | select PM_OPP |
Viresh Kumar | 99af771 | 2013-05-04 12:03:54 +0530 | [diff] [blame] | 12 | help |
| 13 | This enables the Generic CPUfreq driver for ARM big.LITTLE platforms. |
Viresh Kumar | 8a67f0e | 2013-04-01 12:57:49 +0000 | [diff] [blame] | 14 | |
Markus Mayer | de322e0 | 2016-10-27 14:05:35 -0700 | [diff] [blame^] | 15 | config ARM_BRCMSTB_AVS_CPUFREQ |
| 16 | tristate "Broadcom STB AVS CPUfreq driver" |
| 17 | depends on ARCH_BRCMSTB || COMPILE_TEST |
| 18 | default y |
| 19 | help |
| 20 | Some Broadcom STB SoCs use a co-processor running proprietary firmware |
| 21 | ("AVS") to handle voltage and frequency scaling. This driver provides |
| 22 | a standard CPUfreq interface to to the firmware. |
| 23 | |
| 24 | Say Y, if you have a Broadcom SoC with AVS support for DFS or DVFS. |
| 25 | |
Viresh Kumar | 8a67f0e | 2013-04-01 12:57:49 +0000 | [diff] [blame] | 26 | config ARM_DT_BL_CPUFREQ |
Viresh Kumar | 99af771 | 2013-05-04 12:03:54 +0530 | [diff] [blame] | 27 | tristate "Generic probing via DT for ARM big LITTLE CPUfreq driver" |
| 28 | depends on ARM_BIG_LITTLE_CPUFREQ && OF |
Viresh Kumar | 8a67f0e | 2013-04-01 12:57:49 +0000 | [diff] [blame] | 29 | help |
Viresh Kumar | 99af771 | 2013-05-04 12:03:54 +0530 | [diff] [blame] | 30 | This enables probing via DT for Generic CPUfreq driver for ARM |
| 31 | big.LITTLE platform. This gets frequency tables from DT. |
Viresh Kumar | 8a67f0e | 2013-04-01 12:57:49 +0000 | [diff] [blame] | 32 | |
viresh kumar | 3b84d58 | 2014-03-14 12:10:54 +0530 | [diff] [blame] | 33 | config ARM_VEXPRESS_SPC_CPUFREQ |
| 34 | tristate "Versatile Express SPC based CPUfreq driver" |
| 35 | depends on ARM_BIG_LITTLE_CPUFREQ && ARCH_VEXPRESS_SPC |
| 36 | help |
| 37 | This add the CPUfreq driver support for Versatile Express |
| 38 | big.LITTLE platforms using SPC for power management. |
| 39 | |
Arnd Bergmann | 8b2b4a4 | 2015-01-31 14:35:18 -0400 | [diff] [blame] | 40 | config ARM_EXYNOS5440_CPUFREQ |
| 41 | tristate "SAMSUNG EXYNOS5440" |
| 42 | depends on SOC_EXYNOS5440 |
| 43 | depends on HAVE_CLK && OF |
| 44 | select PM_OPP |
| 45 | default y |
| 46 | help |
| 47 | This adds the CPUFreq driver for Samsung EXYNOS5440 |
| 48 | SoC. The nature of exynos5440 clock controller is |
| 49 | different than previous exynos controllers so not using |
| 50 | the common exynos framework. |
| 51 | |
| 52 | If in doubt, say N. |
| 53 | |
Viresh Kumar | a0ea048 | 2013-04-04 12:54:09 +0000 | [diff] [blame] | 54 | config ARM_HIGHBANK_CPUFREQ |
| 55 | tristate "Calxeda Highbank-based" |
Viresh Kumar | bbcf071 | 2014-09-09 19:58:03 +0530 | [diff] [blame] | 56 | depends on ARCH_HIGHBANK && CPUFREQ_DT && REGULATOR |
Viresh Kumar | a0ea048 | 2013-04-04 12:54:09 +0000 | [diff] [blame] | 57 | default m |
| 58 | help |
| 59 | This adds the CPUFreq driver for Calxeda Highbank SoC |
| 60 | based boards. |
| 61 | |
| 62 | If in doubt, say N. |
| 63 | |
| 64 | config ARM_IMX6Q_CPUFREQ |
Shawn Guo | 1d0eaae | 2013-12-20 10:12:16 +0800 | [diff] [blame] | 65 | tristate "Freescale i.MX6 cpufreq support" |
| 66 | depends on ARCH_MXC |
Viresh Kumar | a0ea048 | 2013-04-04 12:54:09 +0000 | [diff] [blame] | 67 | depends on REGULATOR_ANATOP |
Nicolas Del Piano | 7e02168 | 2014-07-13 18:59:00 -0300 | [diff] [blame] | 68 | select PM_OPP |
Viresh Kumar | a0ea048 | 2013-04-04 12:54:09 +0000 | [diff] [blame] | 69 | help |
Shawn Guo | 1d0eaae | 2013-12-20 10:12:16 +0800 | [diff] [blame] | 70 | This adds cpufreq driver support for Freescale i.MX6 series SoCs. |
Viresh Kumar | a0ea048 | 2013-04-04 12:54:09 +0000 | [diff] [blame] | 71 | |
| 72 | If in doubt, say N. |
| 73 | |
| 74 | config ARM_KIRKWOOD_CPUFREQ |
Andrew Lunn | 6c8df11 | 2014-08-30 18:46:12 +0200 | [diff] [blame] | 75 | def_bool MACH_KIRKWOOD |
Viresh Kumar | a0ea048 | 2013-04-04 12:54:09 +0000 | [diff] [blame] | 76 | help |
| 77 | This adds the CPUFreq driver for Marvell Kirkwood |
| 78 | SoCs. |
| 79 | |
Pi-Cheng Chen | 1453863 | 2015-08-19 10:05:06 +0800 | [diff] [blame] | 80 | config ARM_MT8173_CPUFREQ |
Arnd Bergmann | 3c2002a | 2016-02-29 17:04:21 +0100 | [diff] [blame] | 81 | tristate "Mediatek MT8173 CPUFreq support" |
Pi-Cheng Chen | 1453863 | 2015-08-19 10:05:06 +0800 | [diff] [blame] | 82 | depends on ARCH_MEDIATEK && REGULATOR |
Arnd Bergmann | 2d4ee30 | 2015-11-16 22:27:55 +0100 | [diff] [blame] | 83 | depends on ARM64 || (ARM_CPU_TOPOLOGY && COMPILE_TEST) |
Arnd Bergmann | 3c2002a | 2016-02-29 17:04:21 +0100 | [diff] [blame] | 84 | depends on !CPU_THERMAL || THERMAL |
Pi-Cheng Chen | 1453863 | 2015-08-19 10:05:06 +0800 | [diff] [blame] | 85 | select PM_OPP |
| 86 | help |
| 87 | This adds the CPUFreq driver support for Mediatek MT8173 SoC. |
| 88 | |
Russell King | b09db45 | 2012-02-15 11:01:11 -0800 | [diff] [blame] | 89 | config ARM_OMAP2PLUS_CPUFREQ |
| 90 | bool "TI OMAP2+" |
Kevin Hilman | 2d59dcf | 2012-04-13 13:32:30 -0700 | [diff] [blame] | 91 | depends on ARCH_OMAP2PLUS |
Russell King | b09db45 | 2012-02-15 11:01:11 -0800 | [diff] [blame] | 92 | default ARCH_OMAP2PLUS |
Russell King | b09db45 | 2012-02-15 11:01:11 -0800 | [diff] [blame] | 93 | |
Viresh Kumar | f023f8d | 2013-04-04 12:54:15 +0000 | [diff] [blame] | 94 | config ARM_S3C_CPUFREQ |
| 95 | bool |
| 96 | help |
| 97 | Internal configuration node for common cpufreq on Samsung SoC |
| 98 | |
| 99 | config ARM_S3C24XX_CPUFREQ |
| 100 | bool "CPUfreq driver for Samsung S3C24XX series CPUs (EXPERIMENTAL)" |
| 101 | depends on ARCH_S3C24XX |
| 102 | select ARM_S3C_CPUFREQ |
| 103 | help |
| 104 | This enables the CPUfreq driver for the Samsung S3C24XX family |
| 105 | of CPUs. |
| 106 | |
| 107 | For details, take a look at <file:Documentation/cpu-freq>. |
| 108 | |
| 109 | If in doubt, say N. |
| 110 | |
| 111 | config ARM_S3C24XX_CPUFREQ_DEBUG |
| 112 | bool "Debug CPUfreq Samsung driver core" |
| 113 | depends on ARM_S3C24XX_CPUFREQ |
| 114 | help |
| 115 | Enable s3c_freq_dbg for the Samsung S3C CPUfreq core |
| 116 | |
| 117 | config ARM_S3C24XX_CPUFREQ_IODEBUG |
| 118 | bool "Debug CPUfreq Samsung driver IO timing" |
| 119 | depends on ARM_S3C24XX_CPUFREQ |
| 120 | help |
| 121 | Enable s3c_freq_iodbg for the Samsung S3C CPUfreq core |
| 122 | |
| 123 | config ARM_S3C24XX_CPUFREQ_DEBUGFS |
| 124 | bool "Export debugfs for CPUFreq" |
| 125 | depends on ARM_S3C24XX_CPUFREQ && DEBUG_FS |
| 126 | help |
| 127 | Export status information via debugfs. |
| 128 | |
| 129 | config ARM_S3C2410_CPUFREQ |
| 130 | bool |
| 131 | depends on ARM_S3C24XX_CPUFREQ && CPU_S3C2410 |
| 132 | select S3C2410_CPUFREQ_UTILS |
| 133 | help |
| 134 | CPU Frequency scaling support for S3C2410 |
| 135 | |
| 136 | config ARM_S3C2412_CPUFREQ |
| 137 | bool |
| 138 | depends on ARM_S3C24XX_CPUFREQ && CPU_S3C2412 |
| 139 | default y |
| 140 | select S3C2412_IOTIMING |
| 141 | help |
| 142 | CPU Frequency scaling support for S3C2412 and S3C2413 SoC CPUs. |
| 143 | |
Heiko Stübner | 34ee5507 | 2012-02-16 11:42:32 +0100 | [diff] [blame] | 144 | config ARM_S3C2416_CPUFREQ |
| 145 | bool "S3C2416 CPU Frequency scaling support" |
| 146 | depends on CPU_S3C2416 |
| 147 | help |
| 148 | This adds the CPUFreq driver for the Samsung S3C2416 and |
| 149 | S3C2450 SoC. The S3C2416 supports changing the rate of the |
| 150 | armdiv clock source and also entering a so called dynamic |
| 151 | voltage scaling mode in which it is possible to reduce the |
Stratos Karafotis | 735dc24 | 2014-04-22 22:40:10 +0300 | [diff] [blame] | 152 | core voltage of the CPU. |
Heiko Stübner | 34ee5507 | 2012-02-16 11:42:32 +0100 | [diff] [blame] | 153 | |
| 154 | If in doubt, say N. |
| 155 | |
| 156 | config ARM_S3C2416_CPUFREQ_VCORESCALE |
Kees Cook | 0f194b5 | 2012-10-02 11:16:53 -0700 | [diff] [blame] | 157 | bool "Allow voltage scaling for S3C2416 arm core" |
| 158 | depends on ARM_S3C2416_CPUFREQ && REGULATOR |
Heiko Stübner | 34ee5507 | 2012-02-16 11:42:32 +0100 | [diff] [blame] | 159 | help |
| 160 | Enable CPU voltage scaling when entering the dvs mode. |
| 161 | It uses information gathered through existing hardware and |
| 162 | tests but not documented in any datasheet. |
| 163 | |
| 164 | If in doubt, say N. |
| 165 | |
Viresh Kumar | f023f8d | 2013-04-04 12:54:15 +0000 | [diff] [blame] | 166 | config ARM_S3C2440_CPUFREQ |
| 167 | bool "S3C2440/S3C2442 CPU Frequency scaling support" |
| 168 | depends on ARM_S3C24XX_CPUFREQ && (CPU_S3C2440 || CPU_S3C2442) |
| 169 | select S3C2410_CPUFREQ_UTILS |
| 170 | default y |
| 171 | help |
| 172 | CPU Frequency scaling support for S3C2440 and S3C2442 SoC CPUs. |
| 173 | |
Kukjin Kim | 15964d3 | 2011-06-06 18:43:01 -0700 | [diff] [blame] | 174 | config ARM_S3C64XX_CPUFREQ |
| 175 | bool "Samsung S3C64XX" |
| 176 | depends on CPU_S3C6410 |
| 177 | default y |
| 178 | help |
| 179 | This adds the CPUFreq driver for Samsung S3C6410 SoC. |
| 180 | |
| 181 | If in doubt, say N. |
| 182 | |
Kukjin Kim | f7d7707 | 2011-06-01 14:18:22 -0700 | [diff] [blame] | 183 | config ARM_S5PV210_CPUFREQ |
| 184 | bool "Samsung S5PV210 and S5PC110" |
| 185 | depends on CPU_S5PV210 |
| 186 | default y |
| 187 | help |
| 188 | This adds the CPUFreq driver for Samsung S5PV210 and |
| 189 | S5PC110 SoCs. |
| 190 | |
| 191 | If in doubt, say N. |
| 192 | |
Viresh Kumar | 59a2e61 | 2013-04-04 12:54:16 +0000 | [diff] [blame] | 193 | config ARM_SA1100_CPUFREQ |
| 194 | bool |
| 195 | |
| 196 | config ARM_SA1110_CPUFREQ |
| 197 | bool |
| 198 | |
Sudeep Holla | 8def310 | 2015-03-30 10:59:52 +0100 | [diff] [blame] | 199 | config ARM_SCPI_CPUFREQ |
| 200 | tristate "SCPI based CPUfreq driver" |
Punit Agrawal | 73124ce | 2015-11-18 13:52:44 +0000 | [diff] [blame] | 201 | depends on ARM_BIG_LITTLE_CPUFREQ && ARM_SCPI_PROTOCOL && COMMON_CLK_SCPI |
Sudeep Holla | 8def310 | 2015-03-30 10:59:52 +0100 | [diff] [blame] | 202 | help |
| 203 | This adds the CPUfreq driver support for ARM big.LITTLE platforms |
| 204 | using SCPI protocol for CPU power management. |
| 205 | |
| 206 | This driver uses SCPI Message Protocol driver to interact with the |
| 207 | firmware providing the CPU DVFS functionality. |
| 208 | |
Deepak Sikri | 4209932 | 2012-11-27 14:05:26 +0100 | [diff] [blame] | 209 | config ARM_SPEAR_CPUFREQ |
| 210 | bool "SPEAr CPUFreq support" |
| 211 | depends on PLAT_SPEAR |
| 212 | default y |
| 213 | help |
| 214 | This adds the CPUFreq driver support for SPEAr SOCs. |
Viresh Kumar | dbb8d76 | 2013-06-12 12:05:48 +0530 | [diff] [blame] | 215 | |
Lee Jones | ab0ea25 | 2015-12-10 09:42:16 +0000 | [diff] [blame] | 216 | config ARM_STI_CPUFREQ |
| 217 | tristate "STi CPUFreq support" |
| 218 | depends on SOC_STIH407 |
| 219 | help |
| 220 | This driver uses the generic OPP framework to match the running |
| 221 | platform with a predefined set of suitable values. If not provided |
| 222 | we will fall-back so safe-values contained in Device Tree. Enable |
| 223 | this config option if you wish to add CPUFreq support for STi based |
| 224 | SoCs. |
| 225 | |
Tuomas Tynkkynen | 109e13e | 2015-05-13 17:58:47 +0300 | [diff] [blame] | 226 | config ARM_TEGRA20_CPUFREQ |
| 227 | bool "Tegra20 CPUFreq support" |
Viresh Kumar | dbb8d76 | 2013-06-12 12:05:48 +0530 | [diff] [blame] | 228 | depends on ARCH_TEGRA |
Viresh Kumar | dbb8d76 | 2013-06-12 12:05:48 +0530 | [diff] [blame] | 229 | default y |
| 230 | help |
Tuomas Tynkkynen | 109e13e | 2015-05-13 17:58:47 +0300 | [diff] [blame] | 231 | This adds the CPUFreq driver support for Tegra20 SOCs. |
Petr Cvek | 608eab2 | 2014-11-24 04:59:26 +0100 | [diff] [blame] | 232 | |
Tuomas Tynkkynen | 9eb15db | 2015-05-13 17:58:48 +0300 | [diff] [blame] | 233 | config ARM_TEGRA124_CPUFREQ |
| 234 | tristate "Tegra124 CPUFreq support" |
Arnd Bergmann | b5832e4 | 2015-12-08 22:52:45 +0100 | [diff] [blame] | 235 | depends on ARCH_TEGRA && CPUFREQ_DT && REGULATOR |
Tuomas Tynkkynen | 9eb15db | 2015-05-13 17:58:48 +0300 | [diff] [blame] | 236 | default y |
| 237 | help |
| 238 | This adds the CPUFreq driver support for Tegra124 SOCs. |
| 239 | |
Petr Cvek | 608eab2 | 2014-11-24 04:59:26 +0100 | [diff] [blame] | 240 | config ARM_PXA2xx_CPUFREQ |
| 241 | tristate "Intel PXA2xx CPUfreq driver" |
| 242 | depends on PXA27x || PXA25x |
| 243 | help |
| 244 | This add the CPUFreq driver support for Intel PXA2xx SOCs. |
| 245 | |
| 246 | If in doubt, say N. |
Ashwin Chaugule | 5477fb3 | 2015-10-02 10:04:01 -0400 | [diff] [blame] | 247 | |
| 248 | config ACPI_CPPC_CPUFREQ |
| 249 | tristate "CPUFreq driver based on the ACPI CPPC spec" |
| 250 | depends on ACPI |
| 251 | select ACPI_CPPC_LIB |
| 252 | default n |
| 253 | help |
| 254 | This adds a CPUFreq driver which uses CPPC methods |
| 255 | as described in the ACPIv5.1 spec. CPPC stands for |
| 256 | Collaborative Processor Performance Controls. It |
| 257 | is based on an abstract continuous scale of CPU |
| 258 | performance values which allows the remote power |
| 259 | processor to flexibly optimize for power and |
| 260 | performance. CPPC relies on power management firmware |
| 261 | support for its operation. |
| 262 | |
| 263 | If in doubt, say N. |