Linux Audio

Check our new training course

Loading...
v4.6
 
 1/*
 2 *  linux/drivers/devfreq/governor_powersave.c
 3 *
 4 *  Copyright (C) 2011 Samsung Electronics
 5 *	MyungJoo Ham <myungjoo.ham@samsung.com>
 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#include <linux/devfreq.h>
13#include <linux/module.h>
14#include "governor.h"
15
16static int devfreq_powersave_func(struct devfreq *df,
17				  unsigned long *freq)
18{
19	/*
20	 * target callback should be able to get ceiling value as
21	 * said in devfreq.h
22	 */
23	*freq = df->min_freq;
24	return 0;
25}
26
27static int devfreq_powersave_handler(struct devfreq *devfreq,
28				unsigned int event, void *data)
29{
30	int ret = 0;
31
32	if (event == DEVFREQ_GOV_START) {
33		mutex_lock(&devfreq->lock);
34		ret = update_devfreq(devfreq);
35		mutex_unlock(&devfreq->lock);
36	}
37
38	return ret;
39}
40
41static struct devfreq_governor devfreq_powersave = {
42	.name = "powersave",
43	.get_target_freq = devfreq_powersave_func,
44	.event_handler = devfreq_powersave_handler,
45};
46
47static int __init devfreq_powersave_init(void)
48{
49	return devfreq_add_governor(&devfreq_powersave);
50}
51subsys_initcall(devfreq_powersave_init);
52
53static void __exit devfreq_powersave_exit(void)
54{
55	int ret;
56
57	ret = devfreq_remove_governor(&devfreq_powersave);
58	if (ret)
59		pr_err("%s: failed remove governor %d\n", __func__, ret);
60
61	return;
62}
63module_exit(devfreq_powersave_exit);
64MODULE_LICENSE("GPL");
v6.2
 1// SPDX-License-Identifier: GPL-2.0-only
 2/*
 3 *  linux/drivers/devfreq/governor_powersave.c
 4 *
 5 *  Copyright (C) 2011 Samsung Electronics
 6 *	MyungJoo Ham <myungjoo.ham@samsung.com>
 
 
 
 
 7 */
 8
 9#include <linux/devfreq.h>
10#include <linux/module.h>
11#include "governor.h"
12
13static int devfreq_powersave_func(struct devfreq *df,
14				  unsigned long *freq)
15{
16	/*
17	 * target callback should be able to get ceiling value as
18	 * said in devfreq.h
19	 */
20	*freq = DEVFREQ_MIN_FREQ;
21	return 0;
22}
23
24static int devfreq_powersave_handler(struct devfreq *devfreq,
25				unsigned int event, void *data)
26{
27	int ret = 0;
28
29	if (event == DEVFREQ_GOV_START) {
30		mutex_lock(&devfreq->lock);
31		ret = update_devfreq(devfreq);
32		mutex_unlock(&devfreq->lock);
33	}
34
35	return ret;
36}
37
38static struct devfreq_governor devfreq_powersave = {
39	.name = DEVFREQ_GOV_POWERSAVE,
40	.get_target_freq = devfreq_powersave_func,
41	.event_handler = devfreq_powersave_handler,
42};
43
44static int __init devfreq_powersave_init(void)
45{
46	return devfreq_add_governor(&devfreq_powersave);
47}
48subsys_initcall(devfreq_powersave_init);
49
50static void __exit devfreq_powersave_exit(void)
51{
52	int ret;
53
54	ret = devfreq_remove_governor(&devfreq_powersave);
55	if (ret)
56		pr_err("%s: failed remove governor %d\n", __func__, ret);
57
58	return;
59}
60module_exit(devfreq_powersave_exit);
61MODULE_LICENSE("GPL");