diff options
author | Martin Pieuchot <mpi@cvs.openbsd.org> | 2014-02-13 10:31:43 +0000 |
---|---|---|
committer | Martin Pieuchot <mpi@cvs.openbsd.org> | 2014-02-13 10:31:43 +0000 |
commit | 7abe5bc33029d430bfd0685140d13f461614de97 (patch) | |
tree | c6cd82cb3967b22d58c9254c54a1c1121bf8cd71 | |
parent | 24a2cafc414e23e2479dcc79094734c6998fdd48 (diff) |
When sending a neighbor advertisement, correctly use the carp mac
address and not the mac of the physical interface as target lladdr.
This allows us to get rid of the hack adding and removing the route to
loopback of a carp node when its status switch to master and backup
respectively. Now the route entry will no longer be updated to use the
mac address of the physical interface of the master node as gateway.
While here send the ARP request through the carp interface for consistency.
Analysed with and ok mikeb@, ok bluhm@
-rw-r--r-- | sys/netinet/ip_carp.c | 17 |
1 files changed, 3 insertions, 14 deletions
diff --git a/sys/netinet/ip_carp.c b/sys/netinet/ip_carp.c index 3cd6c94662c..0f383fc90ed 100644 --- a/sys/netinet/ip_carp.c +++ b/sys/netinet/ip_carp.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ip_carp.c,v 1.221 2014/02/07 22:22:37 stsp Exp $ */ +/* $OpenBSD: ip_carp.c,v 1.222 2014/02/13 10:31:42 mpi Exp $ */ /* * Copyright (c) 2002 Michael Shalayeff. All rights reserved. @@ -509,17 +509,6 @@ carp_setroute(struct carp_softc *sc, int cmd) } break; } - -#ifdef INET6 - case AF_INET6: - if (sc->sc_balancing >= CARP_BAL_IP) - continue; - if (cmd == RTM_ADD) - in6_ifaddloop(ifa); - else - in6_ifremloop(ifa); - break; -#endif /* INET6 */ default: break; } @@ -1330,7 +1319,7 @@ carp_send_arp(struct carp_softc *sc) continue; in = ifatoia(ifa)->ia_addr.sin_addr.s_addr; - arprequest(sc->sc_carpdev, &in, &in, sc->sc_ac.ac_enaddr); + arprequest(&sc->sc_if, &in, &in, sc->sc_ac.ac_enaddr); DELAY(1000); /* XXX */ } splx(s); @@ -1351,7 +1340,7 @@ carp_send_na(struct carp_softc *sc) continue; in6 = &ifatoia6(ifa)->ia_addr.sin6_addr; - nd6_na_output(sc->sc_carpdev, &mcast, in6, + nd6_na_output(&sc->sc_if, &mcast, in6, ND_NA_FLAG_OVERRIDE | (ip6_forwarding ? ND_NA_FLAG_ROUTER : 0), 1, NULL); DELAY(1000); /* XXX */ |