summaryrefslogtreecommitdiff
path: root/sys/netinet
diff options
context:
space:
mode:
authorRyan Thomas McBride <mcbride@cvs.openbsd.org>2003-11-14 08:17:47 +0000
committerRyan Thomas McBride <mcbride@cvs.openbsd.org>2003-11-14 08:17:47 +0000
commitd060dadef7265d744b922b67a454a61924ecee75 (patch)
treedc7776611eb41b709a81f059d3b37b0617ad6bac /sys/netinet
parent93854580a59b9b13c3721c63ddef5bad11dbfe9a (diff)
Don't include KAME link-local interface ID in HMAC.
from itojun@
Diffstat (limited to 'sys/netinet')
-rw-r--r--sys/netinet/ip_carp.c13
1 files changed, 8 insertions, 5 deletions
diff --git a/sys/netinet/ip_carp.c b/sys/netinet/ip_carp.c
index 7c6a2b58dec..7a7e4f506fa 100644
--- a/sys/netinet/ip_carp.c
+++ b/sys/netinet/ip_carp.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ip_carp.c,v 1.27 2003/11/09 08:56:55 mcbride Exp $ */
+/* $OpenBSD: ip_carp.c,v 1.28 2003/11/14 08:17:46 mcbride Exp $ */
/*
* Copyright (c) 2002 Michael Shalayeff. All rights reserved.
@@ -179,6 +179,7 @@ carp_hmac_prepare(struct carp_softc *sc)
u_int8_t vhid = sc->sc_vhid & 0xff;
struct ifaddr *ifa;
int i;
+ struct in6_addr in6;
/* compute ipad from key */
bzero(sc->sc_pad, sizeof(sc->sc_pad));
@@ -202,10 +203,12 @@ carp_hmac_prepare(struct carp_softc *sc)
#endif /* INET */
#ifdef INET6
TAILQ_FOREACH(ifa, &sc->sc_ac.ac_if.if_addrlist, ifa_list) {
- if (ifa->ifa_addr->sa_family == AF_INET6)
- SHA1Update(&sc->sc_sha1,
- (void *)&ifatoia6(ifa)->ia_addr.sin6_addr,
- sizeof(struct in6_addr));
+ if (ifa->ifa_addr->sa_family == AF_INET6) {
+ in6 = ifatoia6(ifa)->ia_addr.sin6_addr;
+ if (IN6_IS_ADDR_LINKLOCAL(&in6))
+ in6.s6_addr16[1] = 0;
+ SHA1Update(&sc->sc_sha1, (void *)&in6, sizeof(in6));
+ }
}
#endif /* INET6 */