diff options
Diffstat (limited to 'sysutils')
-rw-r--r-- | sysutils/ganglia-monitor-core/Makefile | 2 | ||||
-rw-r--r-- | sysutils/ganglia-monitor-core/files/patch-libmetrics_freebsd_metrics.c | 37 |
2 files changed, 30 insertions, 9 deletions
diff --git a/sysutils/ganglia-monitor-core/Makefile b/sysutils/ganglia-monitor-core/Makefile index 3e60b06e70c6..e97dd30dbf44 100644 --- a/sysutils/ganglia-monitor-core/Makefile +++ b/sysutils/ganglia-monitor-core/Makefile @@ -7,7 +7,7 @@ PORTNAME= monitor-core PORTVERSION= 3.1.1 -PORTREVISION= 6 +PORTREVISION= 7 CATEGORIES= sysutils net parallel MASTER_SITES= SF/ganglia/ganglia%20monitoring%20core/${PORTVERSION}%20%28Wien%29 PKGNAMEPREFIX= ganglia- 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 3fd55f70e5d6..771b12e776bd 100644 --- a/sysutils/ganglia-monitor-core/files/patch-libmetrics_freebsd_metrics.c +++ b/sysutils/ganglia-monitor-core/files/patch-libmetrics_freebsd_metrics.c @@ -1,5 +1,8 @@ ---- 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 + +$FreeBSD$ + +--- libmetrics/freebsd/metrics.c.orig ++++ libmetrics/freebsd/metrics.c @@ -106,7 +106,7 @@ static size_t mibswap_size; static kvm_t *kd = NULL; @@ -28,7 +31,25 @@ /* * If the system supports it, the cpufreq driver provides the best -@@ -881,7 +893,6 @@ +@@ -529,6 +541,17 @@ + goto output; + + for (i = 0; i < nentries; kp++, i++) { ++ /* This is a per-CPU idle thread. */ /* idle thread */ ++ if ((kp->ki_tdflags & TDF_IDLETD) != 0) ++ continue; ++ /* Ignore during load avg calculations. */ /* swi or idle thead */ ++#ifdef TDF_NOLOAD ++ /* Introduced in FreeBSD 8.3 */ ++ if ((kp->ki_tdflags & TDF_NOLOAD) != 0) ++#else ++ if ((kp->ki_flag & P_NOLOAD) != 0) ++#endif ++ continue; + #ifdef KINFO_PROC_SIZE + state = kp->ki_stat; + #else +@@ -881,7 +904,6 @@ netvfslist = makenetvfslist(); vfslist = makevfslist(netvfslist); @@ -36,7 +57,7 @@ mntsize = getmntinfo(&mntbuf, MNT_NOWAIT); mntsize = regetmntinfo(&mntbuf, mntsize, vfslist); -@@ -899,6 +910,8 @@ +@@ -899,6 +921,8 @@ *tot_avail += mntbuf[i].f_bavail / toru; } } @@ -45,7 +66,7 @@ return most_full; } -@@ -955,7 +968,7 @@ +@@ -955,7 +979,7 @@ return (NULL); if (fslist[0] == 'n' && fslist[1] == 'o') { fslist += 2; @@ -54,7 +75,7 @@ } for (i = 0, nextcp = fslist; *nextcp; nextcp++) if (*nextcp == ',') -@@ -1007,7 +1020,10 @@ +@@ -1007,7 +1031,10 @@ goto done; } @@ -66,7 +87,7 @@ if (xvfsp->vfc_flags & VFCF_NONLOCAL) continue; -@@ -1057,10 +1073,13 @@ +@@ -1057,10 +1084,13 @@ * Count up the string lengths, we need a extra byte to hold * the between entries ',' or the NUL at the end. */ @@ -83,7 +104,7 @@ if ((str = malloc(slen)) == NULL) { warnx("malloc failed"); -@@ -1069,10 +1088,11 @@ +@@ -1069,10 +1099,11 @@ str[0] = 'n'; str[1] = 'o'; |