treewide: remove redundant IS_ERR() before error code check
[linux/fpc-iii.git] / drivers / devfreq / governor_powersave.c
blob4746af2435b0224ddb5a80526f96e30ff2bab711
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3 * linux/drivers/devfreq/governor_powersave.c
5 * Copyright (C) 2011 Samsung Electronics
6 * MyungJoo Ham <myungjoo.ham@samsung.com>
7 */
9 #include <linux/devfreq.h>
10 #include <linux/module.h>
11 #include "governor.h"
13 static int devfreq_powersave_func(struct devfreq *df,
14 unsigned long *freq)
17 * target callback should be able to get ceiling value as
18 * said in devfreq.h
20 *freq = DEVFREQ_MIN_FREQ;
21 return 0;
24 static int devfreq_powersave_handler(struct devfreq *devfreq,
25 unsigned int event, void *data)
27 int ret = 0;
29 if (event == DEVFREQ_GOV_START) {
30 mutex_lock(&devfreq->lock);
31 ret = update_devfreq(devfreq);
32 mutex_unlock(&devfreq->lock);
35 return ret;
38 static struct devfreq_governor devfreq_powersave = {
39 .name = DEVFREQ_GOV_POWERSAVE,
40 .get_target_freq = devfreq_powersave_func,
41 .event_handler = devfreq_powersave_handler,
44 static int __init devfreq_powersave_init(void)
46 return devfreq_add_governor(&devfreq_powersave);
48 subsys_initcall(devfreq_powersave_init);
50 static void __exit devfreq_powersave_exit(void)
52 int ret;
54 ret = devfreq_remove_governor(&devfreq_powersave);
55 if (ret)
56 pr_err("%s: failed remove governor %d\n", __func__, ret);
58 return;
60 module_exit(devfreq_powersave_exit);
61 MODULE_LICENSE("GPL");