diff options
Diffstat (limited to 'trayfreq_set')
| -rw-r--r-- | trayfreq_set/trayfreq_set.c | 67 | 
1 files changed, 37 insertions, 30 deletions
| diff --git a/trayfreq_set/trayfreq_set.c b/trayfreq_set/trayfreq_set.c index 75b37f0..9318403 100644 --- a/trayfreq_set/trayfreq_set.c +++ b/trayfreq_set/trayfreq_set.c @@ -20,30 +20,43 @@  #include <stdlib.h>  #include <string.h> +#include "../strings.h"  #include "../freq_tray/getfreq.h"  #include "../freq_tray/getcore.h" -#define ERRMSG "FAILED: Couldn't open %s for writing\n" +char file_path[100]; -void set_freq_max(char* freq, char* core) + +void prepare_path(const char* file, const char* core) +{ +	// Sanatise core to make sure there's not monkey business going on -- it's only an integer +	int core_i = atoi(core); + +	sprintf(file_path, "/sys/devices/system/cpu/cpu%d/cpufreq/%s", core_i, file); +} + +void file_open_error() +{ +	printf(S_TRAYFREQ_SET_C_FILE_OPEN_ERROR, file_path); +} + +void set_freq_max(const char* freq, const char* core)  { -	char file_path[100]; -	sprintf(file_path, "/sys/devices/system/cpu/cpu%s/cpufreq/scaling_max_freq", core); +	prepare_path("scaling_max_freq",core);  	FILE* fd = fopen(file_path, "w");  	if (fd)  	{  		fprintf(fd, freq);  		fclose(fd);  	} else { -		printf(ERRMSG,file_path); +		file_open_error();  	}  }  void set_freq_min(char* freq, char* core)  { -	char file_path[100]; -	sprintf(file_path, "/sys/devices/system/cpu/cpu%s/cpufreq/scaling_min_freq", core); +	prepare_path("scaling_min_freq",core);  	FILE* fd = fopen(file_path, "w");  	if (fd) @@ -51,14 +64,13 @@ void set_freq_min(char* freq, char* core)  		fprintf(fd, freq);  		fclose(fd);  	} else { -		printf(ERRMSG,file_path); +		file_open_error();  	}  }  static void set_speed(char* freq, char* core)  { -	char file_path[100]; -	sprintf(file_path, "/sys/devices/system/cpu/cpu%s/cpufreq/scaling_setspeed", core); +	prepare_path("scaling_setspeed",core);  	FILE* fd = fopen(file_path, "w");  	if (fd) @@ -66,14 +78,13 @@ static void set_speed(char* freq, char* core)  		fprintf(fd, freq);  		fclose(fd);  	} else { -		printf(ERRMSG,file_path); +		file_open_error();  	}  }  void set_gov(char* gov, char* core)  { -	char file_path[100]; -	sprintf(file_path, "/sys/devices/system/cpu/cpu%s/cpufreq/scaling_governor", core); +	prepare_path("scaling_governor",core);  	FILE* fd = fopen(file_path, "w");  	if (fd) @@ -81,7 +92,7 @@ void set_gov(char* gov, char* core)  		fprintf(fd, gov);  		fclose(fd);  	} else { -		printf(ERRMSG,file_path); +		file_open_error();  	}  } @@ -98,47 +109,43 @@ int main(int argc, char *argv[])  	if(!argv[1])  	{ -		printf("Use -g to set the governor or -f to set the frequency.\n"); -	} -	else if(strcmp(argv[1], "-g") == 0) -	{ +		printf(S_TRAYFREQ_SET_C_NO_ARGS); +	} else if(strcmp(argv[1], "-g") == 0) {  		if(!argv[2]) -			printf("Pass the governor to set after the -g.\n"); +			printf(S_TRAYFREQ_SET_C_SET_GOVERNOR_ARG);  		else  		{  			if(!argv[3]) -				printf("Use -c to set the core.\n"); +				printf(S_TRAYFREQ_SET_C_SET_CORE_ARG);  			else if(strcmp(argv[3], "-c") == 0)  			{  				if(!argv[4]) -					printf("Pass the core to set after the -c.\n"); +					printf(S_TRAYFREQ_SET_C_SET_CORE_ARG);  				else  					set_gov(argv[2], argv[4]);  			} else -				printf("Use -c to set the core.\n"); +				printf(S_TRAYFREQ_SET_C_SET_CORE_ARG);  		} -	} -	else if(strcmp(argv[1], "-f") == 0) -	{ +	} else if(strcmp(argv[1], "-f") == 0) {  		if(!argv[2])  		{ -			printf("Pass the frequency to set after the -f.\n"); +			printf(S_TRAYFREQ_SET_C_SET_FREQUENCY_ARG);  		} else {  			if(!argv[3])  			{ -				printf("Use -c to set the core.\n"); +				printf(S_TRAYFREQ_SET_C_SET_CORE_ARG);  			} else if(strcmp(argv[3], "-c") == 0)  			{  				if(!argv[4]) -					printf("Pass the core to set after the -c.\n"); +					printf(S_TRAYFREQ_SET_C_SET_CORE_ARG);  				else  					set_freq(argv[2], argv[4]);  			} else { -				printf("Use -c to set the core.\n"); +				printf(S_TRAYFREQ_SET_C_SET_CORE_ARG);  			}  		}  	} else { -		printf("Use -g to set the governor or -f to set the frequency.\n"); +		printf(S_TRAYFREQ_SET_C_NO_ARGS);  	}  	return 0;  }
\ No newline at end of file | 
