Sharing code is a good idea. cpufrequtils/libs exist for years and every distribution should have them. It's also well maintained and ideally is the only userspace tool which needs adjusting if cpufreq sysfs api changes at some time. Signed-off-by: Thomas Renninger <trenn@xxxxxxx> CC: Amit Arora <amit.arora@xxxxxxxxxx> CC: auke@xxxxxxxxxxxxxxx CC: power@xxxxxxxxxxx CC: cpufreq@xxxxxxxxxxxxxxx --- Makefile | 1 + cpufreqstats.c | 52 ++++++++++++++++++++-------------------------------- 2 files changed, 21 insertions(+), 32 deletions(-) diff --git a/Makefile b/Makefile index e4e1671..ee10a84 100644 --- a/Makefile +++ b/Makefile @@ -6,6 +6,7 @@ MANDIR=/usr/share/man/man8 WARNFLAGS=-Wall -Wshadow -W -Wformat -Wimplicit-function-declaration -Wimplicit-int CFLAGS?=-O1 -g ${WARNFLAGS} CC?=gcc +LDFLAGS = -lcpufreq CFLAGS+=-D VERSION=\"$(VERSION)\" diff --git a/cpufreqstats.c b/cpufreqstats.c index d10b047..303c3cf 100644 --- a/cpufreqstats.c +++ b/cpufreqstats.c @@ -29,6 +29,7 @@ #include <stdint.h> #include <sys/types.h> #include <dirent.h> +#include <cpufreq.h> #include "powertop.h" @@ -100,15 +101,11 @@ static char *HzToHuman(unsigned long hz) void do_cpufreq_stats(void) { - DIR *dir; - struct dirent *dirent; - FILE *file; - char filename[PATH_MAX]; - char line[1024]; - - int ret = 0; + struct cpufreq_stats *freq_stats, *tmp; + int cpu = 0, ret = 0; int maxfreq = 0; uint64_t total_time = 0; + unsigned long long time_dummy = 0; memcpy(&oldfreqs, &freqs, sizeof(freqs)); memset(&cpufreqstrings, 0, sizeof(cpufreqstrings)); @@ -117,30 +114,21 @@ void do_cpufreq_stats(void) for (ret = 0; ret<16; ret++) freqs[ret].count = 0; - dir = opendir("/sys/devices/system/cpu"); - if (!dir) + freq_stats = cpufreq_get_stats(0, &time_dummy); + if (!freq_stats) + /* Probably cpufreq_stats not compiled in or no cpufreq + support, printing a debug message is appropriate */ return; - while ((dirent = readdir(dir))) { - int i; - if (dirent->d_name[0]=='.') - continue; - sprintf(filename, "/sys/devices/system/cpu/%s/cpufreq/stats/time_in_state", dirent->d_name); - file = fopen(filename, "r"); - if (!file) - continue; - memset(line, 0, 1024); - - i = 0; - while (!feof(file)) { - uint64_t f,count; - char *c; - if (fgets(line, 1023,file)==NULL) - break; - f = strtoull(line, &c, 10); - if (!c) - break; - count = strtoull(c, NULL, 10); + /* cpu loop */ + while (freq_stats) { + int i = 0; + tmp = freq_stats; + /* freq loop */ + for (;freq_stats; freq_stats = freq_stats->next) { + + unsigned long f = freq_stats->frequency; + unsigned long long count = freq_stats->time_in_state; if (freqs[i].frequency && freqs[i].frequency != f) { zap(); @@ -156,11 +144,11 @@ void do_cpufreq_stats(void) if (i>15) break; } - fclose(file); + cpu++; + cpufreq_put_stats(tmp); + freq_stats = cpufreq_get_stats(cpu, &time_dummy); } - closedir(dir); - for (ret = 0; ret < 16; ret++) { delta[ret].count = freqs[ret].count - oldfreqs[ret].count; total_time += delta[ret].count; -- 1.6.4.2 -- To unsubscribe from this list: send the line "unsubscribe cpufreq" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html