summaryrefslogtreecommitdiff
path: root/net/zebra
diff options
context:
space:
mode:
authorMaxim Sobolev <sobomax@FreeBSD.org>2002-10-07 14:43:54 +0000
committerMaxim Sobolev <sobomax@FreeBSD.org>2002-10-07 14:43:54 +0000
commitf1cbce63eccb3568bdb1b78264e8f399b1456ead (patch)
tree3047b1f4edd518fd4b24194eda506b65369badfc /net/zebra
parentAdd py-vorbis 1.0, object-oriented Python bindings for the vorbis library. (diff)
Properly zero-out struct ifreq before passing it to the SIOCSIFFLAGS
ioctl(2), so that it doesn't occasionally trigger promisc mode on interface. Reported/tested by: Vladimir B. Grebenschikov <vova@sw.ru>
Notes
Notes: svn path=/head/; revision=67560
Diffstat (limited to 'net/zebra')
-rw-r--r--net/zebra/Makefile1
-rw-r--r--net/zebra/files/patch-ioctl.c29
2 files changed, 25 insertions, 5 deletions
diff --git a/net/zebra/Makefile b/net/zebra/Makefile
index 0bdf991b3047..72c8ee8beb4e 100644
--- a/net/zebra/Makefile
+++ b/net/zebra/Makefile
@@ -7,6 +7,7 @@
PORTNAME= zebra
PORTVERSION= 0.93b
+PORTREVISION= 1
CATEGORIES= net ipv6
MASTER_SITES= ftp://ftp.zebra.org/pub/zebra/ \
ftp://ftp.ripe.net/mirrors/sites/ftp.zebra.org/pub/zebra/ \
diff --git a/net/zebra/files/patch-ioctl.c b/net/zebra/files/patch-ioctl.c
index 2c06a9b189e5..aadb3ab5c5dd 100644
--- a/net/zebra/files/patch-ioctl.c
+++ b/net/zebra/files/patch-ioctl.c
@@ -1,6 +1,25 @@
---- zebra/ioctl.c.orig Wed Dec 12 18:02:16 2001
-+++ zebra/ioctl.c Wed Dec 12 18:02:30 2001
-@@ -478,6 +478,9 @@
+
+$FreeBSD$
+
+--- zebra/ioctl.c.orig Tue Oct 23 11:31:29 2001
++++ zebra/ioctl.c Fri Oct 4 19:45:04 2002
+@@ -349,6 +349,7 @@
+ int ret;
+ struct ifreq ifreq;
+
++ bzero(&ifreq, sizeof(struct ifreq));
+ ifreq_set_name (&ifreq, ifp);
+
+ ifreq.ifr_flags = ifp->flags;
+@@ -371,6 +372,7 @@
+ int ret;
+ struct ifreq ifreq;
+
++ bzero(&ifreq, sizeof(struct ifreq));
+ ifreq_set_name (&ifreq, ifp);
+
+ ifreq.ifr_flags = ifp->flags;
+@@ -473,6 +475,9 @@
mask.sin6_len = sizeof (struct sockaddr_in6);
#endif
memcpy (&addreq.ifra_prefixmask, &mask, sizeof (struct sockaddr_in6));
@@ -8,5 +27,5 @@
+ addreq.ifra_lifetime.ia6t_vltime = 0xffffffff;
+ addreq.ifra_lifetime.ia6t_pltime = 0xffffffff;
- ret = if_ioctl_ipv6 (SIOCAIFADDR_IN6, (caddr_t) &addreq);
- if (ret < 0)
+ addreq.ifra_lifetime.ia6t_pltime = ND6_INFINITE_LIFETIME;
+ addreq.ifra_lifetime.ia6t_vltime = ND6_INFINITE_LIFETIME;