Release 4.12 drivers/cpufreq/cpufreq_conservative.c
  
  
  
/*
 *  drivers/cpufreq/cpufreq_conservative.c
 *
 *  Copyright (C)  2001 Russell King
 *            (C)  2003 Venkatesh Pallipadi <venkatesh.pallipadi@intel.com>.
 *                      Jun Nakajima <jun.nakajima@intel.com>
 *            (C)  2009 Alexander Clouter <alex@digriz.org.uk>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 */
#include <linux/slab.h>
#include "cpufreq_governor.h"
struct cs_policy_dbs_info {
	
struct policy_dbs_info policy_dbs;
	
unsigned int down_skip;
	
unsigned int requested_freq;
};
static inline struct cs_policy_dbs_info *to_dbs_info(struct policy_dbs_info *policy_dbs)
{
	return container_of(policy_dbs, struct cs_policy_dbs_info, policy_dbs);
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp | 
| Rafael J. Wysocki | 25 | 100.00% | 1 | 100.00% | 
| Total | 25 | 100.00% | 1 | 100.00% | 
struct cs_dbs_tuners {
	
unsigned int down_threshold;
	
unsigned int freq_step;
};
/* Conservative governor macros */
#define DEF_FREQUENCY_UP_THRESHOLD		(80)
#define DEF_FREQUENCY_DOWN_THRESHOLD		(20)
#define DEF_FREQUENCY_STEP			(5)
#define DEF_SAMPLING_DOWN_FACTOR		(1)
#define MAX_SAMPLING_DOWN_FACTOR		(10)
static inline unsigned int get_freq_step(struct cs_dbs_tuners *cs_tuners,
					 struct cpufreq_policy *policy)
{
	unsigned int freq_step = (cs_tuners->freq_step * policy->max) / 100;
	/* max freq cannot be less than 100. But who knows... */
	if (unlikely(freq_step == 0))
		freq_step = DEF_FREQUENCY_STEP;
	return freq_step;
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp | 
| Stratos Karafotis | 46 | 90.20% | 1 | 50.00% | 
| Viresh Kumar | 5 | 9.80% | 1 | 50.00% | 
| Total | 51 | 100.00% | 2 | 100.00% | 
/*
 * Every sampling_rate, we check, if current idle time is less than 20%
 * (default), then we try to increase frequency. Every sampling_rate *
 * sampling_down_factor, we check, if current idle time is more than 80%
 * (default), then we try to decrease frequency
 *
 * Frequency updates happen at minimum steps of 5% (default) of maximum
 * frequency
 */
static unsigned int cs_dbs_update(struct cpufreq_policy *policy)
{
	struct policy_dbs_info *policy_dbs = policy->governor_data;
	struct cs_policy_dbs_info *dbs_info = to_dbs_info(policy_dbs);
	unsigned int requested_freq = dbs_info->requested_freq;
	struct dbs_data *dbs_data = policy_dbs->dbs_data;
	struct cs_dbs_tuners *cs_tuners = dbs_data->tuners;
	unsigned int load = dbs_update(policy);
	unsigned int freq_step;
	/*
         * break out if we 'cannot' reduce the speed as the user might
         * want freq_step to be zero
         */
	if (cs_tuners->freq_step == 0)
		goto out;
	/*
         * If requested_freq is out of range, it is likely that the limits
         * changed in the meantime, so fall back to current frequency in that
         * case.
         */
	if (requested_freq > policy->max || requested_freq < policy->min)
		requested_freq = policy->cur;
	freq_step = get_freq_step(cs_tuners, policy);
	/*
         * Decrease requested_freq one freq_step for each idle period that
         * we didn't update the frequency.
         */
	if (policy_dbs->idle_periods < UINT_MAX) {
		unsigned int freq_steps = policy_dbs->idle_periods * freq_step;
		if (requested_freq > freq_steps)
			requested_freq -= freq_steps;
		else
			requested_freq = policy->min;
		policy_dbs->idle_periods = UINT_MAX;
	}
	/* Check for frequency increase */
	if (load > dbs_data->up_threshold) {
		dbs_info->down_skip = 0;
		/* if we are already at full speed then break out early */
		if (requested_freq == policy->max)
			goto out;
		requested_freq += freq_step;
		if (requested_freq > policy->max)
			requested_freq = policy->max;
		__cpufreq_driver_target(policy, requested_freq, CPUFREQ_RELATION_H);
		dbs_info->requested_freq = requested_freq;
		goto out;
	}
	/* if sampling_down_factor is active break out early */
	if (++dbs_info->down_skip < dbs_data->sampling_down_factor)
		goto out;
	dbs_info->down_skip = 0;
	/* Check for frequency decrease */
	if (load < cs_tuners->down_threshold) {
		/*
                 * if we cannot reduce the frequency anymore, break out early
                 */
		if (requested_freq == policy->min)
			goto out;
		if (requested_freq > freq_step)
			requested_freq -= freq_step;
		else
			requested_freq = policy->min;
		__cpufreq_driver_target(policy, requested_freq, CPUFREQ_RELATION_L);
		dbs_info->requested_freq = requested_freq;
	}
 out:
	return dbs_data->sampling_rate;
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp | 
| Rafael J. Wysocki | 105 | 34.54% | 5 | 25.00% | 
| Viresh Kumar | 77 | 25.33% | 7 | 35.00% | 
| Stratos Karafotis | 76 | 25.00% | 3 | 15.00% | 
| Xiaoguang Chen | 15 | 4.93% | 1 | 5.00% | 
| Elias Oltmanns | 12 | 3.95% | 1 | 5.00% | 
| Alexander Clouter | 10 | 3.29% | 1 | 5.00% | 
| Namhyung Kim | 9 | 2.96% | 2 | 10.00% | 
| Total | 304 | 100.00% | 20 | 100.00% | 
/************************** sysfs interface ************************/
static ssize_t store_sampling_down_factor(struct gov_attr_set *attr_set,
					  const char *buf, size_t count)
{
	struct dbs_data *dbs_data = to_dbs_data(attr_set);
	unsigned int input;
	int ret;
	ret = sscanf(buf, "%u", &input);
	if (ret != 1 || input > MAX_SAMPLING_DOWN_FACTOR || input < 1)
		return -EINVAL;
	dbs_data->sampling_down_factor = input;
	return count;
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp | 
| Dave Jones | 45 | 60.00% | 1 | 16.67% | 
| Rafael J. Wysocki | 12 | 16.00% | 1 | 16.67% | 
| Viresh Kumar | 10 | 13.33% | 3 | 50.00% | 
| Alexander Clouter | 8 | 10.67% | 1 | 16.67% | 
| Total | 75 | 100.00% | 6 | 100.00% | 
static ssize_t store_up_threshold(struct gov_attr_set *attr_set,
				  const char *buf, size_t count)
{
	struct dbs_data *dbs_data = to_dbs_data(attr_set);
	struct cs_dbs_tuners *cs_tuners = dbs_data->tuners;
	unsigned int input;
	int ret;
	ret = sscanf(buf, "%u", &input);
	if (ret != 1 || input > 100 || input <= cs_tuners->down_threshold)
		return -EINVAL;
	dbs_data->up_threshold = input;
	return count;
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp | 
| Dave Jones | 60 | 69.77% | 1 | 16.67% | 
| Viresh Kumar | 13 | 15.12% | 3 | 50.00% | 
| Rafael J. Wysocki | 12 | 13.95% | 1 | 16.67% | 
| Alexander Clouter | 1 | 1.16% | 1 | 16.67% | 
| Total | 86 | 100.00% | 6 | 100.00% | 
static ssize_t store_down_threshold(struct gov_attr_set *attr_set,
				    const char *buf, size_t count)
{
	struct dbs_data *dbs_data = to_dbs_data(attr_set);
	struct cs_dbs_tuners *cs_tuners = dbs_data->tuners;
	unsigned int input;
	int ret;
	ret = sscanf(buf, "%u", &input);
	/* cannot be lower than 1 otherwise freq will not fall */
	if (ret != 1 || input < 1 || input > 100 ||
			input >= dbs_data->up_threshold)
		return -EINVAL;
	cs_tuners->down_threshold = input;
	return count;
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp | 
| Dave Jones | 60 | 65.93% | 1 | 12.50% | 
| Viresh Kumar | 13 | 14.29% | 3 | 37.50% | 
| Rafael J. Wysocki | 12 | 13.19% | 1 | 12.50% | 
| Alexander Clouter | 4 | 4.40% | 2 | 25.00% | 
| Tomasz Wilczyński | 2 | 2.20% | 1 | 12.50% | 
| Total | 91 | 100.00% | 8 | 100.00% | 
static ssize_t store_ignore_nice_load(struct gov_attr_set *attr_set,
				      const char *buf, size_t count)
{
	struct dbs_data *dbs_data = to_dbs_data(attr_set);
	unsigned int input;
	int ret;
	ret = sscanf(buf, "%u", &input);
	if (ret != 1)
		return -EINVAL;
	if (input > 1)
		input = 1;
	if (input == dbs_data->ignore_nice_load) /* nothing to do */
		return count;
	dbs_data->ignore_nice_load = input;
	/* we need to re-evaluate prev_cpu_idle */
	gov_update_cpu_data(dbs_data);
	return count;
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp | 
| Dave Jones | 71 | 74.74% | 1 | 12.50% | 
| Rafael J. Wysocki | 13 | 13.68% | 2 | 25.00% | 
| Viresh Kumar | 8 | 8.42% | 3 | 37.50% | 
| Alexander Clouter | 2 | 2.11% | 1 | 12.50% | 
| Thomas Renninger | 1 | 1.05% | 1 | 12.50% | 
| Total | 95 | 100.00% | 8 | 100.00% | 
static ssize_t store_freq_step(struct gov_attr_set *attr_set, const char *buf,
			       size_t count)
{
	struct dbs_data *dbs_data = to_dbs_data(attr_set);
	struct cs_dbs_tuners *cs_tuners = dbs_data->tuners;
	unsigned int input;
	int ret;
	ret = sscanf(buf, "%u", &input);
	if (ret != 1)
		return -EINVAL;
	if (input > 100)
		input = 100;
	/*
         * no need to test here if freq_step is zero as the user might actually
         * want this, they would be crazy though :)
         */
	cs_tuners->freq_step = input;
	return count;
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp | 
| Dave Jones | 62 | 71.26% | 1 | 20.00% | 
| Viresh Kumar | 12 | 13.79% | 2 | 40.00% | 
| Rafael J. Wysocki | 12 | 13.79% | 1 | 20.00% | 
| Thomas Renninger | 1 | 1.15% | 1 | 20.00% | 
| Total | 87 | 100.00% | 5 | 100.00% | 
gov_show_one_common(sampling_rate);
gov_show_one_common(sampling_down_factor);
gov_show_one_common(up_threshold);
gov_show_one_common(ignore_nice_load);
gov_show_one_common(min_sampling_rate);
gov_show_one(cs, down_threshold);
gov_show_one(cs, freq_step);
gov_attr_rw(sampling_rate);
gov_attr_rw(sampling_down_factor);
gov_attr_rw(up_threshold);
gov_attr_rw(ignore_nice_load);
gov_attr_ro(min_sampling_rate);
gov_attr_rw(down_threshold);
gov_attr_rw(freq_step);
static struct attribute *cs_attributes[] = {
	&min_sampling_rate.attr,
	&sampling_rate.attr,
	&sampling_down_factor.attr,
	&up_threshold.attr,
	&down_threshold.attr,
	&ignore_nice_load.attr,
	&freq_step.attr,
	NULL
};
/************************** sysfs end ************************/
static struct policy_dbs_info *cs_alloc(void)
{
	struct cs_policy_dbs_info *dbs_info;
	dbs_info = kzalloc(sizeof(*dbs_info), GFP_KERNEL);
	return dbs_info ? &dbs_info->policy_dbs : NULL;
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp | 
| Rafael J. Wysocki | 38 | 100.00% | 1 | 100.00% | 
| Total | 38 | 100.00% | 1 | 100.00% | 
static void cs_free(struct policy_dbs_info *policy_dbs)
{
	kfree(to_dbs_info(policy_dbs));
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp | 
| Rafael J. Wysocki | 19 | 100.00% | 1 | 100.00% | 
| Total | 19 | 100.00% | 1 | 100.00% | 
static int cs_init(struct dbs_data *dbs_data)
{
	struct cs_dbs_tuners *tuners;
	tuners = kzalloc(sizeof(*tuners), GFP_KERNEL);
	if (!tuners)
		return -ENOMEM;
	tuners->down_threshold = DEF_FREQUENCY_DOWN_THRESHOLD;
	tuners->freq_step = DEF_FREQUENCY_STEP;
	dbs_data->up_threshold = DEF_FREQUENCY_UP_THRESHOLD;
	dbs_data->sampling_down_factor = DEF_SAMPLING_DOWN_FACTOR;
	dbs_data->ignore_nice_load = 0;
	dbs_data->tuners = tuners;
	dbs_data->min_sampling_rate = MIN_SAMPLING_RATE_RATIO *
		jiffies_to_usecs(10);
	return 0;
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp | 
| Viresh Kumar | 88 | 100.00% | 4 | 100.00% | 
| Total | 88 | 100.00% | 4 | 100.00% | 
static void cs_exit(struct dbs_data *dbs_data)
{
	kfree(dbs_data->tuners);
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp | 
| Viresh Kumar | 18 | 100.00% | 1 | 100.00% | 
| Total | 18 | 100.00% | 1 | 100.00% | 
static void cs_start(struct cpufreq_policy *policy)
{
	struct cs_policy_dbs_info *dbs_info = to_dbs_info(policy->governor_data);
	dbs_info->down_skip = 0;
	dbs_info->requested_freq = policy->cur;
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp | 
| Rafael J. Wysocki | 37 | 100.00% | 3 | 100.00% | 
| Total | 37 | 100.00% | 3 | 100.00% | 
static struct dbs_governor cs_governor = {
	.gov = CPUFREQ_DBS_GOVERNOR_INITIALIZER("conservative"),
	.kobj_type = { .default_attrs = cs_attributes },
	.gov_dbs_update = cs_dbs_update,
	.alloc = cs_alloc,
	.free = cs_free,
	.init = cs_init,
	.exit = cs_exit,
	.start = cs_start,
};
#define CPU_FREQ_GOV_CONSERVATIVE	(&cs_governor.gov)
static int __init cpufreq_gov_dbs_init(void)
{
	return cpufreq_register_governor(CPU_FREQ_GOV_CONSERVATIVE);
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp | 
| Dave Jones | 14 | 93.33% | 1 | 50.00% | 
| Rafael J. Wysocki | 1 | 6.67% | 1 | 50.00% | 
| Total | 15 | 100.00% | 2 | 100.00% | 
static void __exit cpufreq_gov_dbs_exit(void)
{
	cpufreq_unregister_governor(CPU_FREQ_GOV_CONSERVATIVE);
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp | 
| Dave Jones | 13 | 92.86% | 1 | 50.00% | 
| Rafael J. Wysocki | 1 | 7.14% | 1 | 50.00% | 
| Total | 14 | 100.00% | 2 | 100.00% | 
MODULE_AUTHOR("Alexander Clouter <alex@digriz.org.uk>");
MODULE_DESCRIPTION("'cpufreq_conservative' - A dynamic cpufreq governor for "
		"Low Latency Frequency Transition capable processors "
		"optimised for use in a battery environment");
MODULE_LICENSE("GPL");
#ifdef CONFIG_CPU_FREQ_DEFAULT_GOV_CONSERVATIVE
struct cpufreq_governor *cpufreq_default_governor(void)
{
	return CPU_FREQ_GOV_CONSERVATIVE;
}
Contributors
| Person | Tokens | Prop | Commits | CommitProp | 
| Rafael J. Wysocki | 12 | 100.00% | 2 | 100.00% | 
| Total | 12 | 100.00% | 2 | 100.00% | 
fs_initcall(cpufreq_gov_dbs_init);
#else
module_init(cpufreq_gov_dbs_init);
#endif
module_exit(cpufreq_gov_dbs_exit);
Overall Contributors
| Person | Tokens | Prop | Commits | CommitProp | 
| Dave Jones | 392 | 29.39% | 1 | 2.38% | 
| Viresh Kumar | 371 | 27.81% | 11 | 26.19% | 
| Rafael J. Wysocki | 358 | 26.84% | 13 | 30.95% | 
| Stratos Karafotis | 128 | 9.60% | 6 | 14.29% | 
| Alexander Clouter | 32 | 2.40% | 4 | 9.52% | 
| Xiaoguang Chen | 15 | 1.12% | 1 | 2.38% | 
| Johannes Weiner | 12 | 0.90% | 1 | 2.38% | 
| Elias Oltmanns | 12 | 0.90% | 1 | 2.38% | 
| Namhyung Kim | 9 | 0.67% | 2 | 4.76% | 
| Thomas Renninger | 3 | 0.22% | 1 | 2.38% | 
| Tomasz Wilczyński | 2 | 0.15% | 1 | 2.38% | 
| Total | 1334 | 100.00% | 42 | 100.00% | 
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.