summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKuniyuki Iwashima <kuniyu@google.com>2026-05-18 08:07:11 +0300
committerJakub Kicinski <kuba@kernel.org>2026-05-21 05:12:29 +0300
commitd38be9217277ecbfb1bedb28132887229a45c376 (patch)
treeb0c79d3bbf2906d0ca4b0dd94b3f55284e0e283f
parent567dbca22b373b05be0aa46eb2e64ee92d4f4790 (diff)
downloadlinux-d38be9217277ecbfb1bedb28132887229a45c376.tar.xz
bareudp: Remove synchronize_net() in bareudp_sock_release().
synchronize_net() in bareudp_sock_release() has existed since day 1, commit 571912c69f0e ("net: UDP tunnel encapsulation module for tunnelling different protocols like MPLS, IP, NSH etc."). It was most likely copied from a similar tunneling device like vxlan or geneve. bareudp_sock_release() is called from dev->netdev_ops->ndo_stop(), and synchronize_net() in unregister_netdevice_many_notify() ensures that inflight bareudp fast paths finish before bareudp_dev is freed. Let's remove the redundant synchronize_net() in bareudp_sock_release(). Signed-off-by: Kuniyuki Iwashima <kuniyu@google.com> Link: https://patch.msgid.link/20260518050726.318824-5-kuniyu@google.com Signed-off-by: Jakub Kicinski <kuba@kernel.org>
-rw-r--r--drivers/net/bareudp.c1
1 files changed, 0 insertions, 1 deletions
diff --git a/drivers/net/bareudp.c b/drivers/net/bareudp.c
index 890a0650d9cf..bfcecdcffe67 100644
--- a/drivers/net/bareudp.c
+++ b/drivers/net/bareudp.c
@@ -287,7 +287,6 @@ static void bareudp_sock_release(struct bareudp_dev *bareudp)
sk = bareudp->sk;
rcu_assign_pointer(bareudp->sk, NULL);
- synchronize_net();
udp_tunnel_sock_release(sk);
}