blob: b8b400232a7451fe392f767ed7aaecf6600c680d [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
Viresh Kumarbb176f72013-06-19 14:19:33 +05302 * linux/drivers/cpufreq/cpufreq_powersave.c
Linus Torvalds1da177e2005-04-16 15:20:36 -07003 *
Viresh Kumarbb176f72013-06-19 14:19:33 +05304 * Copyright (C) 2002 - 2003 Dominik Brodowski <linux@brodo.de>
Linus Torvalds1da177e2005-04-16 15:20:36 -07005 *
6 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License version 2 as
9 * published by the Free Software Foundation.
10 *
11 */
12
Viresh Kumardb701152012-10-23 01:29:03 +020013#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
14
Linus Torvalds1da177e2005-04-16 15:20:36 -070015#include <linux/cpufreq.h>
16#include <linux/init.h>
Viresh Kumar5ff0a262013-08-06 22:53:03 +053017#include <linux/module.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070018
Linus Torvalds1da177e2005-04-16 15:20:36 -070019static int cpufreq_governor_powersave(struct cpufreq_policy *policy,
20 unsigned int event)
21{
22 switch (event) {
23 case CPUFREQ_GOV_START:
24 case CPUFREQ_GOV_LIMITS:
Dominik Brodowski2d06d8c2011-03-27 15:04:46 +020025 pr_debug("setting to %u kHz because of event %u\n",
Gautham R Shenoye08f5f52006-10-26 16:20:58 +053026 policy->min, event);
27 __cpufreq_driver_target(policy, policy->min,
28 CPUFREQ_RELATION_L);
Linus Torvalds1da177e2005-04-16 15:20:36 -070029 break;
30 default:
31 break;
32 }
33 return 0;
34}
Dave Jones32ee8c32006-02-28 00:43:23 -050035
Rafael J. Wysockide1df262016-02-05 02:37:42 +010036static struct cpufreq_governor cpufreq_gov_powersave = {
Linus Torvalds1da177e2005-04-16 15:20:36 -070037 .name = "powersave",
38 .governor = cpufreq_governor_powersave,
39 .owner = THIS_MODULE,
40};
Linus Torvalds1da177e2005-04-16 15:20:36 -070041
42static int __init cpufreq_gov_powersave_init(void)
43{
44 return cpufreq_register_governor(&cpufreq_gov_powersave);
45}
46
Linus Torvalds1da177e2005-04-16 15:20:36 -070047static void __exit cpufreq_gov_powersave_exit(void)
48{
49 cpufreq_unregister_governor(&cpufreq_gov_powersave);
50}
51
Linus Torvalds1da177e2005-04-16 15:20:36 -070052MODULE_AUTHOR("Dominik Brodowski <linux@brodo.de>");
53MODULE_DESCRIPTION("CPUfreq policy governor 'powersave'");
54MODULE_LICENSE("GPL");
55
Alessandro Guido30d221d2008-04-18 13:31:13 -070056#ifdef CONFIG_CPU_FREQ_DEFAULT_GOV_POWERSAVE
Rafael J. Wysockide1df262016-02-05 02:37:42 +010057struct cpufreq_governor *cpufreq_default_governor(void)
58{
59 return &cpufreq_gov_powersave;
60}
61
Alessandro Guido30d221d2008-04-18 13:31:13 -070062fs_initcall(cpufreq_gov_powersave_init);
63#else
Linus Torvalds1da177e2005-04-16 15:20:36 -070064module_init(cpufreq_gov_powersave_init);
Alessandro Guido30d221d2008-04-18 13:31:13 -070065#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -070066module_exit(cpufreq_gov_powersave_exit);