Kconfig.arm 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299
  1. #
  2. # ARM CPU Frequency scaling drivers
  3. #
  4. # big LITTLE core layer and glue drivers
  5. config ARM_BIG_LITTLE_CPUFREQ
  6. tristate "Generic ARM big LITTLE CPUfreq driver"
  7. depends on (ARM_CPU_TOPOLOGY || ARM64) && HAVE_CLK
  8. # if CPU_THERMAL is on and THERMAL=m, ARM_BIT_LITTLE_CPUFREQ cannot be =y
  9. depends on !CPU_THERMAL || THERMAL
  10. select PM_OPP
  11. help
  12. This enables the Generic CPUfreq driver for ARM big.LITTLE platforms.
  13. config ARM_BRCMSTB_AVS_CPUFREQ
  14. tristate "Broadcom STB AVS CPUfreq driver"
  15. depends on ARCH_BRCMSTB || COMPILE_TEST
  16. default y
  17. help
  18. Some Broadcom STB SoCs use a co-processor running proprietary firmware
  19. ("AVS") to handle voltage and frequency scaling. This driver provides
  20. a standard CPUfreq interface to to the firmware.
  21. Say Y, if you have a Broadcom SoC with AVS support for DFS or DVFS.
  22. config ARM_BRCMSTB_AVS_CPUFREQ_DEBUG
  23. bool "Broadcom STB AVS CPUfreq driver sysfs debug capability"
  24. depends on ARM_BRCMSTB_AVS_CPUFREQ
  25. help
  26. Enabling this option turns on debug support via sysfs under
  27. /sys/kernel/debug/brcmstb-avs-cpufreq. It is possible to read all and
  28. write some AVS mailbox registers through sysfs entries.
  29. If in doubt, say N.
  30. config ARM_DT_BL_CPUFREQ
  31. tristate "Generic probing via DT for ARM big LITTLE CPUfreq driver"
  32. depends on ARM_BIG_LITTLE_CPUFREQ && OF
  33. help
  34. This enables probing via DT for Generic CPUfreq driver for ARM
  35. big.LITTLE platform. This gets frequency tables from DT.
  36. config ARM_VEXPRESS_SPC_CPUFREQ
  37. tristate "Versatile Express SPC based CPUfreq driver"
  38. depends on ARM_BIG_LITTLE_CPUFREQ && ARCH_VEXPRESS_SPC
  39. help
  40. This add the CPUfreq driver support for Versatile Express
  41. big.LITTLE platforms using SPC for power management.
  42. config ARM_EXYNOS5440_CPUFREQ
  43. tristate "SAMSUNG EXYNOS5440"
  44. depends on SOC_EXYNOS5440
  45. depends on HAVE_CLK && OF
  46. select PM_OPP
  47. default y
  48. help
  49. This adds the CPUFreq driver for Samsung EXYNOS5440
  50. SoC. The nature of exynos5440 clock controller is
  51. different than previous exynos controllers so not using
  52. the common exynos framework.
  53. If in doubt, say N.
  54. config ARM_HIGHBANK_CPUFREQ
  55. tristate "Calxeda Highbank-based"
  56. depends on ARCH_HIGHBANK && CPUFREQ_DT && REGULATOR
  57. default m
  58. help
  59. This adds the CPUFreq driver for Calxeda Highbank SoC
  60. based boards.
  61. If in doubt, say N.
  62. config ARM_DB8500_CPUFREQ
  63. tristate "ST-Ericsson DB8500 cpufreq" if COMPILE_TEST && !ARCH_U8500
  64. default ARCH_U8500
  65. depends on HAS_IOMEM
  66. depends on !CPU_THERMAL || THERMAL
  67. help
  68. This adds the CPUFreq driver for ST-Ericsson Ux500 (DB8500) SoC
  69. series.
  70. config ARM_IMX6Q_CPUFREQ
  71. tristate "Freescale i.MX6 cpufreq support"
  72. depends on ARCH_MXC
  73. depends on REGULATOR_ANATOP
  74. select PM_OPP
  75. help
  76. This adds cpufreq driver support for Freescale i.MX6 series SoCs.
  77. If in doubt, say N.
  78. config ARM_KIRKWOOD_CPUFREQ
  79. def_bool MACH_KIRKWOOD
  80. help
  81. This adds the CPUFreq driver for Marvell Kirkwood
  82. SoCs.
  83. config ARM_MT8173_CPUFREQ
  84. tristate "Mediatek MT8173 CPUFreq support"
  85. depends on ARCH_MEDIATEK && REGULATOR
  86. depends on ARM64 || (ARM_CPU_TOPOLOGY && COMPILE_TEST)
  87. depends on !CPU_THERMAL || THERMAL
  88. select PM_OPP
  89. help
  90. This adds the CPUFreq driver support for Mediatek MT8173 SoC.
  91. config ARM_OMAP2PLUS_CPUFREQ
  92. bool "TI OMAP2+"
  93. depends on ARCH_OMAP2PLUS
  94. default ARCH_OMAP2PLUS
  95. config ARM_S3C_CPUFREQ
  96. bool
  97. help
  98. Internal configuration node for common cpufreq on Samsung SoC
  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. For details, take a look at <file:Documentation/cpu-freq>.
  107. If in doubt, say N.
  108. config ARM_S3C24XX_CPUFREQ_DEBUG
  109. bool "Debug CPUfreq Samsung driver core"
  110. depends on ARM_S3C24XX_CPUFREQ
  111. help
  112. Enable s3c_freq_dbg for the Samsung S3C CPUfreq core
  113. config ARM_S3C24XX_CPUFREQ_IODEBUG
  114. bool "Debug CPUfreq Samsung driver IO timing"
  115. depends on ARM_S3C24XX_CPUFREQ
  116. help
  117. Enable s3c_freq_iodbg for the Samsung S3C CPUfreq core
  118. config ARM_S3C24XX_CPUFREQ_DEBUGFS
  119. bool "Export debugfs for CPUFreq"
  120. depends on ARM_S3C24XX_CPUFREQ && DEBUG_FS
  121. help
  122. Export status information via debugfs.
  123. config ARM_S3C2410_CPUFREQ
  124. bool
  125. depends on ARM_S3C24XX_CPUFREQ && CPU_S3C2410
  126. select S3C2410_CPUFREQ_UTILS
  127. help
  128. CPU Frequency scaling support for S3C2410
  129. config ARM_S3C2412_CPUFREQ
  130. bool
  131. depends on ARM_S3C24XX_CPUFREQ && CPU_S3C2412
  132. default y
  133. select S3C2412_IOTIMING
  134. help
  135. CPU Frequency scaling support for S3C2412 and S3C2413 SoC CPUs.
  136. config ARM_S3C2416_CPUFREQ
  137. bool "S3C2416 CPU Frequency scaling support"
  138. depends on CPU_S3C2416
  139. help
  140. This adds the CPUFreq driver for the Samsung S3C2416 and
  141. S3C2450 SoC. The S3C2416 supports changing the rate of the
  142. armdiv clock source and also entering a so called dynamic
  143. voltage scaling mode in which it is possible to reduce the
  144. core voltage of the CPU.
  145. If in doubt, say N.
  146. config ARM_S3C2416_CPUFREQ_VCORESCALE
  147. bool "Allow voltage scaling for S3C2416 arm core"
  148. depends on ARM_S3C2416_CPUFREQ && REGULATOR
  149. help
  150. Enable CPU voltage scaling when entering the dvs mode.
  151. It uses information gathered through existing hardware and
  152. tests but not documented in any datasheet.
  153. If in doubt, say N.
  154. config ARM_S3C2440_CPUFREQ
  155. bool "S3C2440/S3C2442 CPU Frequency scaling support"
  156. depends on ARM_S3C24XX_CPUFREQ && (CPU_S3C2440 || CPU_S3C2442)
  157. select S3C2410_CPUFREQ_UTILS
  158. default y
  159. help
  160. CPU Frequency scaling support for S3C2440 and S3C2442 SoC CPUs.
  161. config ARM_S3C64XX_CPUFREQ
  162. bool "Samsung S3C64XX"
  163. depends on CPU_S3C6410
  164. default y
  165. help
  166. This adds the CPUFreq driver for Samsung S3C6410 SoC.
  167. If in doubt, say N.
  168. config ARM_S5PV210_CPUFREQ
  169. bool "Samsung S5PV210 and S5PC110"
  170. depends on CPU_S5PV210
  171. default y
  172. help
  173. This adds the CPUFreq driver for Samsung S5PV210 and
  174. S5PC110 SoCs.
  175. If in doubt, say N.
  176. config ARM_SA1100_CPUFREQ
  177. bool
  178. config ARM_SA1110_CPUFREQ
  179. bool
  180. config ARM_SCPI_CPUFREQ
  181. tristate "SCPI based CPUfreq driver"
  182. depends on ARM_BIG_LITTLE_CPUFREQ && ARM_SCPI_PROTOCOL && COMMON_CLK_SCPI
  183. help
  184. This adds the CPUfreq driver support for ARM big.LITTLE platforms
  185. using SCPI protocol for CPU power management.
  186. This driver uses SCPI Message Protocol driver to interact with the
  187. firmware providing the CPU DVFS functionality.
  188. config ARM_SPEAR_CPUFREQ
  189. bool "SPEAr CPUFreq support"
  190. depends on PLAT_SPEAR
  191. default y
  192. help
  193. This adds the CPUFreq driver support for SPEAr SOCs.
  194. config ARM_STI_CPUFREQ
  195. tristate "STi CPUFreq support"
  196. depends on SOC_STIH407
  197. help
  198. This driver uses the generic OPP framework to match the running
  199. platform with a predefined set of suitable values. If not provided
  200. we will fall-back so safe-values contained in Device Tree. Enable
  201. this config option if you wish to add CPUFreq support for STi based
  202. SoCs.
  203. config ARM_TEGRA20_CPUFREQ
  204. bool "Tegra20 CPUFreq support"
  205. depends on ARCH_TEGRA
  206. default y
  207. help
  208. This adds the CPUFreq driver support for Tegra20 SOCs.
  209. config ARM_TEGRA124_CPUFREQ
  210. tristate "Tegra124 CPUFreq support"
  211. depends on ARCH_TEGRA && CPUFREQ_DT && REGULATOR
  212. default y
  213. help
  214. This adds the CPUFreq driver support for Tegra124 SOCs.
  215. config ARM_TEGRA186_CPUFREQ
  216. tristate "Tegra186 CPUFreq support"
  217. depends on ARCH_TEGRA && TEGRA_BPMP
  218. help
  219. This adds the CPUFreq driver support for Tegra186 SOCs.
  220. config ARM_TI_CPUFREQ
  221. bool "Texas Instruments CPUFreq support"
  222. depends on ARCH_OMAP2PLUS
  223. help
  224. This driver enables valid OPPs on the running platform based on
  225. values contained within the SoC in use. Enable this in order to
  226. use the cpufreq-dt driver on all Texas Instruments platforms that
  227. provide dt based operating-points-v2 tables with opp-supported-hw
  228. data provided. Required for cpufreq support on AM335x, AM437x,
  229. DRA7x, and AM57x platforms.
  230. config ARM_PXA2xx_CPUFREQ
  231. tristate "Intel PXA2xx CPUfreq driver"
  232. depends on PXA27x || PXA25x
  233. help
  234. This add the CPUFreq driver support for Intel PXA2xx SOCs.
  235. If in doubt, say N.
  236. config ACPI_CPPC_CPUFREQ
  237. tristate "CPUFreq driver based on the ACPI CPPC spec"
  238. depends on ACPI_PROCESSOR
  239. select ACPI_CPPC_LIB
  240. default n
  241. help
  242. This adds a CPUFreq driver which uses CPPC methods
  243. as described in the ACPIv5.1 spec. CPPC stands for
  244. Collaborative Processor Performance Controls. It
  245. is based on an abstract continuous scale of CPU
  246. performance values which allows the remote power
  247. processor to flexibly optimize for power and
  248. performance. CPPC relies on power management firmware
  249. support for its operation.
  250. If in doubt, say N.