Skip to content

Commit 3b82c15

Browse files
matttbegregkh
authored andcommitted
mptcp: pm: remove mptcp_pm_remove_subflow()
commit f448451 upstream. This helper is confusing. It is in pm.c, but it is specific to the in-kernel PM and it cannot be used by the userspace one. Also, it simply calls one in-kernel specific function with the PM lock, while the similar mptcp_pm_remove_addr() helper requires the PM lock. What's left is the pr_debug(), which is not that useful, because a similar one is present in the only function called by this helper: mptcp_pm_nl_rm_subflow_received() After these modifications, this helper can be marked as 'static', and the lock can be taken only once in mptcp_pm_flush_addrs_and_subflows(). Note that it is not a bug fix, but it will help backporting the following commits. Fixes: 0ee4261 ("mptcp: implement mptcp_pm_remove_subflow") Cc: stable@vger.kernel.org Reviewed-by: Mat Martineau <martineau@kernel.org> Signed-off-by: Matthieu Baerts (NGI0) <matttbe@kernel.org> Link: https://patch.msgid.link/20240819-net-mptcp-pm-reusing-id-v1-7-38035d40de5b@kernel.org Signed-off-by: Jakub Kicinski <kuba@kernel.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
1 parent ef7a65b commit 3b82c15

3 files changed

Lines changed: 7 additions & 22 deletions

File tree

net/mptcp/pm.c

Lines changed: 0 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -60,16 +60,6 @@ int mptcp_pm_remove_addr(struct mptcp_sock *msk, const struct mptcp_rm_list *rm_
6060
return 0;
6161
}
6262

63-
int mptcp_pm_remove_subflow(struct mptcp_sock *msk, const struct mptcp_rm_list *rm_list)
64-
{
65-
pr_debug("msk=%p, rm_list_nr=%d", msk, rm_list->nr);
66-
67-
spin_lock_bh(&msk->pm.lock);
68-
mptcp_pm_nl_rm_subflow_received(msk, rm_list);
69-
spin_unlock_bh(&msk->pm.lock);
70-
return 0;
71-
}
72-
7363
/* path manager event handlers */
7464

7565
void mptcp_pm_new_connection(struct mptcp_sock *msk, const struct sock *ssk, int server_side)

net/mptcp/pm_netlink.c

Lines changed: 7 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -857,8 +857,8 @@ static void mptcp_pm_nl_rm_addr_received(struct mptcp_sock *msk)
857857
mptcp_pm_nl_rm_addr_or_subflow(msk, &msk->pm.rm_list_rx, MPTCP_MIB_RMADDR);
858858
}
859859

860-
void mptcp_pm_nl_rm_subflow_received(struct mptcp_sock *msk,
861-
const struct mptcp_rm_list *rm_list)
860+
static void mptcp_pm_nl_rm_subflow_received(struct mptcp_sock *msk,
861+
const struct mptcp_rm_list *rm_list)
862862
{
863863
mptcp_pm_nl_rm_addr_or_subflow(msk, rm_list, MPTCP_MIB_RMSUBFLOW);
864864
}
@@ -1471,7 +1471,9 @@ static int mptcp_nl_remove_subflow_and_signal_addr(struct net *net,
14711471
!(entry->flags & MPTCP_PM_ADDR_FLAG_IMPLICIT));
14721472

14731473
if (remove_subflow) {
1474-
mptcp_pm_remove_subflow(msk, &list);
1474+
spin_lock_bh(&msk->pm.lock);
1475+
mptcp_pm_nl_rm_subflow_received(msk, &list);
1476+
spin_unlock_bh(&msk->pm.lock);
14751477
} else if (entry->flags & MPTCP_PM_ADDR_FLAG_SUBFLOW) {
14761478
/* If the subflow has been used, but now closed */
14771479
spin_lock_bh(&msk->pm.lock);
@@ -1617,18 +1619,14 @@ static void mptcp_pm_remove_addrs_and_subflows(struct mptcp_sock *msk,
16171619
alist.ids[alist.nr++] = entry->addr.id;
16181620
}
16191621

1622+
spin_lock_bh(&msk->pm.lock);
16201623
if (alist.nr) {
1621-
spin_lock_bh(&msk->pm.lock);
16221624
msk->pm.add_addr_signaled -= alist.nr;
16231625
mptcp_pm_remove_addr(msk, &alist);
1624-
spin_unlock_bh(&msk->pm.lock);
16251626
}
1626-
16271627
if (slist.nr)
1628-
mptcp_pm_remove_subflow(msk, &slist);
1629-
1628+
mptcp_pm_nl_rm_subflow_received(msk, &slist);
16301629
/* Reset counters: maybe some subflows have been removed before */
1631-
spin_lock_bh(&msk->pm.lock);
16321630
bitmap_fill(msk->pm.id_avail_bitmap, MPTCP_PM_MAX_ADDR_ID + 1);
16331631
msk->pm.local_addr_used = 0;
16341632
spin_unlock_bh(&msk->pm.lock);

net/mptcp/protocol.h

Lines changed: 0 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -1021,7 +1021,6 @@ int mptcp_pm_announce_addr(struct mptcp_sock *msk,
10211021
const struct mptcp_addr_info *addr,
10221022
bool echo);
10231023
int mptcp_pm_remove_addr(struct mptcp_sock *msk, const struct mptcp_rm_list *rm_list);
1024-
int mptcp_pm_remove_subflow(struct mptcp_sock *msk, const struct mptcp_rm_list *rm_list);
10251024
void mptcp_pm_remove_addrs(struct mptcp_sock *msk, struct list_head *rm_list);
10261025

10271026
void mptcp_free_local_addr_list(struct mptcp_sock *msk);
@@ -1128,8 +1127,6 @@ static inline u8 subflow_get_local_id(const struct mptcp_subflow_context *subflo
11281127

11291128
void __init mptcp_pm_nl_init(void);
11301129
void mptcp_pm_nl_work(struct mptcp_sock *msk);
1131-
void mptcp_pm_nl_rm_subflow_received(struct mptcp_sock *msk,
1132-
const struct mptcp_rm_list *rm_list);
11331130
unsigned int mptcp_pm_get_add_addr_signal_max(const struct mptcp_sock *msk);
11341131
unsigned int mptcp_pm_get_add_addr_accept_max(const struct mptcp_sock *msk);
11351132
unsigned int mptcp_pm_get_subflows_max(const struct mptcp_sock *msk);

0 commit comments

Comments
 (0)