Commit 41862d12 authored by Eric Dumazet's avatar Eric Dumazet Committed by David S. Miller

net: use indirect call helpers for sk->sk_prot->release_cb()

When adding sk->sk_prot->release_cb() call from __sk_flush_backlog()
Paolo suggested using indirect call helpers to take care of
CONFIG_RETPOLINE=y case.

It turns out Google had such mitigation for years in release_sock(),
it is time to make this public :)
Suggested-by: default avatarPaolo Abeni <pabeni@redhat.com>
Signed-off-by: default avatarEric Dumazet <edumazet@google.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 4fa5ce3e
...@@ -3003,7 +3003,9 @@ void __sk_flush_backlog(struct sock *sk) ...@@ -3003,7 +3003,9 @@ void __sk_flush_backlog(struct sock *sk)
__release_sock(sk); __release_sock(sk);
if (sk->sk_prot->release_cb) if (sk->sk_prot->release_cb)
sk->sk_prot->release_cb(sk); INDIRECT_CALL_INET_1(sk->sk_prot->release_cb,
tcp_release_cb, sk);
spin_unlock_bh(&sk->sk_lock.slock); spin_unlock_bh(&sk->sk_lock.slock);
} }
EXPORT_SYMBOL_GPL(__sk_flush_backlog); EXPORT_SYMBOL_GPL(__sk_flush_backlog);
...@@ -3523,7 +3525,8 @@ void release_sock(struct sock *sk) ...@@ -3523,7 +3525,8 @@ void release_sock(struct sock *sk)
__release_sock(sk); __release_sock(sk);
if (sk->sk_prot->release_cb) if (sk->sk_prot->release_cb)
sk->sk_prot->release_cb(sk); INDIRECT_CALL_INET_1(sk->sk_prot->release_cb,
tcp_release_cb, sk);
sock_release_ownership(sk); sock_release_ownership(sk);
if (waitqueue_active(&sk->sk_lock.wq)) if (waitqueue_active(&sk->sk_lock.wq))
......
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