mirror of
https://github.com/freebsd/freebsd-src.git
synced 2024-11-28 09:02:44 +00:00
Do not hold the lock over if_setlladdr() as it calls into the interface driver
init routine.
This commit is contained in:
parent
cc5abe58ce
commit
6117727b6c
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=202611
@ -473,6 +473,9 @@ static void
|
||||
vlan_iflladdr(void *arg __unused, struct ifnet *ifp)
|
||||
{
|
||||
struct ifvlan *ifv;
|
||||
#ifndef VLAN_ARRAY
|
||||
struct ifvlan *next;
|
||||
#endif
|
||||
int i;
|
||||
|
||||
/*
|
||||
@ -488,13 +491,15 @@ vlan_iflladdr(void *arg __unused, struct ifnet *ifp)
|
||||
*/
|
||||
#ifdef VLAN_ARRAY
|
||||
for (i = 0; i < VLAN_ARRAY_SIZE; i++)
|
||||
if ((ifv = ifp->if_vlantrunk->vlans[i]))
|
||||
if_setlladdr(ifv->ifv_ifp, IF_LLADDR(ifp), ETHER_ADDR_LEN);
|
||||
if ((ifv = ifp->if_vlantrunk->vlans[i])) {
|
||||
#else /* VLAN_ARRAY */
|
||||
for (i = 0; i < (1 << ifp->if_vlantrunk->hwidth); i++)
|
||||
LIST_FOREACH(ifv, &ifp->if_vlantrunk->hash[i], ifv_list)
|
||||
if_setlladdr(ifv->ifv_ifp, IF_LLADDR(ifp), ETHER_ADDR_LEN);
|
||||
LIST_FOREACH_SAFE(ifv, &ifp->if_vlantrunk->hash[i], ifv_list, next) {
|
||||
#endif /* VLAN_ARRAY */
|
||||
VLAN_UNLOCK();
|
||||
if_setlladdr(ifv->ifv_ifp, IF_LLADDR(ifp), ETHER_ADDR_LEN);
|
||||
VLAN_LOCK();
|
||||
}
|
||||
VLAN_UNLOCK();
|
||||
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user