aboutsummaryrefslogtreecommitdiffstats
path: root/tools/testing/selftests/netfilter
diff options
context:
space:
mode:
authorJakub Kicinski <kuba@kernel.org>2021-01-06 10:40:07 -0800
committerJakub Kicinski <kuba@kernel.org>2021-01-08 19:27:41 -0800
commit766b0515d5bec4b780750773ed3009b148df8c0a (patch)
tree39c5fc95f6407f5bf134df340f64219e0b5fba89 /tools/testing/selftests/netfilter
parentnet: make free_netdev() more lenient with unregistering devices (diff)
downloadlinux-dev-766b0515d5bec4b780750773ed3009b148df8c0a.tar.xz
linux-dev-766b0515d5bec4b780750773ed3009b148df8c0a.zip
net: make sure devices go through netdev_wait_all_refs
If register_netdevice() fails at the very last stage - the notifier call - some subsystems may have already seen it and grabbed a reference. struct net_device can't be freed right away without calling netdev_wait_all_refs(). Now that we have a clean interface in form of dev->needs_free_netdev and lenient free_netdev() we can undo what commit 93ee31f14f6f ("[NET]: Fix free_netdev on register_netdev failure.") has done and complete the unregistration path by bringing the net_set_todo() call back. After registration fails user is still expected to explicitly free the net_device, so make sure ->needs_free_netdev is cleared, otherwise rolling back the registration will cause the old double free for callers who release rtnl_lock before the free. This also solves the problem of priv_destructor not being called on notifier error. net_set_todo() will be moved back into unregister_netdevice_queue() in a follow up. Reported-by: Hulk Robot <hulkci@huawei.com> Reported-by: Yang Yingliang <yangyingliang@huawei.com> Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Diffstat (limited to 'tools/testing/selftests/netfilter')
0 files changed, 0 insertions, 0 deletions