From: Liu Jian <liujian56@huawei.com> To: <john.fastabend@gmail.com>, <daniel@iogearbox.net>, <jakub@cloudflare.com>, <lmb@cloudflare.com>, <edumazet@google.com>, <davem@davemloft.net>, <yoshfuji@linux-ipv6.org>, <dsahern@kernel.org>, <kuba@kernel.org>, <ast@kernel.org>, <andrii@kernel.org>, <kafai@fb.com>, <songliubraving@fb.com>, <yhs@fb.com>, <kpsingh@kernel.org>, <netdev@vger.kernel.org>, <bpf@vger.kernel.org> Cc: <liujian56@huawei.com> Subject: [PATCH] tcp_bpf: Fix one concurrency problem in the tcp_bpf_send_verdict function Date: Wed, 29 Sep 2021 16:45:29 +0800 [thread overview] Message-ID: <20210929084529.96583-1-liujian56@huawei.com> (raw) In the following cases: We need to redirect the first msg to sock1 and the second msg to sock2. The sock lock needs to be released at __SK_REDIRECT and to get another sock lock, this will cause the probability that psock->eval is not set to __SK_NONE when the second msg comes. If psock does not set apple bytes, fix this by do the cleanup before releasing the sock lock. And keep the original logic in other cases. Signed-off-by: Liu Jian <liujian56@huawei.com> --- net/ipv4/tcp_bpf.c | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/net/ipv4/tcp_bpf.c b/net/ipv4/tcp_bpf.c index d3e9386b493e..02442e43ac4d 100644 --- a/net/ipv4/tcp_bpf.c +++ b/net/ipv4/tcp_bpf.c @@ -232,6 +232,7 @@ static int tcp_bpf_send_verdict(struct sock *sk, struct sk_psock *psock, bool cork = false, enospc = sk_msg_full(msg); struct sock *sk_redir; u32 tosend, delta = 0; + u32 eval = __SK_NONE; int ret; more_data: @@ -274,6 +275,12 @@ static int tcp_bpf_send_verdict(struct sock *sk, struct sk_psock *psock, break; case __SK_REDIRECT: sk_redir = psock->sk_redir; + if (!psock->apply_bytes) { + /* Clean up before releasing the sock lock. */ + eval = psock->eval; + psock->eval = __SK_NONE; + psock->sk_redir = NULL; + } sk_msg_apply_bytes(psock, tosend); if (psock->cork) { cork = true; @@ -281,7 +288,12 @@ static int tcp_bpf_send_verdict(struct sock *sk, struct sk_psock *psock, } sk_msg_return(sk, msg, tosend); release_sock(sk); + ret = tcp_bpf_sendmsg_redir(sk_redir, msg, tosend, flags); + + if (eval == __SK_REDIRECT) + sock_put(sk_redir); + lock_sock(sk); if (unlikely(ret < 0)) { int free = sk_msg_free_nocharge(sk, msg); -- 2.17.1
next reply other threads:[~2021-09-29 8:45 UTC|newest] Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top 2021-09-29 8:45 Liu Jian [this message] 2021-09-30 22:25 ` John Fastabend 2021-10-04 4:21 ` liujian (CE)
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=20210929084529.96583-1-liujian56@huawei.com \ --to=liujian56@huawei.com \ --cc=andrii@kernel.org \ --cc=ast@kernel.org \ --cc=bpf@vger.kernel.org \ --cc=daniel@iogearbox.net \ --cc=davem@davemloft.net \ --cc=dsahern@kernel.org \ --cc=edumazet@google.com \ --cc=jakub@cloudflare.com \ --cc=john.fastabend@gmail.com \ --cc=kafai@fb.com \ --cc=kpsingh@kernel.org \ --cc=kuba@kernel.org \ --cc=lmb@cloudflare.com \ --cc=netdev@vger.kernel.org \ --cc=songliubraving@fb.com \ --cc=yhs@fb.com \ --cc=yoshfuji@linux-ipv6.org \ --subject='Re: [PATCH] tcp_bpf: Fix one concurrency problem in the tcp_bpf_send_verdict function' \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: link
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).