Skip to content

Commit e0286ea

Browse files
lxingregkh
authored andcommitted
bonding: do not set slave_dev npinfo before slave_enable_netpoll in bond_enslave
[ Upstream commit ddea788 ] After Commit 8a8efa2 ("bonding: sync netpoll code with bridge"), it would set slave_dev npinfo in slave_enable_netpoll when enslaving a dev if bond->dev->npinfo was set. However now slave_dev npinfo is set with bond->dev->npinfo before calling slave_enable_netpoll. With slave_dev npinfo set, __netpoll_setup called in slave_enable_netpoll will not call slave dev's .ndo_netpoll_setup(). It causes that the lower dev of this slave dev can't set its npinfo. One way to reproduce it: # modprobe bonding # brctl addbr br0 # brctl addif br0 eth1 # ifconfig bond0 192.168.122.1/24 up # ifenslave bond0 eth2 # systemctl restart netconsole # ifenslave bond0 br0 # ifconfig eth2 down # systemctl restart netconsole The netpoll won't really work. This patch is to remove that slave_dev npinfo setting in bond_enslave(). Fixes: 8a8efa2 ("bonding: sync netpoll code with bridge") Signed-off-by: Xin Long <[email protected]> Signed-off-by: David S. Miller <[email protected]> Signed-off-by: Greg Kroah-Hartman <[email protected]>
1 parent 5f50186 commit e0286ea

File tree

1 file changed

+1
-2
lines changed

1 file changed

+1
-2
lines changed

drivers/net/bonding/bond_main.c

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1656,8 +1656,7 @@ int bond_enslave(struct net_device *bond_dev, struct net_device *slave_dev)
16561656
} /* switch(bond_mode) */
16571657

16581658
#ifdef CONFIG_NET_POLL_CONTROLLER
1659-
slave_dev->npinfo = bond->dev->npinfo;
1660-
if (slave_dev->npinfo) {
1659+
if (bond->dev->npinfo) {
16611660
if (slave_enable_netpoll(new_slave)) {
16621661
netdev_info(bond_dev, "master_dev is using netpoll, but new slave device does not support netpoll\n");
16631662
res = -EBUSY;

0 commit comments

Comments
 (0)