Skip to content

Commit a81ce1e

Browse files
Geliang Tangintel-lab-lkp
authored andcommitted
mptcp: drop useless "err = 0" in subflow_destroy
Upon successful return, mptcp_pm_parse_addr() returns 0. There is no need to set "err = 0" after this. So after mptcp_nl_find_ssk() returns, just need to set "err = -ESRCH", then release and free msk socket if it returns NULL. Also, no need to define the veriable "subflow" in subflow_destroy(), use mptcp_subflow_ctx(ssk) directly. This patch doesn't change the behaviour of the code, just refactoring. Signed-off-by: Geliang Tang <[email protected]>
1 parent 34d0fcc commit a81ce1e

File tree

1 file changed

+10
-11
lines changed

1 file changed

+10
-11
lines changed

net/mptcp/pm_userspace.c

Lines changed: 10 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -537,19 +537,18 @@ int mptcp_pm_nl_subflow_destroy_doit(struct sk_buff *skb, struct genl_info *info
537537

538538
lock_sock(sk);
539539
ssk = mptcp_nl_find_ssk(msk, &addr_l.addr, &addr_r);
540-
if (ssk) {
541-
struct mptcp_subflow_context *subflow = mptcp_subflow_ctx(ssk);
542-
543-
spin_lock_bh(&msk->pm.lock);
544-
mptcp_userspace_pm_delete_local_addr(msk, &addr_l);
545-
spin_unlock_bh(&msk->pm.lock);
546-
mptcp_subflow_shutdown(sk, ssk, RCV_SHUTDOWN | SEND_SHUTDOWN);
547-
mptcp_close_ssk(sk, ssk, subflow);
548-
MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_RMSUBFLOW);
549-
err = 0;
550-
} else {
540+
if (!ssk) {
551541
err = -ESRCH;
542+
goto release_sock;
552543
}
544+
545+
spin_lock_bh(&msk->pm.lock);
546+
mptcp_userspace_pm_delete_local_addr(msk, &addr_l);
547+
spin_unlock_bh(&msk->pm.lock);
548+
mptcp_subflow_shutdown(sk, ssk, RCV_SHUTDOWN | SEND_SHUTDOWN);
549+
mptcp_close_ssk(sk, ssk, mptcp_subflow_ctx(ssk));
550+
MPTCP_INC_STATS(sock_net(sk), MPTCP_MIB_RMSUBFLOW);
551+
release_sock:
553552
release_sock(sk);
554553

555554
destroy_err:

0 commit comments

Comments
 (0)