diff options
author | nikolay@redhat.com <nikolay@redhat.com> | 2013-04-06 02:54:38 +0200 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2013-04-08 22:45:09 +0200 |
commit | 69b0216ac255f523556fa3d4ff030d857eaaa37f (patch) | |
tree | 45138d6eae10f05815b353556fa62d57ceea35db /kernel/lockdep_proc.c | |
parent | Revert "bonding: remove sysfs before removing devices" (diff) | |
download | linux-69b0216ac255f523556fa3d4ff030d857eaaa37f.tar.xz linux-69b0216ac255f523556fa3d4ff030d857eaaa37f.zip |
bonding: fix bonding_masters race condition in bond unloading
While the bonding module is unloading, it is considered that after
rtnl_link_unregister all bond devices are destroyed but since no
synchronization mechanism exists, a new bond device can be created
via bonding_masters before unregister_pernet_subsys which would
lead to multiple problems (e.g. NULL pointer dereference, wrong RIP,
list corruption).
This patch fixes the issue by removing any bond devices left in the
netns after bonding_masters is removed from sysfs.
Signed-off-by: Nikolay Aleksandrov <nikolay@redhat.com>
Acked-by: Veaceslav Falico <vfalico@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'kernel/lockdep_proc.c')
0 files changed, 0 insertions, 0 deletions