aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorkrion <krion@FreeBSD.org>2003-11-09 00:15:15 +0800
committerkrion <krion@FreeBSD.org>2003-11-09 00:15:15 +0800
commit11b6d049c7e780dc608982d78140a46a794da3d5 (patch)
tree26cc914ac7950126281dbb1e4ca55ec3c232ae03
parentf9da175d1c378ca5d5399e0b53825bd28353667e (diff)
downloadfreebsd-ports-graphics-11b6d049c7e780dc608982d78140a46a794da3d5.tar.gz
freebsd-ports-graphics-11b6d049c7e780dc608982d78140a46a794da3d5.tar.zst
freebsd-ports-graphics-11b6d049c7e780dc608982d78140a46a794da3d5.zip
- Update to version 2.5.5 [1]
* integrates a number of FreeBSD enhancements and fixes a DoS bug - Respect PTHREAD_LIBS and PTHREAD_CFLAGS [2] PR: 59049 Submitted by: brooks [1], krion [2]
-rw-r--r--sysutils/ganglia-monitor-core/Makefile9
-rw-r--r--sysutils/ganglia-monitor-core/distinfo2
-rw-r--r--sysutils/ganglia-monitor-core/files/patch-config.h.in16
-rw-r--r--sysutils/ganglia-monitor-core/files/patch-configure14
-rw-r--r--sysutils/ganglia-monitor-core/files/patch-gmond_key__metrics.h21
-rw-r--r--sysutils/ganglia-monitor-core/files/patch-gmond_machines_freebsd.c748
-rw-r--r--sysutils/ganglia-monitor-core/files/patch-gmond_metric.h65
-rw-r--r--sysutils/ganglia-monitor-core/files/patch-lib_ganglia_net.h14
-rw-r--r--sysutils/ganglia-monitor-core/pkg-plist3
9 files changed, 9 insertions, 883 deletions
diff --git a/sysutils/ganglia-monitor-core/Makefile b/sysutils/ganglia-monitor-core/Makefile
index 52e4d38ec6c..d9a408f46a0 100644
--- a/sysutils/ganglia-monitor-core/Makefile
+++ b/sysutils/ganglia-monitor-core/Makefile
@@ -6,7 +6,7 @@
#
PORTNAME= ganglia-monitor-core
-PORTVERSION= 2.5.4
+PORTVERSION= 2.5.5
CATEGORIES= sysutils net parallel
MASTER_SITES= ${MASTER_SITE_SOURCEFORGE}
MASTER_SITE_SUBDIR= ganglia
@@ -22,8 +22,10 @@ LIB_DEPENDS= rrd.0:${PORTSDIR}/net/rrdtool
.endif
GNU_CONFIGURE= yes
-CONFIGURE_ENV= CPPFLAGS="-I${LOCALBASE}/include" \
- LIBS="-L${LOCALBASE}/lib"
+CONFIGURE_ENV= CPPFLAGS="${CPPFLAGS}" LDFLAGS="${LDFLAGS}"
+CPPFLAGS= -I${LOCALBASE}/include ${PTHREAD_CFLAGS}
+LDFLAGS= -L${LOCALBASE}/lib ${PTHREAD_LIBS}
+
.if !defined (WITHOUT_GMETAD)
CONFIGURE_ARGS+= --with-gmetad
.endif
@@ -59,6 +61,7 @@ post-patch:
${FIX_CONF_FILES}
${REINPLACE_CMD} -e "s|/var/lib/ganglia|/var/db/ganglia|g" \
${FIX_DB_FILES}
+ ${REINPLACE_CMD} -e 's|-pthread||g' ${WRKSRC}/configure
# Post-install
#
diff --git a/sysutils/ganglia-monitor-core/distinfo b/sysutils/ganglia-monitor-core/distinfo
index 263b4f4a515..c519ecd5989 100644
--- a/sysutils/ganglia-monitor-core/distinfo
+++ b/sysutils/ganglia-monitor-core/distinfo
@@ -1 +1 @@
-MD5 (ganglia-monitor-core-2.5.4.tar.gz) = 354b18077ba33738af5bcb9539ae854d
+MD5 (ganglia-monitor-core-2.5.5.tar.gz) = dd26e770b7d06e6252875c8d81fa06bc
diff --git a/sysutils/ganglia-monitor-core/files/patch-config.h.in b/sysutils/ganglia-monitor-core/files/patch-config.h.in
deleted file mode 100644
index f094dc027b6..00000000000
--- a/sysutils/ganglia-monitor-core/files/patch-config.h.in
+++ /dev/null
@@ -1,16 +0,0 @@
-
-$FreeBSD$
-
---- config.h.in.orig Tue Oct 28 14:41:30 2003
-+++ config.h.in Tue Oct 28 14:41:41 2003
-@@ -3,8 +3,8 @@
- /* AIX */
- #undef AIX
-
--/* BSD */
--#undef BSD
-+/* FREEBSD */
-+#undef FREEBSD
-
- /* CPU_VENDOR_OS */
- #undef CPU_VENDOR_OS
diff --git a/sysutils/ganglia-monitor-core/files/patch-configure b/sysutils/ganglia-monitor-core/files/patch-configure
deleted file mode 100644
index 6e977ba1b3c..00000000000
--- a/sysutils/ganglia-monitor-core/files/patch-configure
+++ /dev/null
@@ -1,14 +0,0 @@
-
-$FreeBSD$
-
---- configure.orig Mon Oct 27 16:51:34 2003
-+++ configure Mon Oct 27 16:52:23 2003
-@@ -11458,7 +11458,7 @@
-
-
- cat >>confdefs.h <<\_ACEOF
--#define BSD 1
-+#define FREEBSD 1
- _ACEOF
- ;;
- *cygwin*) metric_source="cygwin.c"
diff --git a/sysutils/ganglia-monitor-core/files/patch-gmond_key__metrics.h b/sysutils/ganglia-monitor-core/files/patch-gmond_key__metrics.h
deleted file mode 100644
index ad0b44ce728..00000000000
--- a/sysutils/ganglia-monitor-core/files/patch-gmond_key__metrics.h
+++ /dev/null
@@ -1,21 +0,0 @@
-
-$FreeBSD$
-
---- gmond/key_metrics.h.orig Mon Oct 27 16:47:42 2003
-+++ gmond/key_metrics.h Mon Oct 27 16:48:12 2003
-@@ -69,6 +69,15 @@
- cpu_avm,
- cpu_vm,
- #endif
-+#ifdef FREEBSD
-+ bytes_in,
-+ bytes_out,
-+ pkts_in,
-+ pkts_out,
-+ disk_total,
-+ disk_free,
-+ part_max_used,
-+#endif
- num_key_metrics
- } key_metrics;
- #endif
diff --git a/sysutils/ganglia-monitor-core/files/patch-gmond_machines_freebsd.c b/sysutils/ganglia-monitor-core/files/patch-gmond_machines_freebsd.c
deleted file mode 100644
index 3916982f264..00000000000
--- a/sysutils/ganglia-monitor-core/files/patch-gmond_machines_freebsd.c
+++ /dev/null
@@ -1,748 +0,0 @@
-
-$FreeBSD$
-
---- gmond/machines/freebsd.c.orig Tue Jul 29 10:56:38 2003
-+++ gmond/machines/freebsd.c Mon Oct 27 17:02:26 2003
-@@ -9,9 +9,11 @@
- */
-
- #include <kvm.h>
--#include <fcntl.h>
-+
- #include <sys/param.h>
-+#include <sys/mount.h>
- #include <sys/sysctl.h>
-+#include <sys/time.h>
- #include <sys/user.h>
- #if __FreeBSD_version < 500101
- #include <sys/dkstat.h>
-@@ -20,12 +22,35 @@
- #endif
- #include <sys/stat.h>
- #include <vm/vm_param.h>
-+
-+#include <sys/socket.h>
-+#include <net/if.h>
-+#include <net/if_dl.h>
-+#include <net/route.h>
-+
- #include <unistd.h>
-+#include <err.h>
-+#include <fcntl.h>
-+#include <limits.h>
-+#include <paths.h>
-+
-+#include "dnet.h"
- #include "ganglia.h"
- #include "metric_typedefs.h"
-
- #define MIB_SWAPINFO_SIZE 3
-
-+#ifndef MIN_NET_POLL_INTERVAL
-+#define MIN_NET_POLL_INTERVAL 0.5
-+#endif
-+
-+#ifndef UINT64_MAX
-+#define UINT64_MAX ULLONG_MAX
-+#endif
-+
-+#define timertod(tvp) \
-+ ((double)(tvp)->tv_sec + (double)(tvp)->tv_usec/(1000*1000))
-+
- #ifndef XSWDEV_VERSION
- #define XSWDEV_VERSION 1
- struct xswdev {
-@@ -37,14 +62,32 @@
- };
- #endif
-
-+struct traffic {
-+ uint64_t in_bytes;
-+ uint64_t out_bytes;
-+ uint64_t in_pkts;
-+ uint64_t out_pkts;
-+};
-+
-+static void get_netbw(double *, double *, double *, double *);
-+static uint64_t counterdiff(uint64_t, uint64_t, uint64_t, uint64_t);
-+
-+
-+static char *makenetvfslist(void);
-+static size_t regetmntinfo(struct statfs **, long, const char **);
-+static int checkvfsname(const char *, const char **);
-+static const char **makevfslist(char *);
-+static float find_disk_space(double *, double *);
-+
- static int use_vm_swap_info = 0;
- static int mibswap[MIB_SWAPINFO_SIZE];
- static size_t mibswap_size;
- static kvm_t *kd = NULL;
- static int pagesize;
-+static int skipvfs;
-
- /* Function prototypes */
--long percentages(int cnt, int *out, register long *new,
-+static long percentages(int cnt, int *out, register long *new,
- register long *old, long *diffs);
-
- /*
-@@ -64,10 +107,25 @@
- if (sysctlnametomib("vm.swap_info", mibswap, &mibswap_size) == -1) {
- kd = kvm_open(NULL, NULL, NULL, O_RDONLY, "metric_init()");
- } else {
-+ /*
-+ * Versions of FreeBSD with the swap mib generally have a version
-+ * of libkvm that doesn't need root for simple proc access so we
-+ * just open /dev/null to give us a working handle here. This is
-+ * bogus, but only a few pre-release versions of 5.0 are
-+ * affected by the bogosity and people running those should
-+ * upgrade.
-+ */
-+ kd = kvm_open(_PATH_DEVNULL, NULL, NULL, O_RDONLY, "metric_init()");
- use_vm_swap_info = 1;
- }
- pagesize = getpagesize();
-
-+ /*
-+ * Call get_netbw once to initalize the counters.
-+ */
-+
-+ get_netbw(NULL, NULL, NULL, NULL);
-+
- val.int32 = SYNAPSE_SUCCESS;
- return val;
- }
-@@ -124,7 +182,7 @@
- g_val_t val;
- struct kvm_swap swap[1];
- struct xswdev xsw;
-- size_t mibsize, size;
-+ size_t size;
- int totswap, n;
- val.uint32 = 0;
- totswap = 0;
-@@ -366,9 +424,41 @@
- g_val_t
- proc_run_func( void )
- {
-+ struct kinfo_proc *kp;
-+ int i;
-+ int state;
-+ int nentries;
-+ int what = KERN_PROC_ALL;
- g_val_t val;
-
- val.uint32 = 0;
-+
-+ if (kd == NULL)
-+ goto output;
-+#ifdef KERN_PROC_NOTHREADS
-+ what |= KERN_PROC_NOTHREADS
-+#endif
-+ if ((kp = kvm_getprocs(kd, what, 0, &nentries)) == 0 || nentries < 0)
-+ goto output;
-+
-+ for (i = 0; i < nentries; kp++, i++) {
-+#ifdef KINFO_PROC_SIZE
-+ state = kp->ki_stat;
-+#else
-+ state = kp->kp_proc.p_stat;
-+#endif
-+ switch(state) {
-+ case SRUN:
-+ case SIDL:
-+ val.uint32++;
-+ break;
-+ }
-+ }
-+
-+ if (val.uint32 > 0)
-+ val.uint32--;
-+
-+output:
- return val;
- }
-
-@@ -461,7 +551,6 @@
- return val;
- }
-
--#include "dnet.h"
-
- static int
- find_mtu(const struct intf_entry *entry, void *arg)
-@@ -509,8 +598,8 @@
- * $FreeBSD$
- */
-
--long percentages(int cnt, int *out, register long *new,
-- register long *old, long *diffs) {
-+static long percentages(int cnt, int *out, register long *new,
-+ register long *old, long *diffs) {
-
- register int i;
- register long change;
-@@ -549,3 +638,563 @@
- return(total_change);
- }
-
-+g_val_t
-+pkts_in_func ( void )
-+{
-+ double in_pkts;
-+ g_val_t val;
-+
-+ get_netbw(NULL, NULL, &in_pkts, NULL);
-+
-+ val.f = (float)in_pkts;
-+ return val;
-+}
-+
-+g_val_t
-+pkts_out_func ( void )
-+{
-+ double out_pkts;
-+ g_val_t val;
-+
-+ get_netbw(NULL, NULL, NULL, &out_pkts);
-+
-+ val.f = (float)out_pkts;
-+ return val;
-+}
-+
-+g_val_t
-+bytes_out_func ( void )
-+{
-+ double out_bytes;
-+ g_val_t val;
-+
-+ get_netbw(NULL, &out_bytes, NULL, NULL);
-+
-+ val.f = (float)out_bytes;
-+ return val;
-+}
-+
-+g_val_t
-+bytes_in_func ( void )
-+{
-+ double in_bytes;
-+ g_val_t val;
-+
-+ get_netbw(&in_bytes, NULL, NULL, NULL);
-+
-+ val.f = (float)in_bytes;
-+ return val;
-+}
-+
-+/*
-+ * Disk space reporting functions from Linux code. find_disk_space()
-+ * body derived from FreeBSD df and mount code.
-+ */
-+
-+g_val_t
-+disk_free_func( void )
-+{
-+ double total_free=0.0;
-+ double total_size=0.0;
-+ g_val_t val;
-+
-+ find_disk_space(&total_size, &total_free);
-+
-+ val.d = total_free;
-+ return val;
-+}
-+
-+g_val_t
-+disk_total_func( void )
-+{
-+ double total_free=0.0;
-+ double total_size=0.0;
-+ g_val_t val;
-+
-+ find_disk_space(&total_size, &total_free);
-+
-+ val.d = total_size;
-+ return val;
-+}
-+
-+g_val_t
-+part_max_used_func( void )
-+{
-+ double total_free=0.0;
-+ double total_size=0.0;
-+ float most_full;
-+ g_val_t val;
-+
-+ most_full = find_disk_space(&total_size, &total_free);
-+
-+ val.f = most_full;
-+ return val;
-+}
-+
-+
-+/*
-+ * Copyright (c) 1980, 1983, 1990, 1993, 1994, 1995
-+ * The Regents of the University of California. All rights reserved.
-+ * (c) UNIX System Laboratories, Inc.
-+ * All or some portions of this file are derived from material licensed
-+ * to the University of California by American Telephone and Telegraph
-+ * Co. or Unix System Laboratories, Inc. and are reproduced herein with
-+ * the permission of UNIX System Laboratories, Inc.
-+ *
-+ * Redistribution and use in source and binary forms, with or without
-+ * modification, are permitted provided that the following conditions
-+ * are met:
-+ * 1. Redistributions of source code must retain the above copyright
-+ * notice, this list of conditions and the following disclaimer.
-+ * 2. Redistributions in binary form must reproduce the above copyright
-+ * notice, this list of conditions and the following disclaimer in the
-+ * documentation and/or other materials provided with the distribution.
-+ * 3. All advertising materials mentioning features or use of this software
-+ * must display the following acknowledgement:
-+ * This product includes software developed by the University of
-+ * California, Berkeley and its contributors.
-+ * 4. Neither the name of the University nor the names of its contributors
-+ * may be used to endorse or promote products derived from this software
-+ * without specific prior written permission.
-+ *
-+ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
-+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
-+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
-+ * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
-+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
-+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
-+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
-+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
-+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
-+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
-+ * SUCH DAMAGE.
-+ *
-+ *
-+ * NOTE: The copyright of UC Berkeley's Berkeley Software Distribution
-+ * ("BSD") source has been updated. The copyright addendum may be found
-+ * at ftp://ftp.cs.berkeley.edu/pub/4bsd/README.Impt.License.Change.
-+ */
-+
-+
-+
-+static float
-+find_disk_space(double *total, double *tot_avail)
-+{
-+ struct statfs *mntbuf;
-+ const char *fstype;
-+ const char **vfslist;
-+ size_t i, mntsize;
-+ size_t used, availblks;
-+ const double reported_units = 1e9;
-+ double toru;
-+ float pct;
-+ float most_full = 0.0;
-+
-+ *total = 0.0;
-+ *tot_avail = 0.0;
-+
-+ fstype = "ufs";
-+
-+ vfslist = makevfslist(makenetvfslist());
-+
-+ mntsize = getmntinfo(&mntbuf, MNT_NOWAIT);
-+ mntsize = regetmntinfo(&mntbuf, mntsize, vfslist);
-+ for (i = 0; i < mntsize; i++) {
-+ if ((mntbuf[i].f_flags & MNT_IGNORE) == 0) {
-+ used = mntbuf[i].f_blocks - mntbuf[i].f_bfree;
-+ availblks = mntbuf[i].f_bavail + used;
-+ pct = (availblks == 0 ? 100.0 :
-+ (double)used / (double)availblks * 100.0);
-+ if (pct > most_full)
-+ most_full = pct;
-+
-+ toru = reported_units/mntbuf[i].f_bsize;
-+ *total += mntbuf[i].f_blocks / toru;
-+ *tot_avail += mntbuf[i].f_bavail / toru;
-+ }
-+ }
-+
-+ return most_full;
-+}
-+
-+/*
-+ * Make a pass over the file system info in ``mntbuf'' filtering out
-+ * file system types not in vfslist and possibly re-stating to get
-+ * current (not cached) info. Returns the new count of valid statfs bufs.
-+ */
-+static size_t
-+regetmntinfo(struct statfs **mntbufp, long mntsize, const char **vfslist)
-+{
-+ int i, j;
-+ struct statfs *mntbuf;
-+
-+ if (vfslist == NULL)
-+ return (getmntinfo(mntbufp, MNT_WAIT));
-+
-+ mntbuf = *mntbufp;
-+ for (j = 0, i = 0; i < mntsize; i++) {
-+ if (checkvfsname(mntbuf[i].f_fstypename, vfslist))
-+ continue;
-+ (void)statfs(mntbuf[i].f_mntonname,&mntbuf[j]);
-+ j++;
-+ }
-+ return (j);
-+}
-+
-+static int
-+checkvfsname(vfsname, vfslist)
-+ const char *vfsname;
-+ const char **vfslist;
-+{
-+
-+ if (vfslist == NULL)
-+ return (0);
-+ while (*vfslist != NULL) {
-+ if (strcmp(vfsname, *vfslist) == 0)
-+ return (skipvfs);
-+ ++vfslist;
-+ }
-+ return (!skipvfs);
-+}
-+
-+static const char **
-+makevfslist(fslist)
-+ char *fslist;
-+{
-+ const char **av;
-+ int i;
-+ char *nextcp;
-+
-+ if (fslist == NULL)
-+ return (NULL);
-+ if (fslist[0] == 'n' && fslist[1] == 'o') {
-+ fslist += 2;
-+ skipvfs = 1;
-+ }
-+ for (i = 0, nextcp = fslist; *nextcp; nextcp++)
-+ if (*nextcp == ',')
-+ i++;
-+ if ((av = malloc((size_t)(i + 2) * sizeof(char *))) == NULL) {
-+ warnx("malloc failed");
-+ return (NULL);
-+ }
-+ nextcp = fslist;
-+ i = 0;
-+ av[i++] = nextcp;
-+ while ((nextcp = strchr(nextcp, ',')) != NULL) {
-+ *nextcp++ = '\0';
-+ av[i++] = nextcp;
-+ }
-+ av[i++] = NULL;
-+ return (av);
-+}
-+
-+static char *
-+makenetvfslist(void)
-+{
-+#if __FreeBSD_version > 500000
-+ char *str, *strptr, **listptr;
-+ struct xvfsconf *xvfsp, *keep_xvfsp;
-+ size_t buflen;
-+ int cnt, i, maxvfsconf;
-+
-+ if (sysctlbyname("vfs.conflist", NULL, &buflen, NULL, 0) < 0) {
-+ warn("sysctl(vfs.conflist)");
-+ return (NULL);
-+ }
-+ xvfsp = malloc(buflen);
-+ if (xvfsp == NULL) {
-+ warnx("malloc failed");
-+ return (NULL);
-+ }
-+ keep_xvfsp = xvfsp;
-+ if (sysctlbyname("vfs.conflist", xvfsp, &buflen, NULL, 0) < 0) {
-+ warn("sysctl(vfs.conflist)");
-+ free(keep_xvfsp);
-+ return (NULL);
-+ }
-+ maxvfsconf = buflen / sizeof(struct xvfsconf);
-+
-+ if ((listptr = malloc(sizeof(char*) * maxvfsconf)) == NULL) {
-+ warnx("malloc failed");
-+ free(keep_xvfsp);
-+ return (NULL);
-+ }
-+
-+ for (cnt = 0, i = 0; i < maxvfsconf; i++) {
-+ if (xvfsp->vfc_flags & (VFCF_NETWORK|VFCF_SYNTHETIC|VFCF_LOOPBACK)) {
-+ listptr[cnt++] = strdup(xvfsp->vfc_name);
-+ if (listptr[cnt-1] == NULL) {
-+ warnx("malloc failed");
-+ free(listptr);
-+ free(keep_xvfsp);
-+ return (NULL);
-+ }
-+ }
-+ xvfsp++;
-+ }
-+
-+ if (cnt == 0 ||
-+ (str = malloc(sizeof(char) * (32 * cnt + cnt + 2))) == NULL) {
-+ if (cnt > 0)
-+ warnx("malloc failed");
-+ free(listptr);
-+ free(keep_xvfsp);
-+ return (NULL);
-+ }
-+
-+ *str = 'n'; *(str + 1) = 'o';
-+ for (i = 0, strptr = str + 2; i < cnt; i++, strptr++) {
-+ strncpy(strptr, listptr[i], 32);
-+ strptr += strlen(listptr[i]);
-+ *strptr = ',';
-+ free(listptr[i]);
-+ }
-+ *(--strptr) = NULL;
-+
-+ free(keep_xvfsp);
-+#else
-+ char *str, *strptr, **listptr;
-+ int mib[3], maxvfsconf, cnt=0, i;
-+ size_t miblen;
-+ struct ovfsconf *ptr;
-+
-+ mib[0] = CTL_VFS; mib[1] = VFS_GENERIC; mib[2] = VFS_MAXTYPENUM;
-+ miblen=sizeof(maxvfsconf);
-+ if (sysctl(mib, (unsigned int)(sizeof(mib) / sizeof(mib[0])),
-+ &maxvfsconf, &miblen, NULL, 0)) {
-+ warnx("sysctl failed");
-+ return (NULL);
-+ }
-+
-+ if ((listptr = malloc(sizeof(char*) * maxvfsconf)) == NULL) {
-+ warnx("malloc failed");
-+ return (NULL);
-+ }
-+
-+ for (ptr = getvfsent(); ptr; ptr = getvfsent())
-+ if (ptr->vfc_flags & (VFCF_NETWORK|VFCF_SYNTHETIC|VFCF_LOOPBACK)) {
-+ listptr[cnt++] = strdup(ptr->vfc_name);
-+ if (listptr[cnt-1] == NULL) {
-+ warnx("malloc failed");
-+ return (NULL);
-+ }
-+ }
-+
-+ if (cnt == 0 ||
-+ (str = malloc(sizeof(char) * (32 * cnt + cnt + 2))) == NULL) {
-+ if (cnt > 0)
-+ warnx("malloc failed");
-+ free(listptr);
-+ return (NULL);
-+ }
-+
-+ *str = 'n'; *(str + 1) = 'o';
-+ for (i = 0, strptr = str + 2; i < cnt; i++, strptr++) {
-+ strncpy(strptr, listptr[i], 32);
-+ strptr += strlen(listptr[i]);
-+ *strptr = ',';
-+ free(listptr[i]);
-+ }
-+ *(--strptr) = NULL;
-+
-+#endif
-+ free(listptr);
-+ return (str);
-+
-+}
-+
-+static void
-+get_netbw(double *in_bytes, double *out_bytes,
-+ double *in_pkts, double *out_pkts)
-+{
-+#ifdef NETBW_DEBUG
-+ char name[IFNAMSIZ];
-+#endif
-+ struct if_msghdr *ifm, *nextifm;
-+ struct sockaddr_dl *sdl;
-+ char *buf, *lim, *next;
-+ size_t needed;
-+ int mib[6];
-+ int i;
-+ int index;
-+ static double ibytes, obytes, ipkts, opkts;
-+ struct timeval this_time;
-+ struct timeval time_diff;
-+ struct traffic traffic;
-+ static struct timeval last_time = {0,0};
-+ static int indexes = 0;
-+ static int *seen = NULL;
-+ static struct traffic *lastcount = NULL;
-+ static double o_ibytes, o_obytes, o_ipkts, o_opkts;
-+
-+ ibytes = obytes = ipkts = opkts = 0.0;
-+
-+ mib[0] = CTL_NET;
-+ mib[1] = PF_ROUTE;
-+ mib[2] = 0;
-+ mib[3] = 0; /* address family */
-+ mib[4] = NET_RT_IFLIST;
-+ mib[5] = 0; /* interface index */
-+
-+ gettimeofday(&this_time, NULL);
-+ timersub(&this_time, &last_time, &time_diff);
-+ if (timertod(&time_diff) < MIN_NET_POLL_INTERVAL) {
-+ goto output;
-+ }
-+
-+
-+ if (sysctl(mib, 6, NULL, &needed, NULL, 0) < 0)
-+ errx(1, "iflist-sysctl-estimate");
-+ if ((buf = malloc(needed)) == NULL)
-+ errx(1, "malloc");
-+ if (sysctl(mib, 6, buf, &needed, NULL, 0) < 0)
-+ errx(1, "actual retrieval of interface table");
-+ lim = buf + needed;
-+
-+ next = buf;
-+ while (next < lim) {
-+
-+ ifm = (struct if_msghdr *)next;
-+
-+ if (ifm->ifm_type == RTM_IFINFO) {
-+ sdl = (struct sockaddr_dl *)(ifm + 1);
-+ } else {
-+ fprintf(stderr, "out of sync parsing NET_RT_IFLIST\n");
-+ fprintf(stderr, "expected %d, got %d\n", RTM_IFINFO,
-+ ifm->ifm_type);
-+ fprintf(stderr, "msglen = %d\n", ifm->ifm_msglen);
-+ fprintf(stderr, "buf:%p, next:%p, lim:%p\n", buf, next,
-+ lim);
-+ exit (1);
-+ }
-+
-+ next += ifm->ifm_msglen;
-+ while (next < lim) {
-+ nextifm = (struct if_msghdr *)next;
-+
-+ if (nextifm->ifm_type != RTM_NEWADDR)
-+ break;
-+
-+ next += nextifm->ifm_msglen;
-+ }
-+
-+ if ((ifm->ifm_flags & IFF_LOOPBACK) ||
-+ !(ifm->ifm_flags & IFF_UP))
-+ continue;
-+
-+ index = ifm->ifm_index;
-+
-+ /* If we don't have a previous value yet, make a slot. */
-+ if (index >= indexes) {
-+ seen = realloc(seen, sizeof(*seen)*(index+1));
-+ lastcount = realloc(lastcount,
-+ sizeof(*lastcount)*(index+1));
-+
-+ /* Initalize the new slots */
-+ for (i = indexes; i <= index; i++) {
-+ seen[i] = 0;
-+ }
-+ indexes = index+1;
-+ }
-+
-+ /*
-+ * If this is the first time we've seen this interface,
-+ * set the last values to the current ones. That causes
-+ * us to see no bandwidth on the interface the first
-+ * time, but that's OK.
-+ */
-+ if (!seen[index]) {
-+ seen[index] = 1;
-+ lastcount[index].in_bytes = ifm->ifm_data.ifi_ibytes;
-+ lastcount[index].out_bytes = ifm->ifm_data.ifi_obytes;
-+ lastcount[index].in_pkts = ifm->ifm_data.ifi_ipackets;
-+ lastcount[index].out_pkts = ifm->ifm_data.ifi_opackets;
-+ }
-+
-+ traffic.in_bytes = counterdiff(lastcount[index].in_bytes,
-+ ifm->ifm_data.ifi_ibytes, ULONG_MAX, 0);
-+ traffic.out_bytes = counterdiff(lastcount[index].out_bytes,
-+ ifm->ifm_data.ifi_obytes, ULONG_MAX, 0);
-+ traffic.in_pkts = counterdiff(lastcount[index].in_pkts,
-+ ifm->ifm_data.ifi_ipackets, ULONG_MAX, 0);
-+ traffic.out_pkts = counterdiff(lastcount[index].out_pkts,
-+ ifm->ifm_data.ifi_opackets, ULONG_MAX, 0);
-+
-+ lastcount[index].in_bytes = ifm->ifm_data.ifi_ibytes;
-+ lastcount[index].out_bytes = ifm->ifm_data.ifi_obytes;
-+ lastcount[index].in_pkts = ifm->ifm_data.ifi_ipackets;
-+ lastcount[index].out_pkts = ifm->ifm_data.ifi_opackets;
-+
-+#ifdef NETBW_DEBUG
-+ if_indextoname(index, name);
-+ printf("%s: \n", name);
-+ printf("\topackets=%llu ipackets=%llu\n",
-+ traffic.out_pkts, traffic.in_pkts);
-+ printf("\tobytes=%llu ibytes=%llu\n",
-+ traffic.out_bytes, traffic.in_bytes);
-+#endif
-+
-+ if (timerisset(&last_time)) {
-+ ibytes += (double)traffic.in_bytes / timertod(&time_diff);
-+ obytes += (double)traffic.out_bytes / timertod(&time_diff);
-+ ipkts += (double)traffic.in_pkts / timertod(&time_diff);
-+ opkts += (double)traffic.out_pkts / timertod(&time_diff);
-+ }
-+ }
-+ free(buf);
-+
-+ /* Save the values from this time */
-+ last_time = this_time;
-+ o_ibytes = ibytes;
-+ o_obytes = obytes;
-+ o_ipkts = ipkts;
-+ o_opkts = opkts;
-+
-+output:
-+ if (in_bytes != NULL)
-+ *in_bytes = o_ibytes;
-+ if (out_bytes != NULL)
-+ *out_bytes = o_obytes;
-+ if (in_pkts != NULL)
-+ *in_pkts = o_ipkts;
-+ if (out_pkts != NULL)
-+ *out_pkts = o_opkts;
-+}
-+
-+static uint64_t
-+counterdiff(uint64_t oldval, uint64_t newval, uint64_t maxval, uint64_t maxdiff)
-+{
-+ uint64_t diff;
-+
-+ if (maxdiff == 0)
-+ maxdiff = maxval;
-+
-+ /* Paranoia */
-+ if (oldval > maxval || newval > maxval)
-+ return 0;
-+
-+ /*
-+ * Tackle the easy case. Don't worry about maxdiff here because
-+ * we're SOL if it happens (i.e. assuming a reset just makes
-+ * matters worse).
-+ */
-+ if (oldval <= newval)
-+ return (newval - oldval);
-+
-+ /*
-+ * Now the tricky part. If we assume counters never get reset,
-+ * this is easy. Unfortunaly, they do get reset on some
-+ * systems, so we need to try and deal with that. Our huristic
-+ * is that if out difference is greater then maxdiff and newval
-+ * is less or equal to maxdiff, then we've probably been reset
-+ * rather then actually wrapping. Obviously, you need to be
-+ * careful to poll often enough that you won't exceed maxdiff or
-+ * you will get undersized numbers when you do wrap.
-+ */
-+ diff = maxval - oldval + newval;
-+ if (diff > maxdiff && newval <= maxdiff)
-+ return newval;
-+
-+ return diff;
-+}
diff --git a/sysutils/ganglia-monitor-core/files/patch-gmond_metric.h b/sysutils/ganglia-monitor-core/files/patch-gmond_metric.h
deleted file mode 100644
index 7c7d8eeb06b..00000000000
--- a/sysutils/ganglia-monitor-core/files/patch-gmond_metric.h
+++ /dev/null
@@ -1,65 +0,0 @@
-
-$FreeBSD$
-
---- gmond/metric.h.orig Mon Oct 27 16:47:53 2003
-+++ gmond/metric.h Mon Oct 27 16:48:15 2003
-@@ -88,6 +88,18 @@
-
- #endif
-
-+#ifdef FREEBSD
-+
-+extern g_val_t bytes_in_func(void);
-+extern g_val_t bytes_out_func(void);
-+extern g_val_t pkts_in_func(void);
-+extern g_val_t pkts_out_func(void);
-+extern g_val_t disk_total_func(void);
-+extern g_val_t disk_free_func(void);
-+extern g_val_t part_max_used_func(void);
-+
-+#endif
-+
- #define INIT 0, 0, {0}, {0}
- #define KEY(NAME) { #NAME, NAME ##_func, INIT
-
-@@ -182,7 +194,8 @@
- KEY(pkts_in), 256, 30, 40, 200, 300, g_float, "packets/sec", "%.2f" },
- KEY(pkts_out), 256, 30, 40, 200, 300, g_float, "packets/sec", "%.2f" },
-
--/* The amount of disk space could change - hot-swap, mounts, etc. check: 30-60min. */
-+/*
-+ * The amount of disk space could change - hot-swap, mounts, etc. check: 30-60min. */
- KEY(disk_total), 1, 1800, 3600, 900, 1200, g_double, "GB", "%.3f" },
- KEY(disk_free), 1, 30, 40, 120, 180, g_double, "GB", "%.3f" },
- KEY(part_max_used), 1, 30, 40, 120, 180, g_float, "%", "%.1f" }
-@@ -198,6 +211,30 @@
- KEY(mem_rm), 1024, 30, 40, 120, 180, g_uint32, "KB", "%u" },
- KEY(mem_avm), 1024, 30, 40, 120, 180, g_uint32, "KB", "%u" },
- KEY(mem_vm), 1024, 30, 40, 120, 180, g_uint32, "KB", "%u" }
-+
-+#endif
-+
-+#ifdef FREEBSD
-+
-+,
-+/*
-+ * (sacerdoti) Experiments have shown gmon resting bandwidth is around
-+ * 2KB/s for a 128-node cluster. We set the value thresh of these
-+ * metrics to double that.
-+ *
-+ */
-+KEY(bytes_out), 4096, 30, 40, 200, 300, g_float, "bytes/sec", "%.2f" },
-+KEY(bytes_in), 4096, 30, 40, 200, 300, g_float, "bytes/sec", "%.2f" },
-+KEY(pkts_in), 256, 30, 40, 200, 300, g_float, "packets/sec", "%.2f" },
-+KEY(pkts_out), 256, 30, 40, 200, 300, g_float, "packets/sec", "%.2f" },
-+
-+/*
-+ * The amount of disk space could change - hot-swap, mounts, etc.
-+ * check: 30-60min.
-+ */
-+KEY(disk_total), 1, 1800, 3600, 900, 1200, g_double, "GB", "%.3f" },
-+KEY(disk_free), 1, 30, 40, 120, 180, g_double, "GB", "%.3f" },
-+KEY(part_max_used), 1, 30, 40, 120, 180, g_float, "%", "%.1f" }
-
- #endif
- };
diff --git a/sysutils/ganglia-monitor-core/files/patch-lib_ganglia_net.h b/sysutils/ganglia-monitor-core/files/patch-lib_ganglia_net.h
deleted file mode 100644
index 0ca2ad99970..00000000000
--- a/sysutils/ganglia-monitor-core/files/patch-lib_ganglia_net.h
+++ /dev/null
@@ -1,14 +0,0 @@
-
-$FreeBSD$
-
---- lib/ganglia/net.h.orig Mon Oct 27 16:53:00 2003
-+++ lib/ganglia/net.h Mon Oct 27 16:53:07 2003
-@@ -12,7 +12,7 @@
- #include <netdb.h>
- #include <ganglia/llist.h>
- #include <ganglia/net.h>
--#ifdef BSD
-+#ifdef FREEBSD
- #include <sys/types.h>
- #endif
- #include <netinet/in.h>
diff --git a/sysutils/ganglia-monitor-core/pkg-plist b/sysutils/ganglia-monitor-core/pkg-plist
index 4144d046aa4..c049c2190b1 100644
--- a/sysutils/ganglia-monitor-core/pkg-plist
+++ b/sysutils/ganglia-monitor-core/pkg-plist
@@ -38,4 +38,5 @@ lib/libganglia.a
%%GMETAD%%sbin/gmetad
sbin/gmond
@dirrm include/ganglia
-@unexec rmdir /var/db/ganglia/rrds /var/db/ganglia 2>/dev/null || true
+@unexec rmdir %D/var/db/ganglia/rrds 2>/dev/null || true
+@unexec rmdir %D/var/db/ganglia 2>/dev/null || true