Module Name: src
Committed By: yamaguchi
Date: Thu Jun 14 08:06:07 UTC 2018
Modified Files:
src/sys/net: if_vlan.c
src/sys/netinet: ip_carp.c
Log Message:
Add the lock to refer the list included in ethercom for safety
The lock is already held while adding and deleting
ok ozaki-r@
To generate a diff of this commit:
cvs rdiff -u -r1.127 -r1.128 src/sys/net/if_vlan.c
cvs rdiff -u -r1.97 -r1.98 src/sys/netinet/ip_carp.c
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/sys/net/if_vlan.c
diff -u src/sys/net/if_vlan.c:1.127 src/sys/net/if_vlan.c:1.128
--- src/sys/net/if_vlan.c:1.127 Thu Jun 14 07:54:57 2018
+++ src/sys/net/if_vlan.c Thu Jun 14 08:06:07 2018
@@ -1,4 +1,4 @@
-/* $NetBSD: if_vlan.c,v 1.127 2018/06/14 07:54:57 yamaguchi Exp $ */
+/* $NetBSD: if_vlan.c,v 1.128 2018/06/14 08:06:07 yamaguchi Exp $ */
/*
* Copyright (c) 2000, 2001 The NetBSD Foundation, Inc.
@@ -78,7 +78,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_vlan.c,v 1.127 2018/06/14 07:54:57 yamaguchi Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_vlan.c,v 1.128 2018/06/14 08:06:07 yamaguchi Exp $");
#ifdef _KERNEL_OPT
#include "opt_inet.h"
@@ -1176,7 +1176,11 @@ vlan_ether_addmulti(struct ifvlan *ifv,
*/
error = ether_multiaddr(sa, addrlo, addrhi);
KASSERT(error == 0);
+
+ ETHER_LOCK(&ifv->ifv_ec);
mc->mc_enm = ether_lookup_multi(addrlo, addrhi, &ifv->ifv_ec);
+ ETHER_UNLOCK(&ifv->ifv_ec);
+
KASSERT(mc->mc_enm != NULL);
memcpy(&mc->mc_addr, sa, sa->sa_len);
@@ -1221,7 +1225,10 @@ vlan_ether_delmulti(struct ifvlan *ifv,
*/
if ((error = ether_multiaddr(sa, addrlo, addrhi)) != 0)
return error;
+
+ ETHER_LOCK(&ifv->ifv_ec);
enm = ether_lookup_multi(addrlo, addrhi, &ifv->ifv_ec);
+ ETHER_UNLOCK(&ifv->ifv_ec);
error = ether_delmulti(sa, &ifv->ifv_ec);
if (error != ENETRESET)
Index: src/sys/netinet/ip_carp.c
diff -u src/sys/netinet/ip_carp.c:1.97 src/sys/netinet/ip_carp.c:1.98
--- src/sys/netinet/ip_carp.c:1.97 Thu Jun 14 07:54:57 2018
+++ src/sys/netinet/ip_carp.c Thu Jun 14 08:06:07 2018
@@ -1,4 +1,4 @@
-/* $NetBSD: ip_carp.c,v 1.97 2018/06/14 07:54:57 yamaguchi Exp $ */
+/* $NetBSD: ip_carp.c,v 1.98 2018/06/14 08:06:07 yamaguchi Exp $ */
/* $OpenBSD: ip_carp.c,v 1.113 2005/11/04 08:11:54 mcbride Exp $ */
/*
@@ -33,7 +33,7 @@
#endif
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ip_carp.c,v 1.97 2018/06/14 07:54:57 yamaguchi Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ip_carp.c,v 1.98 2018/06/14 08:06:07 yamaguchi Exp $");
/*
* TODO:
@@ -2312,7 +2312,11 @@ carp_ether_addmulti(struct carp_softc *s
* statement shouldn't fail.
*/
(void)ether_multiaddr(sa, addrlo, addrhi);
+
+ ETHER_LOCK(&sc->sc_ac);
mc->mc_enm = ether_lookup_multi(addrlo, addrhi, &sc->sc_ac);
+ ETHER_UNLOCK(&sc->sc_ac);
+
memcpy(&mc->mc_addr, sa, sa->sa_len);
LIST_INSERT_HEAD(&sc->carp_mc_listhead, mc, mc_entries);
@@ -2351,7 +2355,10 @@ carp_ether_delmulti(struct carp_softc *s
*/
if ((error = ether_multiaddr(sa, addrlo, addrhi)) != 0)
return (error);
+
+ ETHER_LOCK(&sc->sc_ac);
enm = ether_lookup_multi(addrlo, addrhi, &sc->sc_ac);
+ ETHER_UNLOCK(&sc->sc_ac);
if (enm == NULL)
return (EINVAL);