aboutsummaryrefslogtreecommitdiffstats
path: root/sysutils
diff options
context:
space:
mode:
authormarcel <marcel@FreeBSD.org>2010-01-04 04:07:57 +0800
committermarcel <marcel@FreeBSD.org>2010-01-04 04:07:57 +0800
commit8c284195875bce931a9e67a9345473eb12c785f9 (patch)
tree93bbcc7ad25b542016fd1cf0f875bf489dec6ffc /sysutils
parentf4f559cba74425d7e85a5a49aa938032cbe77e92 (diff)
downloadfreebsd-ports-gnome-8c284195875bce931a9e67a9345473eb12c785f9.tar.gz
freebsd-ports-gnome-8c284195875bce931a9e67a9345473eb12c785f9.tar.zst
freebsd-ports-gnome-8c284195875bce931a9e67a9345473eb12c785f9.zip
Query the generic "hw.freq.cpu" sysctl before using i386/amd64
specific ones to obtain the CPU frequency. This fixes CPU frequency reporting for ia64 & sparc64.
Diffstat (limited to 'sysutils')
-rw-r--r--sysutils/ganglia-monitor-core/files/patch-libmetrics_freebsd_metrics.c38
1 files changed, 27 insertions, 11 deletions
diff --git a/sysutils/ganglia-monitor-core/files/patch-libmetrics_freebsd_metrics.c b/sysutils/ganglia-monitor-core/files/patch-libmetrics_freebsd_metrics.c
index d92d1c35a8cd..3fd55f70e5d6 100644
--- a/sysutils/ganglia-monitor-core/files/patch-libmetrics_freebsd_metrics.c
+++ b/sysutils/ganglia-monitor-core/files/patch-libmetrics_freebsd_metrics.c
@@ -1,8 +1,5 @@
-
-$FreeBSD$
-
---- libmetrics/freebsd/metrics.c.orig
-+++ libmetrics/freebsd/metrics.c
+--- libmetrics/freebsd/metrics.c.orig 2010-01-03 20:00:03.213056511 +0000
++++ libmetrics/freebsd/metrics.c 2010-01-03 20:00:14.482769820 +0000
@@ -106,7 +106,7 @@
static size_t mibswap_size;
static kvm_t *kd = NULL;
@@ -12,7 +9,26 @@ $FreeBSD$
/* Function prototypes */
static long percentages(int cnt, int *out, register long *new,
-@@ -881,7 +881,6 @@
+@@ -170,6 +170,18 @@
+ size_t len;
+ uint32_t freq = 0, tmpfreq;
+ uint64_t tscfreq;
++ unsigned int cpu_freq;
++
++ /*
++ * Try the portable sysctl (introduced on ia64).
++ */
++ cpu_freq = 0;
++ len = sizeof(cpu_freq);
++ if (sysctlbyname("hw.freq.cpu", &cpu_freq, &len, NULL, 0) != -1 &&
++ cpu_freq != 0) {
++ freq = cpu_freq;
++ goto done;
++ }
+
+ /*
+ * If the system supports it, the cpufreq driver provides the best
+@@ -881,7 +893,6 @@
netvfslist = makenetvfslist();
vfslist = makevfslist(netvfslist);
@@ -20,7 +36,7 @@ $FreeBSD$
mntsize = getmntinfo(&mntbuf, MNT_NOWAIT);
mntsize = regetmntinfo(&mntbuf, mntsize, vfslist);
-@@ -899,6 +898,8 @@
+@@ -899,6 +910,8 @@
*tot_avail += mntbuf[i].f_bavail / toru;
}
}
@@ -29,7 +45,7 @@ $FreeBSD$
return most_full;
}
-@@ -955,7 +956,7 @@
+@@ -955,7 +968,7 @@
return (NULL);
if (fslist[0] == 'n' && fslist[1] == 'o') {
fslist += 2;
@@ -38,7 +54,7 @@ $FreeBSD$
}
for (i = 0, nextcp = fslist; *nextcp; nextcp++)
if (*nextcp == ',')
-@@ -1007,7 +1008,10 @@
+@@ -1007,7 +1020,10 @@
goto done;
}
@@ -50,7 +66,7 @@ $FreeBSD$
if (xvfsp->vfc_flags & VFCF_NONLOCAL)
continue;
-@@ -1057,10 +1061,13 @@
+@@ -1057,10 +1073,13 @@
* Count up the string lengths, we need a extra byte to hold
* the between entries ',' or the NUL at the end.
*/
@@ -67,7 +83,7 @@ $FreeBSD$
if ((str = malloc(slen)) == NULL) {
warnx("malloc failed");
-@@ -1069,10 +1076,11 @@
+@@ -1069,10 +1088,11 @@
str[0] = 'n';
str[1] = 'o';