projects
/
collectd.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Merge branch 'master' into processes
[collectd.git]
/
src
/
cpufreq.c
diff --git
a/src/cpufreq.c
b/src/cpufreq.c
index
92f1cc5
..
ba0149a
100644
(file)
--- a/
src/cpufreq.c
+++ b/
src/cpufreq.c
@@
-1,6
+1,6
@@
/**
* collectd - src/cpufreq.c
/**
* collectd - src/cpufreq.c
- * Copyright (C) 2005 Peter Holik
+ * Copyright (C) 2005
,2006
Peter Holik
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the
@@
-26,11
+26,17
@@
#define MODULE_NAME "cpufreq"
#define MODULE_NAME "cpufreq"
+#if defined(KERNEL_LINUX)
+# define CPUFREQ_HAVE_READ 1
+#else
+# define CPUFREQ_HAVE_READ 0
+#endif
+
static char *cpufreq_file = "cpufreq-%s.rrd";
static char *ds_def[] =
{
static char *cpufreq_file = "cpufreq-%s.rrd";
static char *ds_def[] =
{
- "DS:value:GAUGE:
25
:0:U",
+ "DS:value:GAUGE:
"COLLECTD_HEARTBEAT"
:0:U",
NULL
};
static int ds_num = 1;
NULL
};
static int ds_num = 1;
@@
-51,7
+57,7
@@
static void cpufreq_init (void)
while (1)
{
while (1)
{
- status = snprintf (filename, BUFSIZE, "/sys/devices/system/cpu/cpu%d/cpufreq/
cpuinfo
_cur_freq", num_cpu);
+ status = snprintf (filename, BUFSIZE, "/sys/devices/system/cpu/cpu%d/cpufreq/
scaling
_cur_freq", num_cpu);
if (status < 1 || status >= BUFSIZE)
break;
if (status < 1 || status >= BUFSIZE)
break;
@@
-79,6
+85,7
@@
static void cpufreq_write (char *host, char *inst, char *val)
rrd_update_file (host, file, val, ds_def, ds_num);
}
rrd_update_file (host, file, val, ds_def, ds_num);
}
+#if CPUFREQ_HAVE_READ
static void cpufreq_submit (int cpu_num, unsigned long long val)
{
char buf[BUFSIZE];
static void cpufreq_submit (int cpu_num, unsigned long long val)
{
char buf[BUFSIZE];
@@
-103,7
+110,7
@@
static void cpufreq_read (void)
for (i = 0; i < num_cpu; i++)
{
for (i = 0; i < num_cpu; i++)
{
- status = snprintf (filename, BUFSIZE, "/sys/devices/system/cpu/cpu%d/cpufreq/
cpuinfo
_cur_freq", i);
+ status = snprintf (filename, BUFSIZE, "/sys/devices/system/cpu/cpu%d/cpufreq/
scaling
_cur_freq", i);
if (status < 1 || status >= BUFSIZE)
return;
if (status < 1 || status >= BUFSIZE)
return;
@@
-116,6
+123,7
@@
static void cpufreq_read (void)
if (fgets (buffer, 16, fp) == NULL)
{
syslog (LOG_WARNING, "cpufreq: fgets: %s", strerror (errno));
if (fgets (buffer, 16, fp) == NULL)
{
syslog (LOG_WARNING, "cpufreq: fgets: %s", strerror (errno));
+ fclose (fp);
return;
}
return;
}
@@
-131,6
+139,9
@@
static void cpufreq_read (void)
return;
}
return;
}
+#else
+#define cpufreq_read NULL
+#endif
#undef BUFSIZE
void module_register (void)
#undef BUFSIZE
void module_register (void)