The limits might have changed in between, it is best to check them
before accepting new ADD_ADDR.

Fixes: d0876b2284cf ("mptcp: add the incoming RM_ADDR support")
Cc: [email protected]
Reviewed-by: Mat Martineau <[email protected]>
Signed-off-by: Matthieu Baerts (NGI0) <[email protected]>
---
 net/mptcp/pm_netlink.c | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/net/mptcp/pm_netlink.c b/net/mptcp/pm_netlink.c
index 882781571c7b..28a9a3726146 100644
--- a/net/mptcp/pm_netlink.c
+++ b/net/mptcp/pm_netlink.c
@@ -848,8 +848,8 @@ static void mptcp_pm_nl_rm_addr_or_subflow(struct 
mptcp_sock *msk,
                        /* Note: if the subflow has been closed before, this
                         * add_addr_accepted counter will not be decremented.
                         */
-                       msk->pm.add_addr_accepted--;
-                       WRITE_ONCE(msk->pm.accept_addr, true);
+                       if (--msk->pm.add_addr_accepted < 
mptcp_pm_get_add_addr_accept_max(msk))
+                               WRITE_ONCE(msk->pm.accept_addr, true);
                }
        }
 }

-- 
2.45.2


Reply via email to