blob: e3b874c235eada5d353f4b02831140c6a244af68 [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
Sven Wegenerc4d14bc2008-09-20 16:50:08 +020036#ifndef CONFIG_CPU_FREQ_DEFAULT_GOV_POWERSAVE
37static
38#endif
Alessandro Guido30d221d2008-04-18 13:31:13 -070039struct cpufreq_governor cpufreq_gov_powersave = {
Linus Torvalds1da177e2005-04-16 15:20:36 -070040 .name = "powersave",
41 .governor = cpufreq_governor_powersave,
42 .owner = THIS_MODULE,
43};
Linus Torvalds1da177e2005-04-16 15:20:36 -070044
45static int __init cpufreq_gov_powersave_init(void)
46{
47 return cpufreq_register_governor(&cpufreq_gov_powersave);
48}
49
Linus Torvalds1da177e2005-04-16 15:20:36 -070050static void __exit cpufreq_gov_powersave_exit(void)
51{
52 cpufreq_unregister_governor(&cpufreq_gov_powersave);
53}
54
Linus Torvalds1da177e2005-04-16 15:20:36 -070055MODULE_AUTHOR("Dominik Brodowski <linux@brodo.de>");
56MODULE_DESCRIPTION("CPUfreq policy governor 'powersave'");
57MODULE_LICENSE("GPL");
58
Alessandro Guido30d221d2008-04-18 13:31:13 -070059#ifdef CONFIG_CPU_FREQ_DEFAULT_GOV_POWERSAVE
60fs_initcall(cpufreq_gov_powersave_init);
61#else
Linus Torvalds1da177e2005-04-16 15:20:36 -070062module_init(cpufreq_gov_powersave_init);
Alessandro Guido30d221d2008-04-18 13:31:13 -070063#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -070064module_exit(cpufreq_gov_powersave_exit);