summaryrefslogtreecommitdiff
path: root/net/net-snmp
diff options
context:
space:
mode:
authorchristos <christos@pkgsrc.org>2006-06-17 17:20:56 +0000
committerchristos <christos@pkgsrc.org>2006-06-17 17:20:56 +0000
commit452ca84b5cbfb5c2e915d1f54a728f97e5ffa328 (patch)
tree7c7c00d63eb2551dd3caca57b578423b67cada4d /net/net-snmp
parentfd97e49920850bff04d0cac55892e661df92db94 (diff)
downloadpkgsrc-452ca84b5cbfb5c2e915d1f54a728f97e5ffa328.tar.gz
- don't use getfsstat, use getvfsstat.
- add code to do disk i/o statistics for NetBSD and enable it.
Diffstat (limited to 'net/net-snmp')
-rw-r--r--net/net-snmp/Makefile8
-rw-r--r--net/net-snmp/distinfo4
-rw-r--r--net/net-snmp/patches/patch-aa12
-rw-r--r--net/net-snmp/patches/patch-ab155
4 files changed, 176 insertions, 3 deletions
diff --git a/net/net-snmp/Makefile b/net/net-snmp/Makefile
index fc2571f9ac7..dd066ec7871 100644
--- a/net/net-snmp/Makefile
+++ b/net/net-snmp/Makefile
@@ -1,7 +1,7 @@
-# $NetBSD: Makefile,v 1.48 2006/03/19 22:03:29 joerg Exp $
+# $NetBSD: Makefile,v 1.49 2006/06/17 17:20:56 christos Exp $
DISTNAME= net-snmp-5.3.0.1
-PKGREVISION= 2
+PKGREVISION= 3
CATEGORIES= net
MASTER_SITES= ${MASTER_SITE_SOURCEFORGE:=net-snmp/} \
ftp://ftp.net-smnp.org/pub/sourceforge/net-snmp/
@@ -56,7 +56,11 @@ CONFIGURE_ARGS+= --with-persistent-directory=${NET_SNMP_PERSISTENTDIR:Q}
.if !empty(NET_SNMP_MIBDIRS)
CONFIGURE_ARGS+= --with-mibdirs=${NET_SNMP_MIBDIRS:Q}
.endif
+.if ${OPSYS} == "NetBSD"
+CONFIGURE_ARGS+= --with-mib-modules="smux host ucd-snmp/diskio"
+.else
CONFIGURE_ARGS+= --with-mib-modules="smux host"
+.endif
.if !empty(MACHINE_PLATFORM:MDarwin-[567].*)
CONFIGURE_ARGS+= --with-out-mib-modules="ucd-snmp/diskio mibII"
.endif
diff --git a/net/net-snmp/distinfo b/net/net-snmp/distinfo
index 1ba514a752d..a0213405a4e 100644
--- a/net/net-snmp/distinfo
+++ b/net/net-snmp/distinfo
@@ -1,8 +1,10 @@
-$NetBSD: distinfo,v 1.22 2006/03/19 22:03:29 joerg Exp $
+$NetBSD: distinfo,v 1.23 2006/06/17 17:20:56 christos Exp $
SHA1 (net-snmp-5.3.0.1.tar.gz) = c58ddabe4281c3681a268bd48de6865e812f2ec5
RMD160 (net-snmp-5.3.0.1.tar.gz) = 86b7e56b512faf73d2a08ac3df2def4560b62945
Size (net-snmp-5.3.0.1.tar.gz) = 4183370 bytes
+SHA1 (patch-aa) = 30a4d1546fe7022a0578d01004fc3f284e45c392
+SHA1 (patch-ab) = e274e0a440e760a6c25b7c5311089e4138098ec6
SHA1 (patch-ae) = 750412088b9ccd5fb50bd6e7fc049903f6113a39
SHA1 (patch-af) = f7c95d2276ccd8332e7dc39f2bf88c857bdfde9f
SHA1 (patch-ag) = 9bad3789cfb12bb68c2b306e82600d866467471a
diff --git a/net/net-snmp/patches/patch-aa b/net/net-snmp/patches/patch-aa
new file mode 100644
index 00000000000..5de05cfbbea
--- /dev/null
+++ b/net/net-snmp/patches/patch-aa
@@ -0,0 +1,12 @@
+$NetBSD: patch-aa,v 1.5 2006/06/17 17:20:56 christos Exp $
+
+--- agent/mibgroup/host/hr_filesys.c.orig 2005-02-28 07:52:58.000000000 -0500
++++ agent/mibgroup/host/hr_filesys.c 2006-06-17 12:21:40.000000000 -0400
+@@ -88,6 +88,7 @@
+
+ #elif defined(HAVE_STATVFS) && defined(__NetBSD__)
+
++#define getfsstat getvfsstat
+ static struct statvfs *fsstats = NULL;
+ struct statvfs *HRFS_entry;
+ static int fscount;
diff --git a/net/net-snmp/patches/patch-ab b/net/net-snmp/patches/patch-ab
new file mode 100644
index 00000000000..08c237277ce
--- /dev/null
+++ b/net/net-snmp/patches/patch-ab
@@ -0,0 +1,155 @@
+$NetBSD: patch-ab,v 1.7 2006/06/17 17:20:56 christos Exp $
+
+--- agent/mibgroup/ucd-snmp/diskio.c.orig 2005-12-04 09:25:54.000000000 -0500
++++ agent/mibgroup/ucd-snmp/diskio.c 2006-06-17 13:09:51.000000000 -0400
+@@ -419,6 +419,150 @@
+ }
+ #endif /* bsdi */
+
++#ifdef __NetBSD__
++#include <sys/sysctl.h>
++static int ndisk;
++static int nmib[2] = {CTL_HW, HW_DISKNAMES};
++#ifdef HW_DISKSTATS
++static int dmib[3] = {CTL_HW, HW_DISKSTATS, sizeof(struct disk_sysctl)};
++static struct disk_sysctl *dk;
++#endif
++#ifdef HW_IOSTATS
++#include <sys/iostat.h>
++static int dmib[3] = {CTL_HW, HW_IOSTATS, sizeof(struct io_sysctl)};
++static struct io_sysctl *dk;
++#endif
++static char **dkname;
++
++static int
++getstats(void)
++{
++ time_t now;
++ char *t, *tp;
++ int size, dkn_size, i;
++
++ now = time(NULL);
++ if (cache_time + CACHE_TIMEOUT > now) {
++ return 1;
++ }
++ size = 0;
++ if (sysctl(dmib, 3, NULL, &size, NULL, 0) < 0) {
++ perror("Can't get size of HW_DISKSTATS/HW_IOSTATS mib");
++ return 0;
++ }
++ if (ndisk != size / dmib[2]) {
++ if (dk)
++ free(dk);
++ if (dkname) {
++ for (i = 0; i < ndisk; i++)
++ if (dkname[i])
++ free(dkname[i]);
++ free(dkname);
++ }
++ ndisk = size / dmib[2];
++ if (ndisk == 0)
++ return 0;
++ dkname = malloc(ndisk * sizeof(char *));
++ if (sysctl(nmib, 2, NULL, &dkn_size, NULL, 0) < 0) {
++ perror("Can't get size of HW_DISKNAMES mib");
++ return 0;
++ }
++ t = malloc(dkn_size);
++ if (sysctl(nmib, 2, t, &dkn_size, NULL, 0) < 0) {
++ perror("Can't get size of HW_DISKNAMES mib");
++ return 0;
++ }
++ for (i = 0, tp = strtok(t, " "); tp && i < ndisk; i++,
++ tp = strtok(NULL, " ")) {
++ dkname[i] = strdup(tp);
++ }
++ free(t);
++ dk = malloc(ndisk * sizeof(*dk));
++ }
++ if (sysctl(dmib, 3, dk, &size, NULL, 0) < 0) {
++ perror("Can't get HW_DISKSTATS/HW_IOSTATS mib");
++ return 0;
++ }
++ cache_time = now;
++ return 1;
++}
++
++u_char *
++var_diskio(struct variable * vp,
++ oid * name,
++ size_t * length,
++ int exact, size_t * var_len, WriteMethod ** write_method)
++{
++ static long long_ret;
++ unsigned int indx;
++
++ if (getstats() == 0)
++ return 0;
++
++ if (header_simple_table
++ (vp, name, length, exact, var_len, write_method, ndisk))
++ return NULL;
++
++ indx = (unsigned int) (name[*length - 1] - 1);
++ if (indx >= ndisk)
++ return NULL;
++
++ switch (vp->magic) {
++ case DISKIO_INDEX:
++ long_ret = (long) indx + 1;
++ return (u_char *) & long_ret;
++
++ case DISKIO_DEVICE:
++ *var_len = strlen(dkname[indx]);
++ return (u_char *) dkname[indx];
++
++ case DISKIO_NREAD:
++#ifdef HW_DISKSTATS
++ long_ret = dk[indx].dk_rbytes;
++#endif
++#ifdef HW_IOSTATS
++ if (dk[indx].type == IOSTAT_DISK)
++ long_ret = dk[indx].rbytes;
++#endif
++ return (u_char *) & long_ret;
++
++ case DISKIO_NWRITTEN:
++#ifdef HW_DISKSTATS
++ long_ret = dk[indx].dk_wbytes;
++#endif
++#ifdef HW_IOSTATS
++ if (dk[indx].type == IOSTAT_DISK)
++ long_ret = dk[indx].wbytes;
++#endif
++ return (u_char *) & long_ret;
++
++ case DISKIO_READS:
++#ifdef HW_DISKSTATS
++ long_ret = dk[indx].dk_rxfer;
++#endif
++#ifdef HW_IOSTATS
++ if (dk[indx].type == IOSTAT_DISK)
++ long_ret = dk[indx].rxfer;
++#endif
++ return (u_char *) & long_ret;
++
++ case DISKIO_WRITES:
++#ifdef HW_DISKSTATS
++ long_ret = dk[indx].dk_wxfer;
++#endif
++#ifdef HW_IOSTATS
++ if (dk[indx].type == IOSTAT_DISK)
++ long_ret = dk[indx].wxfer;
++#endif
++ return (u_char *) & long_ret;
++
++ default:
++ ERROR_MSG("diskio.c: don't know how to handle this request.");
++ }
++ return NULL;
++}
++#endif /* __NetBSD__ */
++
+ #if defined(freebsd4) || defined(freebsd5)
+
+ /* disk load average patch by Rojer */