summaryrefslogtreecommitdiff
path: root/net/ucd-snmp/patches
diff options
context:
space:
mode:
authortron <tron@pkgsrc.org>1999-08-15 11:07:13 +0000
committertron <tron@pkgsrc.org>1999-08-15 11:07:13 +0000
commit99888b864b64036e52f8dd1ac92447f77dc34142 (patch)
tree3201d06ff7266754b946087133e5917352d7a29c /net/ucd-snmp/patches
parent6177eaed01b7b317ab16df1219e300882edf9ff3 (diff)
downloadpkgsrc-99888b864b64036e52f8dd1ac92447f77dc34142.tar.gz
Fix "ucd-snmpd" to return "mib-2.ip.ipAddrTable" and make sure "netbsd1"
preprocessor symbol gets defined on NetBSD systems. Patches supplied by Zdenek Salvet in PR pkg/7799.
Diffstat (limited to 'net/ucd-snmp/patches')
-rw-r--r--net/ucd-snmp/patches/patch-af46
-rw-r--r--net/ucd-snmp/patches/patch-ag29
2 files changed, 75 insertions, 0 deletions
diff --git a/net/ucd-snmp/patches/patch-af b/net/ucd-snmp/patches/patch-af
new file mode 100644
index 00000000000..e09f76d18e8
--- /dev/null
+++ b/net/ucd-snmp/patches/patch-af
@@ -0,0 +1,46 @@
+$NetBSD: patch-af,v 1.1 1999/08/15 11:07:14 tron Exp $
+
+--- agent/mibgroup/mibII/interfaces.c.orig Tue Mar 16 00:46:12 1999
++++ agent/mibgroup/mibII/interfaces.c Thu Jun 17 10:21:06 1999
+@@ -114,7 +114,7 @@
+
+ #if HAVE_SYS_SYSCTL_H
+ #include <sys/sysctl.h>
+-# if defined(CTL_NET) && !defined(freebsd2)
++# if defined(CTL_NET) && !defined(freebsd2) && !defined(netbsd1)
+ # ifdef PF_ROUTE
+ # ifdef NET_RT_IFLIST
+ # define USE_SYSCTL_IFLIST
+@@ -1462,16 +1462,31 @@
+ cp = strchr(saveName, '\0');
+ string_append_int (cp, ifnet.if_unit);
+ #endif
+- if (1 || strcmp(saveName,"lo0") != 0) { /* XXX */
++ if (1) { /* XXX */
+ /*
+ * Try to find an address for this interface
+ */
+
+ auto_nlist(IFADDR_SYMBOL, (char *)&ia, sizeof(ia));
++#ifdef netbsd1
++ ia=(struct in_ifaddr *)ifnet.if_addrlist.tqh_first;
++#endif
+ while (ia) {
+ klookup((unsigned long)ia , (char *)&in_ifaddr, sizeof(in_ifaddr));
++#ifdef netbsd1
++#define CP(x) ((char *)(x))
++{ char *cp; struct sockaddr * sa;
++ cp = (CP(in_ifaddr.ia_ifa.ifa_addr) - CP(ia)) +
++ CP(&in_ifaddr); sa = (struct sockaddr *)cp;
++if (sa->sa_family==AF_INET)
++#endif
+ if (in_ifaddr.ia_ifp == ifnetaddr) break;
++}
++#ifdef netbsd1
++ ia=(struct in_ifaddr *)in_ifaddr.ia_ifa.ifa_list.tqe_next;
++#else
+ ia = in_ifaddr.ia_next;
++#endif
+ }
+
+ #if !defined(netbsd1) && !defined(freebsd2) && !defined(openbsd2) && !defined(STRUCT_IFNET_HAS_IF_ADDRLIST)
diff --git a/net/ucd-snmp/patches/patch-ag b/net/ucd-snmp/patches/patch-ag
new file mode 100644
index 00000000000..3eb94bc7675
--- /dev/null
+++ b/net/ucd-snmp/patches/patch-ag
@@ -0,0 +1,29 @@
+$NetBSD: patch-ag,v 1.1 1999/08/15 11:07:14 tron Exp $
+
+
+--- agent/mibgroup/mibII/ip.c.orig Fri Mar 12 18:15:05 1999
++++ agent/mibgroup/mibII/ip.c Thu Jun 17 10:08:11 1999
+@@ -728,7 +728,11 @@
+ #ifdef linux
+ return (u_char *)&((struct sockaddr_in *)&lowin_ifnet.ia_subnetmask)->sin_addr.s_addr;
+ #else
++#ifdef netbsd1
++ long_return = lowin_ifaddr.ia_subnetmask;
++#else
+ long_return = ntohl(lowin_ifaddr.ia_subnetmask);
++#endif
+ return(u_char *) &long_return;
+ #endif
+ #endif
+@@ -737,7 +741,11 @@
+ #if defined(linux) || defined(sunV3)
+ long_return = ntohl(((struct sockaddr_in *) &lowin_ifnet.ifu_broadaddr)->sin_addr.s_addr) & 1;
+ #else
++#ifdef netbsd1
++ long_return = (((struct sockaddr_in *) &lowin_ifaddr.ia_broadaddr)->sin_addr.s_addr) & 1;
++#else
+ long_return = ntohl(((struct sockaddr_in *) &lowin_ifaddr.ia_broadaddr)->sin_addr.s_addr) & 1;
++#endif
+ #endif
+ return(u_char *) &long_return;
+ case IPADREASMMAX: