summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHajimu UMEMOTO <ume@FreeBSD.org>2001-07-19 22:04:09 +0000
committerHajimu UMEMOTO <ume@FreeBSD.org>2001-07-19 22:04:09 +0000
commit74fd29e0bc55342fa2b5d3eaa3387f0ebf083b75 (patch)
treeee62a47acb968e5aebe0e6547078ced96e895dae
parentc8ce6587d0443eea1299bafe506ecdf72df9459f (diff)
Notes
-rw-r--r--usr.sbin/syslogd/syslogd.c13
1 files changed, 9 insertions, 4 deletions
diff --git a/usr.sbin/syslogd/syslogd.c b/usr.sbin/syslogd/syslogd.c
index dc6a7ec9e64f..3ff3233138b8 100644
--- a/usr.sbin/syslogd/syslogd.c
+++ b/usr.sbin/syslogd/syslogd.c
@@ -1813,10 +1813,10 @@ allowaddr(s)
char *cp1, *cp2;
struct allowedpeer ap;
struct servent *se;
- int masklen = -1;
+ int masklen = -1, i;
struct addrinfo hints, *res;
struct in_addr *addrp, *maskp;
- u_int32_t *mask6p;
+ u_int32_t *addr6p, *mask6p;
char ip[NI_MAXHOST];
#ifdef INET6
@@ -1907,6 +1907,11 @@ allowaddr(s)
*mask6p++ = 0xffffffff;
masklen -= 32;
}
+ /* Lose any host bits in the network number. */
+ mask6p = (u_int32_t *)&((struct sockaddr_in6 *)&ap.a_mask)->sin6_addr;
+ addr6p = (u_int32_t *)&((struct sockaddr_in6 *)&ap.a_addr)->sin6_addr;
+ for (i = 0; i < 4; i++)
+ addr6p[i] &= mask6p[i];
}
#endif
else {
@@ -2032,8 +2037,8 @@ validate(sa, hname)
#endif
reject = 0;
for (j = 0; j < 16; j += 4) {
- if ((*(u_int32_t *)&sin6->sin6_addr.s6_addr[i] & *(u_int32_t *)&m6p->sin6_addr.s6_addr[i])
- != *(u_int32_t *)&a6p->sin6_addr.s6_addr[i]) {
+ if ((*(u_int32_t *)&sin6->sin6_addr.s6_addr[j] & *(u_int32_t *)&m6p->sin6_addr.s6_addr[j])
+ != *(u_int32_t *)&a6p->sin6_addr.s6_addr[j]) {
++reject;
break;
}