blob: f1e5ac7ab3013810daed08f7cc1d71ee531b6916 [file] [log] [blame]
b.liue9582032025-04-17 19:18:16 +08001// 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
8static struct cpufreq_frequency_table freq_table[] = {
9 { .frequency = 1 },
10 { .frequency = 2 },
11 { .frequency = CPUFREQ_TABLE_END },
12};
13
14static int dummy_cpufreq_target_index(struct cpufreq_policy *policy,
15 unsigned int index)
16{
17 return 0;
18}
19
20static int dummy_cpufreq_driver_init(struct cpufreq_policy *policy)
21{
22 policy->freq_table = freq_table;
23 return 0;
24}
25
26static unsigned int dummy_cpufreq_get(unsigned int cpu)
27{
28 return 1;
29}
30
31static int dummy_cpufreq_verify(struct cpufreq_policy_data *policy)
32{
33 return 0;
34}
35
36static struct cpufreq_driver dummy_cpufreq_driver = {
37 .name = "dummy",
38 .target_index = dummy_cpufreq_target_index,
39 .init = dummy_cpufreq_driver_init,
40 .get = dummy_cpufreq_get,
41 .verify = dummy_cpufreq_verify,
42 .attr = cpufreq_generic_attr,
43};
44
45static int __init dummy_cpufreq_init(void)
46{
47 return cpufreq_register_driver(&dummy_cpufreq_driver);
48}
49
50static void __exit dummy_cpufreq_exit(void)
51{
52 cpufreq_unregister_driver(&dummy_cpufreq_driver);
53}
54
55module_init(dummy_cpufreq_init);
56module_exit(dummy_cpufreq_exit);
57
58MODULE_AUTHOR("Connor O'Brien <connoro@google.com>");
59MODULE_DESCRIPTION("dummy cpufreq driver");
60MODULE_LICENSE("GPL");