Thomas Gleixner | ec8f24b | 2019-05-19 13:07:45 +0100 | [diff] [blame] | 1 | # SPDX-License-Identifier: GPL-2.0-only |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 2 | # |
Dave Jones | bb0a56e | 2011-05-19 18:51:07 -0400 | [diff] [blame] | 3 | # x86 CPU Frequency scaling drivers |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 4 | # |
| 5 | |
Dirk Brandewie | 93f0822 | 2013-02-06 09:02:13 -0800 | [diff] [blame] | 6 | config X86_INTEL_PSTATE |
Krzysztof Kozlowski | cde10f8 | 2019-11-21 04:19:15 +0100 | [diff] [blame] | 7 | bool "Intel P state control" |
| 8 | depends on X86 |
| 9 | select ACPI_PROCESSOR if ACPI |
| 10 | select ACPI_CPPC_LIB if X86_64 && ACPI && SCHED_MC_PRIO |
Rafael J. Wysocki | a00ec38 | 2020-03-26 20:24:35 +0100 | [diff] [blame] | 11 | select CPU_FREQ_GOV_PERFORMANCE |
| 12 | select CPU_FREQ_GOV_SCHEDUTIL if SMP |
Krzysztof Kozlowski | cde10f8 | 2019-11-21 04:19:15 +0100 | [diff] [blame] | 13 | help |
| 14 | This driver provides a P state for Intel core processors. |
Dirk Brandewie | 93f0822 | 2013-02-06 09:02:13 -0800 | [diff] [blame] | 15 | The driver implements an internal governor and will become |
Krzysztof Kozlowski | cde10f8 | 2019-11-21 04:19:15 +0100 | [diff] [blame] | 16 | the scaling driver and governor for Sandy bridge processors. |
Dirk Brandewie | 93f0822 | 2013-02-06 09:02:13 -0800 | [diff] [blame] | 17 | |
Stratos Karafotis | 735dc24 | 2014-04-22 22:40:10 +0300 | [diff] [blame] | 18 | When this driver is enabled it will become the preferred |
Krzysztof Kozlowski | cde10f8 | 2019-11-21 04:19:15 +0100 | [diff] [blame] | 19 | scaling driver for Sandy bridge processors. |
Dirk Brandewie | 93f0822 | 2013-02-06 09:02:13 -0800 | [diff] [blame] | 20 | |
Dirk Brandewie | 93f0822 | 2013-02-06 09:02:13 -0800 | [diff] [blame] | 21 | If in doubt, say N. |
| 22 | |
Naga Chumbalkar | 0f1d683 | 2009-12-17 20:18:27 +0000 | [diff] [blame] | 23 | config X86_PCC_CPUFREQ |
| 24 | tristate "Processor Clocking Control interface driver" |
| 25 | depends on ACPI && ACPI_PROCESSOR |
| 26 | help |
| 27 | This driver adds support for the PCC interface. |
| 28 | |
| 29 | For details, take a look at: |
Mauro Carvalho Chehab | c3419b7 | 2020-03-03 14:52:02 +0100 | [diff] [blame] | 30 | <file:Documentation/admin-guide/pm/cpufreq_drivers.rst>. |
Naga Chumbalkar | 0f1d683 | 2009-12-17 20:18:27 +0000 | [diff] [blame] | 31 | |
| 32 | To compile this driver as a module, choose M here: the |
| 33 | module will be called pcc-cpufreq. |
| 34 | |
| 35 | If in doubt, say N. |
| 36 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 37 | config X86_ACPI_CPUFREQ |
| 38 | tristate "ACPI Processor P-States driver" |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 39 | depends on ACPI_PROCESSOR |
| 40 | help |
| 41 | This driver adds a CPUFreq driver which utilizes the ACPI |
| 42 | Processor Performance States. |
Matthew Garrett | 3dc9a633 | 2012-09-04 08:28:02 +0000 | [diff] [blame] | 43 | This driver also supports Intel Enhanced Speedstep and newer |
| 44 | AMD CPUs. |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 45 | |
Sam Ravnborg | e8ef952 | 2007-11-06 19:35:19 +0100 | [diff] [blame] | 46 | To compile this driver as a module, choose M here: the |
| 47 | module will be called acpi-cpufreq. |
| 48 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 49 | For details, take a look at <file:Documentation/cpu-freq/>. |
| 50 | |
| 51 | If in doubt, say N. |
| 52 | |
Andre Przywara | 11269ff | 2012-09-04 08:28:08 +0000 | [diff] [blame] | 53 | config X86_ACPI_CPUFREQ_CPB |
| 54 | default y |
| 55 | bool "Legacy cpb sysfs knob support for AMD CPUs" |
| 56 | depends on X86_ACPI_CPUFREQ && CPU_SUP_AMD |
| 57 | help |
| 58 | The powernow-k8 driver used to provide a sysfs knob called "cpb" |
| 59 | to disable the Core Performance Boosting feature of AMD CPUs. This |
Stratos Karafotis | 735dc24 | 2014-04-22 22:40:10 +0300 | [diff] [blame] | 60 | file has now been superseded by the more generic "boost" entry. |
Andre Przywara | 11269ff | 2012-09-04 08:28:08 +0000 | [diff] [blame] | 61 | |
| 62 | By enabling this option the acpi_cpufreq driver provides the old |
| 63 | entry in addition to the new boost ones, for compatibility reasons. |
| 64 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 65 | config ELAN_CPUFREQ |
Dave Jones | bf6fc9f | 2005-05-31 19:03:45 -0700 | [diff] [blame] | 66 | tristate "AMD Elan SC400 and SC410" |
Ian Campbell | ce9c99a | 2011-04-08 07:42:29 +0100 | [diff] [blame] | 67 | depends on MELAN |
Masahiro Yamada | a7f7f62 | 2020-06-14 01:50:22 +0900 | [diff] [blame] | 68 | help |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 69 | This adds the CPUFreq driver for AMD Elan SC400 and SC410 |
| 70 | processors. |
| 71 | |
| 72 | You need to specify the processor maximum speed as boot |
| 73 | parameter: elanfreq=maxspeed (in kHz) or as module |
| 74 | parameter "max_freq". |
| 75 | |
| 76 | For details, take a look at <file:Documentation/cpu-freq/>. |
| 77 | |
| 78 | If in doubt, say N. |
| 79 | |
Dave Jones | bf6fc9f | 2005-05-31 19:03:45 -0700 | [diff] [blame] | 80 | config SC520_CPUFREQ |
| 81 | tristate "AMD Elan SC520" |
Ian Campbell | ce9c99a | 2011-04-08 07:42:29 +0100 | [diff] [blame] | 82 | depends on MELAN |
Masahiro Yamada | a7f7f62 | 2020-06-14 01:50:22 +0900 | [diff] [blame] | 83 | help |
Dave Jones | bf6fc9f | 2005-05-31 19:03:45 -0700 | [diff] [blame] | 84 | This adds the CPUFreq driver for AMD Elan SC520 processor. |
| 85 | |
| 86 | For details, take a look at <file:Documentation/cpu-freq/>. |
| 87 | |
| 88 | If in doubt, say N. |
| 89 | |
| 90 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 91 | config X86_POWERNOW_K6 |
| 92 | tristate "AMD Mobile K6-2/K6-3 PowerNow!" |
Sam Ravnborg | e8ef952 | 2007-11-06 19:35:19 +0100 | [diff] [blame] | 93 | depends on X86_32 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 94 | help |
| 95 | This adds the CPUFreq driver for mobile AMD K6-2+ and mobile |
| 96 | AMD K6-3+ processors. |
| 97 | |
| 98 | For details, take a look at <file:Documentation/cpu-freq/>. |
| 99 | |
| 100 | If in doubt, say N. |
| 101 | |
| 102 | config X86_POWERNOW_K7 |
| 103 | tristate "AMD Mobile Athlon/Duron PowerNow!" |
Sam Ravnborg | e8ef952 | 2007-11-06 19:35:19 +0100 | [diff] [blame] | 104 | depends on X86_32 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 105 | help |
| 106 | This adds the CPUFreq driver for mobile AMD K7 mobile processors. |
| 107 | |
| 108 | For details, take a look at <file:Documentation/cpu-freq/>. |
| 109 | |
| 110 | If in doubt, say N. |
| 111 | |
| 112 | config X86_POWERNOW_K7_ACPI |
| 113 | bool |
| 114 | depends on X86_POWERNOW_K7 && ACPI_PROCESSOR |
| 115 | depends on !(X86_POWERNOW_K7 = y && ACPI_PROCESSOR = m) |
Sam Ravnborg | e8ef952 | 2007-11-06 19:35:19 +0100 | [diff] [blame] | 116 | depends on X86_32 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 117 | default y |
| 118 | |
| 119 | config X86_POWERNOW_K8 |
| 120 | tristate "AMD Opteron/Athlon64 PowerNow!" |
Borislav Petkov | 631e8ac | 2013-01-18 00:19:37 +0100 | [diff] [blame] | 121 | depends on ACPI && ACPI_PROCESSOR && X86_ACPI_CPUFREQ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 122 | help |
Andre Przywara | 034be8f | 2012-09-04 08:28:04 +0000 | [diff] [blame] | 123 | This adds the CPUFreq driver for K8/early Opteron/Athlon64 processors. |
| 124 | Support for K10 and newer processors is now in acpi-cpufreq. |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 125 | |
Sam Ravnborg | e8ef952 | 2007-11-06 19:35:19 +0100 | [diff] [blame] | 126 | To compile this driver as a module, choose M here: the |
| 127 | module will be called powernow-k8. |
| 128 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 129 | For details, take a look at <file:Documentation/cpu-freq/>. |
| 130 | |
Jacob Shin | 9c5320c | 2013-04-04 16:19:04 +0000 | [diff] [blame] | 131 | config X86_AMD_FREQ_SENSITIVITY |
| 132 | tristate "AMD frequency sensitivity feedback powersave bias" |
| 133 | depends on CPU_FREQ_GOV_ONDEMAND && X86_ACPI_CPUFREQ && CPU_SUP_AMD |
| 134 | help |
| 135 | This adds AMD-specific powersave bias function to the ondemand |
| 136 | governor, which allows it to make more power-conscious frequency |
Masanari Iida | 8c88126 | 2013-09-29 20:54:15 +0900 | [diff] [blame] | 137 | change decisions based on feedback from hardware (available on AMD |
Jacob Shin | 9c5320c | 2013-04-04 16:19:04 +0000 | [diff] [blame] | 138 | Family 16h and above). |
| 139 | |
| 140 | Hardware feedback tells software how "sensitive" to frequency changes |
| 141 | the CPUs' workloads are. CPU-bound workloads will be more sensitive |
| 142 | -- they will perform better as frequency increases. Memory/IO-bound |
| 143 | workloads will be less sensitive -- they will not necessarily perform |
| 144 | better as frequency increases. |
| 145 | |
| 146 | If in doubt, say N. |
| 147 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 148 | config X86_GX_SUSPMOD |
| 149 | tristate "Cyrix MediaGX/NatSemi Geode Suspend Modulation" |
Sam Ravnborg | e8ef952 | 2007-11-06 19:35:19 +0100 | [diff] [blame] | 150 | depends on X86_32 && PCI |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 151 | help |
| 152 | This add the CPUFreq driver for NatSemi Geode processors which |
| 153 | support suspend modulation. |
| 154 | |
| 155 | For details, take a look at <file:Documentation/cpu-freq/>. |
| 156 | |
| 157 | If in doubt, say N. |
| 158 | |
| 159 | config X86_SPEEDSTEP_CENTRINO |
Sam Ravnborg | e8ef952 | 2007-11-06 19:35:19 +0100 | [diff] [blame] | 160 | tristate "Intel Enhanced SpeedStep (deprecated)" |
Sam Ravnborg | e8ef952 | 2007-11-06 19:35:19 +0100 | [diff] [blame] | 161 | select X86_SPEEDSTEP_CENTRINO_TABLE if X86_32 |
| 162 | depends on X86_32 || (X86_64 && ACPI_PROCESSOR) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 163 | help |
Sam Ravnborg | e8ef952 | 2007-11-06 19:35:19 +0100 | [diff] [blame] | 164 | This is deprecated and this functionality is now merged into |
| 165 | acpi_cpufreq (X86_ACPI_CPUFREQ). Use that driver instead of |
| 166 | speedstep_centrino. |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 167 | This adds the CPUFreq driver for Enhanced SpeedStep enabled |
Sam Ravnborg | e8ef952 | 2007-11-06 19:35:19 +0100 | [diff] [blame] | 168 | mobile CPUs. This means Intel Pentium M (Centrino) CPUs |
| 169 | or 64bit enabled Intel Xeons. |
| 170 | |
| 171 | To compile this driver as a module, choose M here: the |
| 172 | module will be called speedstep-centrino. |
Dave Jones | 388d6c5 | 2006-03-11 16:04:53 -0500 | [diff] [blame] | 173 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 174 | For details, take a look at <file:Documentation/cpu-freq/>. |
Dave Jones | 388d6c5 | 2006-03-11 16:04:53 -0500 | [diff] [blame] | 175 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 176 | If in doubt, say N. |
| 177 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 178 | config X86_SPEEDSTEP_CENTRINO_TABLE |
| 179 | bool "Built-in tables for Banias CPUs" |
Sam Ravnborg | e8ef952 | 2007-11-06 19:35:19 +0100 | [diff] [blame] | 180 | depends on X86_32 && X86_SPEEDSTEP_CENTRINO |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 181 | default y |
| 182 | help |
| 183 | Use built-in tables for Banias CPUs if ACPI encoding |
| 184 | is not available. |
| 185 | |
| 186 | If in doubt, say N. |
| 187 | |
| 188 | config X86_SPEEDSTEP_ICH |
| 189 | tristate "Intel Speedstep on ICH-M chipsets (ioport interface)" |
Sam Ravnborg | e8ef952 | 2007-11-06 19:35:19 +0100 | [diff] [blame] | 190 | depends on X86_32 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 191 | help |
| 192 | This adds the CPUFreq driver for certain mobile Intel Pentium III |
| 193 | (Coppermine), all mobile Intel Pentium III-M (Tualatin) and all |
Dave Jones | 388d6c5 | 2006-03-11 16:04:53 -0500 | [diff] [blame] | 194 | mobile Intel Pentium 4 P4-M on systems which have an Intel ICH2, |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 195 | ICH3 or ICH4 southbridge. |
| 196 | |
| 197 | For details, take a look at <file:Documentation/cpu-freq/>. |
| 198 | |
| 199 | If in doubt, say N. |
| 200 | |
| 201 | config X86_SPEEDSTEP_SMI |
| 202 | tristate "Intel SpeedStep on 440BX/ZX/MX chipsets (SMI interface)" |
Kees Cook | 0f194b56 | 2012-10-02 11:16:53 -0700 | [diff] [blame] | 203 | depends on X86_32 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 204 | help |
| 205 | This adds the CPUFreq driver for certain mobile Intel Pentium III |
Dave Jones | 388d6c5 | 2006-03-11 16:04:53 -0500 | [diff] [blame] | 206 | (Coppermine), all mobile Intel Pentium III-M (Tualatin) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 207 | on systems which have an Intel 440BX/ZX/MX southbridge. |
| 208 | |
| 209 | For details, take a look at <file:Documentation/cpu-freq/>. |
| 210 | |
| 211 | If in doubt, say N. |
| 212 | |
| 213 | config X86_P4_CLOCKMOD |
| 214 | tristate "Intel Pentium 4 clock modulation" |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 215 | help |
| 216 | This adds the CPUFreq driver for Intel Pentium 4 / XEON |
Sam Ravnborg | e8ef952 | 2007-11-06 19:35:19 +0100 | [diff] [blame] | 217 | processors. When enabled it will lower CPU temperature by skipping |
| 218 | clocks. |
| 219 | |
| 220 | This driver should be only used in exceptional |
| 221 | circumstances when very low power is needed because it causes severe |
| 222 | slowdowns and noticeable latencies. Normally Speedstep should be used |
| 223 | instead. |
| 224 | |
| 225 | To compile this driver as a module, choose M here: the |
| 226 | module will be called p4-clockmod. |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 227 | |
| 228 | For details, take a look at <file:Documentation/cpu-freq/>. |
| 229 | |
Sam Ravnborg | e8ef952 | 2007-11-06 19:35:19 +0100 | [diff] [blame] | 230 | Unless you are absolutely sure say N. |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 231 | |
| 232 | config X86_CPUFREQ_NFORCE2 |
| 233 | tristate "nVidia nForce2 FSB changing" |
Kees Cook | 0f194b56 | 2012-10-02 11:16:53 -0700 | [diff] [blame] | 234 | depends on X86_32 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 235 | help |
| 236 | This adds the CPUFreq driver for FSB changing on nVidia nForce2 |
| 237 | platforms. |
| 238 | |
| 239 | For details, take a look at <file:Documentation/cpu-freq/>. |
| 240 | |
| 241 | If in doubt, say N. |
| 242 | |
| 243 | config X86_LONGRUN |
| 244 | tristate "Transmeta LongRun" |
Sam Ravnborg | e8ef952 | 2007-11-06 19:35:19 +0100 | [diff] [blame] | 245 | depends on X86_32 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 246 | help |
| 247 | This adds the CPUFreq driver for Transmeta Crusoe and Efficeon processors |
| 248 | which support LongRun. |
| 249 | |
| 250 | For details, take a look at <file:Documentation/cpu-freq/>. |
| 251 | |
| 252 | If in doubt, say N. |
| 253 | |
| 254 | config X86_LONGHAUL |
| 255 | tristate "VIA Cyrix III Longhaul" |
Sam Ravnborg | e8ef952 | 2007-11-06 19:35:19 +0100 | [diff] [blame] | 256 | depends on X86_32 && ACPI_PROCESSOR |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 257 | help |
Dave Jones | 388d6c5 | 2006-03-11 16:04:53 -0500 | [diff] [blame] | 258 | This adds the CPUFreq driver for VIA Samuel/CyrixIII, |
| 259 | VIA Cyrix Samuel/C3, VIA Cyrix Ezra and VIA Cyrix Ezra-T |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 260 | processors. |
| 261 | |
| 262 | For details, take a look at <file:Documentation/cpu-freq/>. |
| 263 | |
| 264 | If in doubt, say N. |
| 265 | |
Rafa³ Bilski | 86acd49 | 2007-02-05 19:57:25 +0100 | [diff] [blame] | 266 | config X86_E_POWERSAVER |
Harald Welte | 0fea615 | 2009-06-08 18:29:36 +0800 | [diff] [blame] | 267 | tristate "VIA C7 Enhanced PowerSaver (DANGEROUS)" |
Rafał Bilski | b5f1472 | 2013-05-19 19:27:55 +0000 | [diff] [blame] | 268 | depends on X86_32 && ACPI_PROCESSOR |
Rafa³ Bilski | 86acd49 | 2007-02-05 19:57:25 +0100 | [diff] [blame] | 269 | help |
Harald Welte | 0fea615 | 2009-06-08 18:29:36 +0800 | [diff] [blame] | 270 | This adds the CPUFreq driver for VIA C7 processors. However, this driver |
| 271 | does not have any safeguards to prevent operating the CPU out of spec |
| 272 | and is thus considered dangerous. Please use the regular ACPI cpufreq |
| 273 | driver, enabled by CONFIG_X86_ACPI_CPUFREQ. |
Rafa³ Bilski | 86acd49 | 2007-02-05 19:57:25 +0100 | [diff] [blame] | 274 | |
| 275 | If in doubt, say N. |
| 276 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 277 | comment "shared options" |
| 278 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 279 | config X86_SPEEDSTEP_LIB |
| 280 | tristate |
Sam Ravnborg | e8ef952 | 2007-11-06 19:35:19 +0100 | [diff] [blame] | 281 | default (X86_SPEEDSTEP_ICH || X86_SPEEDSTEP_SMI || X86_P4_CLOCKMOD) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 282 | |
| 283 | config X86_SPEEDSTEP_RELAXED_CAP_CHECK |
| 284 | bool "Relaxed speedstep capability checks" |
Sam Ravnborg | e8ef952 | 2007-11-06 19:35:19 +0100 | [diff] [blame] | 285 | depends on X86_32 && (X86_SPEEDSTEP_SMI || X86_SPEEDSTEP_ICH) |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 286 | help |
Dave Jones | 388d6c5 | 2006-03-11 16:04:53 -0500 | [diff] [blame] | 287 | Don't perform all checks for a speedstep capable system which would |
| 288 | normally be done. Some ancient or strange systems, though speedstep |
| 289 | capable, don't always indicate that they are speedstep capable. This |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 290 | option lets the probing code bypass some of those checks if the |
| 291 | parameter "relaxed_check=1" is passed to the module. |
| 292 | |