processor_driver.c 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /*
  3. * processor_driver.c - ACPI Processor Driver
  4. *
  5. * Copyright (C) 2001, 2002 Andy Grover <[email protected]>
  6. * Copyright (C) 2001, 2002 Paul Diefenbaugh <[email protected]>
  7. * Copyright (C) 2004 Dominik Brodowski <[email protected]>
  8. * Copyright (C) 2004 Anil S Keshavamurthy <[email protected]>
  9. * - Added processor hotplug support
  10. * Copyright (C) 2013, Intel Corporation
  11. * Rafael J. Wysocki <[email protected]>
  12. */
  13. #include <linux/kernel.h>
  14. #include <linux/module.h>
  15. #include <linux/init.h>
  16. #include <linux/cpufreq.h>
  17. #include <linux/cpu.h>
  18. #include <linux/cpuidle.h>
  19. #include <linux/slab.h>
  20. #include <linux/acpi.h>
  21. #include <acpi/processor.h>
  22. #include "internal.h"
  23. #define ACPI_PROCESSOR_NOTIFY_PERFORMANCE 0x80
  24. #define ACPI_PROCESSOR_NOTIFY_POWER 0x81
  25. #define ACPI_PROCESSOR_NOTIFY_THROTTLING 0x82
  26. MODULE_AUTHOR("Paul Diefenbaugh");
  27. MODULE_DESCRIPTION("ACPI Processor Driver");
  28. MODULE_LICENSE("GPL");
  29. static int acpi_processor_start(struct device *dev);
  30. static int acpi_processor_stop(struct device *dev);
  31. static const struct acpi_device_id processor_device_ids[] = {
  32. {ACPI_PROCESSOR_OBJECT_HID, 0},
  33. {ACPI_PROCESSOR_DEVICE_HID, 0},
  34. {"", 0},
  35. };
  36. MODULE_DEVICE_TABLE(acpi, processor_device_ids);
  37. static struct device_driver acpi_processor_driver = {
  38. .name = "processor",
  39. .bus = &cpu_subsys,
  40. .acpi_match_table = processor_device_ids,
  41. .probe = acpi_processor_start,
  42. .remove = acpi_processor_stop,
  43. };
  44. static void acpi_processor_notify(acpi_handle handle, u32 event, void *data)
  45. {
  46. struct acpi_device *device = data;
  47. struct acpi_processor *pr;
  48. int saved;
  49. if (device->handle != handle)
  50. return;
  51. pr = acpi_driver_data(device);
  52. if (!pr)
  53. return;
  54. switch (event) {
  55. case ACPI_PROCESSOR_NOTIFY_PERFORMANCE:
  56. saved = pr->performance_platform_limit;
  57. acpi_processor_ppc_has_changed(pr, 1);
  58. if (saved == pr->performance_platform_limit)
  59. break;
  60. acpi_bus_generate_netlink_event(device->pnp.device_class,
  61. dev_name(&device->dev), event,
  62. pr->performance_platform_limit);
  63. break;
  64. case ACPI_PROCESSOR_NOTIFY_POWER:
  65. acpi_processor_power_state_has_changed(pr);
  66. acpi_bus_generate_netlink_event(device->pnp.device_class,
  67. dev_name(&device->dev), event, 0);
  68. break;
  69. case ACPI_PROCESSOR_NOTIFY_THROTTLING:
  70. acpi_processor_tstate_has_changed(pr);
  71. acpi_bus_generate_netlink_event(device->pnp.device_class,
  72. dev_name(&device->dev), event, 0);
  73. break;
  74. default:
  75. acpi_handle_debug(handle, "Unsupported event [0x%x]\n", event);
  76. break;
  77. }
  78. return;
  79. }
  80. static int __acpi_processor_start(struct acpi_device *device);
  81. static int acpi_soft_cpu_online(unsigned int cpu)
  82. {
  83. struct acpi_processor *pr = per_cpu(processors, cpu);
  84. struct acpi_device *device;
  85. if (!pr)
  86. return 0;
  87. device = acpi_fetch_acpi_dev(pr->handle);
  88. if (!device)
  89. return 0;
  90. /*
  91. * CPU got physically hotplugged and onlined for the first time:
  92. * Initialize missing things.
  93. */
  94. if (pr->flags.need_hotplug_init) {
  95. int ret;
  96. pr_info("Will online and init hotplugged CPU: %d\n",
  97. pr->id);
  98. pr->flags.need_hotplug_init = 0;
  99. ret = __acpi_processor_start(device);
  100. WARN(ret, "Failed to start CPU: %d\n", pr->id);
  101. } else {
  102. /* Normal CPU soft online event. */
  103. acpi_processor_ppc_has_changed(pr, 0);
  104. acpi_processor_hotplug(pr);
  105. acpi_processor_reevaluate_tstate(pr, false);
  106. acpi_processor_tstate_has_changed(pr);
  107. }
  108. return 0;
  109. }
  110. static int acpi_soft_cpu_dead(unsigned int cpu)
  111. {
  112. struct acpi_processor *pr = per_cpu(processors, cpu);
  113. if (!pr || !acpi_fetch_acpi_dev(pr->handle))
  114. return 0;
  115. acpi_processor_reevaluate_tstate(pr, true);
  116. return 0;
  117. }
  118. #ifdef CONFIG_ACPI_CPU_FREQ_PSS
  119. static void acpi_pss_perf_init(struct acpi_processor *pr)
  120. {
  121. acpi_processor_ppc_has_changed(pr, 0);
  122. acpi_processor_get_throttling_info(pr);
  123. if (pr->flags.throttling)
  124. pr->flags.limit = 1;
  125. }
  126. #else
  127. static inline void acpi_pss_perf_init(struct acpi_processor *pr) {}
  128. #endif /* CONFIG_ACPI_CPU_FREQ_PSS */
  129. static int __acpi_processor_start(struct acpi_device *device)
  130. {
  131. struct acpi_processor *pr = acpi_driver_data(device);
  132. acpi_status status;
  133. int result = 0;
  134. if (!pr)
  135. return -ENODEV;
  136. if (pr->flags.need_hotplug_init)
  137. return 0;
  138. result = acpi_cppc_processor_probe(pr);
  139. if (result && !IS_ENABLED(CONFIG_ACPI_CPU_FREQ_PSS))
  140. dev_dbg(&device->dev, "CPPC data invalid or not present\n");
  141. if (!cpuidle_get_driver() || cpuidle_get_driver() == &acpi_idle_driver)
  142. acpi_processor_power_init(pr);
  143. acpi_pss_perf_init(pr);
  144. result = acpi_processor_thermal_init(pr, device);
  145. if (result)
  146. goto err_power_exit;
  147. status = acpi_install_notify_handler(device->handle, ACPI_DEVICE_NOTIFY,
  148. acpi_processor_notify, device);
  149. if (ACPI_SUCCESS(status))
  150. return 0;
  151. result = -ENODEV;
  152. acpi_processor_thermal_exit(pr, device);
  153. err_power_exit:
  154. acpi_processor_power_exit(pr);
  155. return result;
  156. }
  157. static int acpi_processor_start(struct device *dev)
  158. {
  159. struct acpi_device *device = ACPI_COMPANION(dev);
  160. int ret;
  161. if (!device)
  162. return -ENODEV;
  163. /* Protect against concurrent CPU hotplug operations */
  164. cpu_hotplug_disable();
  165. ret = __acpi_processor_start(device);
  166. cpu_hotplug_enable();
  167. return ret;
  168. }
  169. static int acpi_processor_stop(struct device *dev)
  170. {
  171. struct acpi_device *device = ACPI_COMPANION(dev);
  172. struct acpi_processor *pr;
  173. if (!device)
  174. return 0;
  175. acpi_remove_notify_handler(device->handle, ACPI_DEVICE_NOTIFY,
  176. acpi_processor_notify);
  177. pr = acpi_driver_data(device);
  178. if (!pr)
  179. return 0;
  180. acpi_processor_power_exit(pr);
  181. acpi_cppc_processor_exit(pr);
  182. acpi_processor_thermal_exit(pr, device);
  183. return 0;
  184. }
  185. bool acpi_processor_cpufreq_init;
  186. static int acpi_processor_notifier(struct notifier_block *nb,
  187. unsigned long event, void *data)
  188. {
  189. struct cpufreq_policy *policy = data;
  190. if (event == CPUFREQ_CREATE_POLICY) {
  191. acpi_thermal_cpufreq_init(policy);
  192. acpi_processor_ppc_init(policy);
  193. } else if (event == CPUFREQ_REMOVE_POLICY) {
  194. acpi_processor_ppc_exit(policy);
  195. acpi_thermal_cpufreq_exit(policy);
  196. }
  197. return 0;
  198. }
  199. static struct notifier_block acpi_processor_notifier_block = {
  200. .notifier_call = acpi_processor_notifier,
  201. };
  202. /*
  203. * We keep the driver loaded even when ACPI is not running.
  204. * This is needed for the powernow-k8 driver, that works even without
  205. * ACPI, but needs symbols from this driver
  206. */
  207. static enum cpuhp_state hp_online;
  208. static int __init acpi_processor_driver_init(void)
  209. {
  210. int result = 0;
  211. if (acpi_disabled)
  212. return 0;
  213. result = driver_register(&acpi_processor_driver);
  214. if (result < 0)
  215. return result;
  216. result = cpuhp_setup_state_nocalls(CPUHP_AP_ONLINE_DYN,
  217. "acpi/cpu-drv:online",
  218. acpi_soft_cpu_online, NULL);
  219. if (result < 0)
  220. goto err;
  221. hp_online = result;
  222. cpuhp_setup_state_nocalls(CPUHP_ACPI_CPUDRV_DEAD, "acpi/cpu-drv:dead",
  223. NULL, acpi_soft_cpu_dead);
  224. if (!cpufreq_register_notifier(&acpi_processor_notifier_block,
  225. CPUFREQ_POLICY_NOTIFIER)) {
  226. acpi_processor_cpufreq_init = true;
  227. acpi_processor_ignore_ppc_init();
  228. }
  229. acpi_processor_throttling_init();
  230. return 0;
  231. err:
  232. driver_unregister(&acpi_processor_driver);
  233. return result;
  234. }
  235. static void __exit acpi_processor_driver_exit(void)
  236. {
  237. if (acpi_disabled)
  238. return;
  239. if (acpi_processor_cpufreq_init) {
  240. cpufreq_unregister_notifier(&acpi_processor_notifier_block,
  241. CPUFREQ_POLICY_NOTIFIER);
  242. acpi_processor_cpufreq_init = false;
  243. }
  244. cpuhp_remove_state_nocalls(hp_online);
  245. cpuhp_remove_state_nocalls(CPUHP_ACPI_CPUDRV_DEAD);
  246. driver_unregister(&acpi_processor_driver);
  247. }
  248. module_init(acpi_processor_driver_init);
  249. module_exit(acpi_processor_driver_exit);
  250. MODULE_ALIAS("processor");