linux/drivers/net/team
Ido Schimmel 942f64c4c2 team: Fix possible deadlock during team enslave
Both dev_uc_sync_multiple() and dev_mc_sync_multiple() require the
source device to be locked by netif_addr_lock_bh(), but this is missing
in team's enslave function, so add it.

This fixes the following lockdep warning:

Possible interrupt unsafe locking scenario:

        CPU0                    CPU1
        ----                    ----
   lock(_xmit_ETHER/1);
                                local_irq_disable();
                                lock(&(&mc->mca_lock)->rlock);
                                lock(&team_netdev_addr_lock_key);
   <Interrupt>
     lock(&(&mc->mca_lock)->rlock);

  *** DEADLOCK ***

Fixes: cb41c997d4 ("team: team should sync the port's uc/mc addrs when add a port")
Signed-off-by: Jiri Pirko <jiri@mellanox.com>
Signed-off-by: Ido Schimmel <idosch@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-06-22 16:31:03 -04:00
..
Kconfig team: introduce random mode 2013-03-06 14:55:20 -05:00
Makefile team: introduce random mode 2013-03-06 14:55:20 -05:00
team.c team: Fix possible deadlock during team enslave 2016-06-22 16:31:03 -04:00
team_mode_activebackup.c team: fill-up LAG changeupper info struct and pass it along 2015-12-03 11:49:26 -05:00
team_mode_broadcast.c team: fill-up LAG changeupper info struct and pass it along 2015-12-03 11:49:26 -05:00
team_mode_loadbalance.c team: fill-up LAG changeupper info struct and pass it along 2015-12-03 11:49:26 -05:00
team_mode_random.c team: fill-up LAG changeupper info struct and pass it along 2015-12-03 11:49:26 -05:00
team_mode_roundrobin.c team: fill-up LAG changeupper info struct and pass it along 2015-12-03 11:49:26 -05:00