diff options
author | Veaceslav Falico <vfalico@redhat.com> | 2013-04-03 01:46:33 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2013-04-05 00:46:13 -0400 |
commit | 4de79c737b200492195ebc54a887075327e1ec1d (patch) | |
tree | 13f1ea930500381271013346af4a62e364b6ade2 /drivers/net/bonding | |
parent | 31d1670e73f4911fe401273a8f576edc9c2b5fea (diff) |
bonding: remove sysfs before removing devices
We have a race condition if we try to rmmod bonding and simultaneously add
a bond master through sysfs. In bonding_exit() we first remove the devices
(through rtnl_link_unregister() ) and only after that we remove the sysfs.
If we manage to add a device through sysfs after that the devices were
removed - we'll end up with that device/sysfs structure and with the module
unloaded.
Fix this by first removing the sysfs and only after that calling
rtnl_link_unregister().
Signed-off-by: Veaceslav Falico <vfalico@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/bonding')
-rw-r--r-- | drivers/net/bonding/bond_main.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/net/bonding/bond_main.c b/drivers/net/bonding/bond_main.c index a51241b2e621..171b10f167a5 100644 --- a/drivers/net/bonding/bond_main.c +++ b/drivers/net/bonding/bond_main.c | |||
@@ -4902,8 +4902,8 @@ static void __exit bonding_exit(void) | |||
4902 | 4902 | ||
4903 | bond_destroy_debugfs(); | 4903 | bond_destroy_debugfs(); |
4904 | 4904 | ||
4905 | rtnl_link_unregister(&bond_link_ops); | ||
4906 | unregister_pernet_subsys(&bond_net_ops); | 4905 | unregister_pernet_subsys(&bond_net_ops); |
4906 | rtnl_link_unregister(&bond_link_ops); | ||
4907 | 4907 | ||
4908 | #ifdef CONFIG_NET_POLL_CONTROLLER | 4908 | #ifdef CONFIG_NET_POLL_CONTROLLER |
4909 | /* | 4909 | /* |