Commit 5fc094f5 authored by Kirill Tkhai's avatar Kirill Tkhai Committed by David S. Miller

net: Convert ip6_frags_ops

Exit methods calls inet_frags_exit_net() with global ip6_frags
as argument. So, after we make the pernet_operations async,
a pair of exit methods may be called to iterate this hash table.
Since there is inet_frag_worker(), which already may work
in parallel with inet_frags_exit_net(), and it can make the same
cleanup, that inet_frags_exit_net() does, it's safe. So we may
mark these pernet_operations as async.
Signed-off-by: default avatarKirill Tkhai <ktkhai@virtuozzo.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent d16784d9
...@@ -733,6 +733,7 @@ static void __net_exit ipv6_frags_exit_net(struct net *net) ...@@ -733,6 +733,7 @@ static void __net_exit ipv6_frags_exit_net(struct net *net)
static struct pernet_operations ip6_frags_ops = { static struct pernet_operations ip6_frags_ops = {
.init = ipv6_frags_init_net, .init = ipv6_frags_init_net,
.exit = ipv6_frags_exit_net, .exit = ipv6_frags_exit_net,
.async = true,
}; };
int __init ipv6_frag_init(void) int __init ipv6_frag_init(void)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment