dummy-cpufreq.c 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Copyright (C) 2019 Google, Inc.
  4. */
  5. #include <linux/cpufreq.h>
  6. #include <linux/module.h>
  7. static struct cpufreq_frequency_table freq_table[] = {
  8. { .frequency = 1 },
  9. { .frequency = 2 },
  10. { .frequency = CPUFREQ_TABLE_END },
  11. };
  12. static int dummy_cpufreq_target_index(struct cpufreq_policy *policy,
  13. unsigned int index)
  14. {
  15. return 0;
  16. }
  17. static int dummy_cpufreq_driver_init(struct cpufreq_policy *policy)
  18. {
  19. return cpufreq_table_validate_and_show(policy, freq_table);
  20. }
  21. static unsigned int dummy_cpufreq_get(unsigned int cpu)
  22. {
  23. return 1;
  24. }
  25. static int dummy_cpufreq_verify(struct cpufreq_policy *policy)
  26. {
  27. return 0;
  28. }
  29. static struct cpufreq_driver dummy_cpufreq_driver = {
  30. .name = "dummy",
  31. .target_index = dummy_cpufreq_target_index,
  32. .init = dummy_cpufreq_driver_init,
  33. .get = dummy_cpufreq_get,
  34. .verify = dummy_cpufreq_verify,
  35. .attr = cpufreq_generic_attr,
  36. };
  37. static int __init dummy_cpufreq_init(void)
  38. {
  39. return cpufreq_register_driver(&dummy_cpufreq_driver);
  40. }
  41. static void __exit dummy_cpufreq_exit(void)
  42. {
  43. cpufreq_unregister_driver(&dummy_cpufreq_driver);
  44. }
  45. module_init(dummy_cpufreq_init);
  46. module_exit(dummy_cpufreq_exit);
  47. MODULE_AUTHOR("Connor O'Brien <connoro@google.com>");
  48. MODULE_DESCRIPTION("dummy cpufreq driver");
  49. MODULE_LICENSE("GPL");