diff options
author | Patrick Latifi <pat@cvs.openbsd.org> | 2004-12-15 14:13:07 +0000 |
---|---|---|
committer | Patrick Latifi <pat@cvs.openbsd.org> | 2004-12-15 14:13:07 +0000 |
commit | d27d748842eb80b51a4b4141ce6808efe4bdaa06 (patch) | |
tree | 9ec5aad0d69424ad9fa5c36e450bb4ad4248e4aa | |
parent | 4d1883c65b32449bb4bb4b76dbdd633b9a564bff (diff) |
* fix the multicast memberships removal
* less hardcoding in format strings for easier maintenance
mcbride ok
-rw-r--r-- | sys/netinet/ip_carp.c | 37 |
1 files changed, 21 insertions, 16 deletions
diff --git a/sys/netinet/ip_carp.c b/sys/netinet/ip_carp.c index 62c1ab3e46d..aa1b0404862 100644 --- a/sys/netinet/ip_carp.c +++ b/sys/netinet/ip_carp.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ip_carp.c,v 1.79 2004/12/10 23:13:52 mcbride Exp $ */ +/* $OpenBSD: ip_carp.c,v 1.80 2004/12/15 14:13:06 pat Exp $ */ /* * Copyright (c) 2002 Michael Shalayeff. All rights reserved. @@ -156,7 +156,8 @@ struct carp_if { #define CARP_LOG(sc, s) \ if (carp_opts[CARPCTL_LOG]) { \ if (sc) \ - log(LOG_INFO, "%s: ", (sc)->sc_ac.ac_if.if_xname);\ + log(LOG_INFO, "%s: ", \ + (sc)->sc_ac.ac_if.if_xname); \ else \ log(LOG_INFO, "carp: "); \ addlog s; \ @@ -419,8 +420,8 @@ carp_proto_input(struct mbuf *m, ...) /* verify that the IP TTL is 255. */ if (ip->ip_ttl != CARP_DFLTTL) { carpstats.carps_badttl++; - CARP_LOG(sc, ("received ttl %d != 255 on %s", ip->ip_ttl, - m->m_pkthdr.rcvif->if_xname)); + CARP_LOG(sc, ("received ttl %d != %d on %s", ip->ip_ttl, + CARP_DFLTTL, m->m_pkthdr.rcvif->if_xname)); m_freem(m); return; } @@ -429,8 +430,9 @@ carp_proto_input(struct mbuf *m, ...) if (m->m_pkthdr.len < iplen + sizeof(*ch)) { carpstats.carps_badlen++; - CARP_LOG(sc, ("received len %d < 36 on %s", - m->m_len - sizeof(struct ip), m->m_pkthdr.rcvif->if_xname)); + CARP_LOG(sc, ("received len %d < %d on %s", + m->m_len - sizeof(struct ip), sizeof(*ch), + m->m_pkthdr.rcvif->if_xname)); m_freem(m); return; } @@ -508,8 +510,8 @@ carp6_proto_input(struct mbuf **mp, int *offp, int proto) /* verify that the IP TTL is 255 */ if (ip6->ip6_hlim != CARP_DFLTTL) { carpstats.carps_badttl++; - CARP_LOG(sc, ("received ttl %d != 255 on %s", ip6->ip6_hlim, - m->m_pkthdr.rcvif->if_xname)); + CARP_LOG(sc, ("received ttl %d != %d on %s", ip6->ip6_hlim, + CARP_DFLTTL, m->m_pkthdr.rcvif->if_xname)); m_freem(m); return (IPPROTO_DONE); } @@ -568,7 +570,8 @@ carp_proto_input_c(struct mbuf *m, struct carp_header *ch, sa_family_t af) if (ch->carp_version != CARP_VERSION) { carpstats.carps_badver++; sc->sc_ac.ac_if.if_ierrors++; - CARP_LOG(sc, ("invalid version %d", ch->carp_version)); + CARP_LOG(sc, ("invalid version %d != %d", + ch->carp_version, CARP_VERSION)); m_freem(m); return; } @@ -1396,13 +1399,16 @@ carp_multicast_cleanup(struct carp_softc *sc) { struct ip_moptions *imo = &sc->sc_imo; struct ip6_moptions *im6o = &sc->sc_im6o; + u_int16_t n = imo->imo_num_memberships; /* Clean up our own multicast memberships */ - while (imo->imo_num_memberships > 0) { - if (imo->imo_membership[--imo->imo_num_memberships] == NULL) - in_delmulti(imo->imo_membership[imo->imo_num_memberships]); - imo->imo_membership[imo->imo_num_memberships] = NULL; + while (n-- > 0) { + if (imo->imo_membership[n] != NULL) { + in_delmulti(imo->imo_membership[n]); + imo->imo_membership[n] = NULL; + } } + imo->imo_num_memberships = 0; imo->imo_multicast_ifp = NULL; while (!LIST_EMPTY(&im6o->im6o_memberships)) { @@ -2071,7 +2077,6 @@ carp_carpdev_state(struct ifnet *ifp) } } - int carp_ether_addmulti(struct carp_softc *sc, struct ifreq *ifr) { @@ -2182,8 +2187,8 @@ carp_ether_purgemulti(struct carp_softc *sc) char ifr_name[IFNAMSIZ]; struct sockaddr_storage ifr_ss; } ifreq_storage; - } ifreq; - struct ifreq *ifr = &ifreq.ifreq; + } u; + struct ifreq *ifr = &u.ifreq; if (ifp == NULL) return; |