diff options
Diffstat (limited to 'tools/power/cpupower/utils/helpers/misc.c')
| -rw-r--r-- | tools/power/cpupower/utils/helpers/misc.c | 76 | 
1 files changed, 54 insertions, 22 deletions
| diff --git a/tools/power/cpupower/utils/helpers/misc.c b/tools/power/cpupower/utils/helpers/misc.c index 76e461ff4f74..166dc1e470ea 100644 --- a/tools/power/cpupower/utils/helpers/misc.c +++ b/tools/power/cpupower/utils/helpers/misc.c @@ -8,15 +8,14 @@  #include "helpers/helpers.h"  #include "helpers/sysfs.h"  #include "cpufreq.h" +#include "cpupower_intern.h"  #if defined(__i386__) || defined(__x86_64__) -#include "cpupower_intern.h" -  #define MSR_AMD_HWCR	0xc0010015 -int cpufreq_has_boost_support(unsigned int cpu, int *support, int *active, -			int *states) +int cpufreq_has_x86_boost_support(unsigned int cpu, int *support, int *active, +				  int *states)  {  	int ret;  	unsigned long long val; @@ -124,24 +123,6 @@ int cpupower_set_amd_pstate_mode(char *mode)  	return 0;  } -int cpupower_set_turbo_boost(int turbo_boost) -{ -	char path[SYSFS_PATH_MAX]; -	char linebuf[2] = {}; - -	snprintf(path, sizeof(path), PATH_TO_CPU "cpufreq/boost"); - -	if (!is_valid_path(path)) -		return -1; - -	snprintf(linebuf, sizeof(linebuf), "%d", turbo_boost); - -	if (cpupower_write_sysfs(path, linebuf, 2) <= 0) -		return -1; - -	return 0; -} -  bool cpupower_amd_pstate_enabled(void)  {  	char *driver = cpufreq_get_driver(0); @@ -160,6 +141,39 @@ bool cpupower_amd_pstate_enabled(void)  #endif /* #if defined(__i386__) || defined(__x86_64__) */ +int cpufreq_has_generic_boost_support(bool *active) +{ +	char path[SYSFS_PATH_MAX]; +	char linebuf[2] = {}; +	unsigned long val; +	char *endp; + +	snprintf(path, sizeof(path), PATH_TO_CPU "cpufreq/boost"); + +	if (!is_valid_path(path)) +		return -EACCES; + +	if (cpupower_read_sysfs(path, linebuf, 2) <= 0) +		return -EINVAL; + +	val = strtoul(linebuf, &endp, 0); +	if (endp == linebuf || errno == ERANGE) +		return -EINVAL; + +	switch (val) { +	case 0: +		*active = false; +		break; +	case 1: +		*active = true; +		break; +	default: +		return -EINVAL; +	} + +	return 0; +} +  /* get_cpustate   *   * Gather the information of all online CPUs into bitmask struct @@ -259,3 +273,21 @@ void print_speed(unsigned long speed, int no_rounding)  		}  	}  } + +int cpupower_set_turbo_boost(int turbo_boost) +{ +	char path[SYSFS_PATH_MAX]; +	char linebuf[2] = {}; + +	snprintf(path, sizeof(path), PATH_TO_CPU "cpufreq/boost"); + +	if (!is_valid_path(path)) +		return -1; + +	snprintf(linebuf, sizeof(linebuf), "%d", turbo_boost); + +	if (cpupower_write_sysfs(path, linebuf, 2) <= 0) +		return -1; + +	return 0; +} | 
