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);
 

Reply via email to