diff options
Diffstat (limited to 'drivers/cpufreq/cppc_cpufreq.c')
| -rw-r--r-- | drivers/cpufreq/cppc_cpufreq.c | 109 | 
1 files changed, 109 insertions, 0 deletions
| diff --git a/drivers/cpufreq/cppc_cpufreq.c b/drivers/cpufreq/cppc_cpufreq.c index cb93f00bafdb..b7c688a5659c 100644 --- a/drivers/cpufreq/cppc_cpufreq.c +++ b/drivers/cpufreq/cppc_cpufreq.c @@ -808,10 +808,119 @@ static ssize_t show_freqdomain_cpus(struct cpufreq_policy *policy, char *buf)  	return cpufreq_show_cpus(cpu_data->shared_cpu_map, buf);  } + +static ssize_t show_auto_select(struct cpufreq_policy *policy, char *buf) +{ +	bool val; +	int ret; + +	ret = cppc_get_auto_sel(policy->cpu, &val); + +	/* show "<unsupported>" when this register is not supported by cpc */ +	if (ret == -EOPNOTSUPP) +		return sysfs_emit(buf, "<unsupported>\n"); + +	if (ret) +		return ret; + +	return sysfs_emit(buf, "%d\n", val); +} + +static ssize_t store_auto_select(struct cpufreq_policy *policy, +				 const char *buf, size_t count) +{ +	bool val; +	int ret; + +	ret = kstrtobool(buf, &val); +	if (ret) +		return ret; + +	ret = cppc_set_auto_sel(policy->cpu, val); +	if (ret) +		return ret; + +	return count; +} + +static ssize_t show_auto_act_window(struct cpufreq_policy *policy, char *buf) +{ +	u64 val; +	int ret; + +	ret = cppc_get_auto_act_window(policy->cpu, &val); + +	/* show "<unsupported>" when this register is not supported by cpc */ +	if (ret == -EOPNOTSUPP) +		return sysfs_emit(buf, "<unsupported>\n"); + +	if (ret) +		return ret; + +	return sysfs_emit(buf, "%llu\n", val); +} + +static ssize_t store_auto_act_window(struct cpufreq_policy *policy, +				     const char *buf, size_t count) +{ +	u64 usec; +	int ret; + +	ret = kstrtou64(buf, 0, &usec); +	if (ret) +		return ret; + +	ret = cppc_set_auto_act_window(policy->cpu, usec); +	if (ret) +		return ret; + +	return count; +} + +static ssize_t show_energy_performance_preference_val(struct cpufreq_policy *policy, char *buf) +{ +	u64 val; +	int ret; + +	ret = cppc_get_epp_perf(policy->cpu, &val); + +	/* show "<unsupported>" when this register is not supported by cpc */ +	if (ret == -EOPNOTSUPP) +		return sysfs_emit(buf, "<unsupported>\n"); + +	if (ret) +		return ret; + +	return sysfs_emit(buf, "%llu\n", val); +} + +static ssize_t store_energy_performance_preference_val(struct cpufreq_policy *policy, +						       const char *buf, size_t count) +{ +	u64 val; +	int ret; + +	ret = kstrtou64(buf, 0, &val); +	if (ret) +		return ret; + +	ret = cppc_set_epp(policy->cpu, val); +	if (ret) +		return ret; + +	return count; +} +  cpufreq_freq_attr_ro(freqdomain_cpus); +cpufreq_freq_attr_rw(auto_select); +cpufreq_freq_attr_rw(auto_act_window); +cpufreq_freq_attr_rw(energy_performance_preference_val);  static struct freq_attr *cppc_cpufreq_attr[] = {  	&freqdomain_cpus, +	&auto_select, +	&auto_act_window, +	&energy_performance_preference_val,  	NULL,  }; | 
