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 <[email protected]>
CC: Amit Arora <[email protected]>
CC: [email protected]
CC: [email protected]
CC: [email protected]
---
 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

_______________________________________________
Power mailing list
[email protected]
http://www.bughost.org/mailman/listinfo/power

Reply via email to