summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorclaudio <claudio@openbsd.org>2009-06-25 15:54:22 +0000
committerclaudio <claudio@openbsd.org>2009-06-25 15:54:22 +0000
commitf57ddf8ebc3e0d02fed52c14601326276ffa6772 (patch)
treea54bb5d6b1f3df116f8686dda57d1fb1a7764446
parentCheck RTM_VERSION even on sysctl data. (diff)
downloadwireguard-openbsd-f57ddf8ebc3e0d02fed52c14601326276ffa6772.tar.xz
wireguard-openbsd-f57ddf8ebc3e0d02fed52c14601326276ffa6772.zip
Add missing RTM_VERSION checks. Bad me, no cockies.
Tested and OK sthen@, OK henning@
-rw-r--r--usr.sbin/bgpd/kroute.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/usr.sbin/bgpd/kroute.c b/usr.sbin/bgpd/kroute.c
index e6d2043672f..d16cf3b4156 100644
--- a/usr.sbin/bgpd/kroute.c
+++ b/usr.sbin/bgpd/kroute.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: kroute.c,v 1.168 2009/06/12 16:42:53 claudio Exp $ */
+/* $OpenBSD: kroute.c,v 1.169 2009/06/25 15:54:22 claudio Exp $ */
/*
* Copyright (c) 2003, 2004 Henning Brauer <henning@openbsd.org>
@@ -2184,6 +2184,8 @@ fetchtable(u_int rtableid, int connected_only)
lim = buf + len;
for (next = buf; next < lim; next += rtm->rtm_msglen) {
rtm = (struct rt_msghdr *)next;
+ if (rtm->rtm_version != RTM_VERSION)
+ continue;
sa = (struct sockaddr *)(next + rtm->rtm_hdrlen);
get_rtaddrs(rtm->rtm_addrs, sa, rti_info);
@@ -2409,6 +2411,8 @@ dispatch_rtmsg(void)
lim = buf + n;
for (next = buf; next < lim; next += rtm->rtm_msglen) {
rtm = (struct rt_msghdr *)next;
+ if (rtm->rtm_version != RTM_VERSION)
+ continue;
switch (rtm->rtm_type) {
case RTM_ADD: