From nobody Thu Sep 18 08:18:37 2025 Delivered-To: wpasupplicant.patchew@gmail.com Received: by 2002:a05:6a06:869:b0:4b8:7781:bd2f with SMTP id d41csp696949pis; Tue, 26 Apr 2022 14:57:31 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwj/CBAznP6yxmYvdoNx8AX8/WMs0+dCOQgv3C6R5gqXx+ASu6bdRU3sPsMUM1Tvcdkwl1+ X-Received: by 2002:a05:6402:1941:b0:413:2b5f:9074 with SMTP id f1-20020a056402194100b004132b5f9074mr26789278edz.414.1651010251136; Tue, 26 Apr 2022 14:57:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1651010251; cv=none; d=google.com; s=arc-20160816; b=A8gzeD+V6Q3P3LI8l0iwGyt8HxMHuLgUNHn0FLNFUNTabfiKYuqF9qzWwKV074Zq+V bVHu4vW3kyEGnjatG4CYPxZesXCZwoqvLVIGjJH8W2E1LwlztT6Fr1kULGbdrFSTGZvz FY11yQcJEm5a6p0MlPo3cdV5/XlqfJRDlW+57PjSnVuRbml+87th2JWpOsZA0/PJqgmd iu3UF0hbJZu6fDPxzxF3g4yPxDT9RrWQcpMKfi2tv9NPUB914T84RQ6w6tR0O/aMcwsC V2qTxdRg5V6DNebFG7ep/MUMHZrqOE52S8a4a9J/fgwt1jZ+FHCUcAIYwuqfoGrF7ykn h2ig== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=YZF7iBjyJ8UpFN3cZmJaOMVtxK8Pn7Z3ZkSg1XyYllQ=; b=GMqglkW3pS3PrCIwg2j+6795wkVpnYkqwiVFYXjWi+5xIsd0yJTgTh09JIk7WZP2Tj hbKWugkvxVI8rsEYlGfKgqiInT5aVlDk65Wqa17tK/YDt7791lqQB4F8mM8FBYnwC76a 3Lx3y2hGImCcKZdea7uxuujqVFI5ygS78o2lwUAzkEvE7KPP0sxIz/4n9PqPMDjAMUr1 0LexVhbDmSU56rjMY29cCbGlsz47QwByficqjznCW0AtjInxjKplcO0SrVPFLNqA+dmH O/80/7B9/pQDIqYGB81NzybAypDnC/J+FPA8swlt/uLMRyOQpoIQ6m62Gf3YZOjr8waB 0oSA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=V0eSC4yv; spf=pass (google.com: domain of mptcp+bounces-4902-wpasupplicant.patchew=gmail.com@lists.linux.dev designates 2604:1380:4040:4f00::1 as permitted sender) smtp.mailfrom="mptcp+bounces-4902-wpasupplicant.patchew=gmail.com@lists.linux.dev"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from da.mirrors.kernel.org (da.mirrors.kernel.org. [2604:1380:4040:4f00::1]) by mx.google.com with ESMTPS id f14-20020a17090624ce00b006f3a0b4e2basi4453185ejb.614.2022.04.26.14.57.30 for (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Tue, 26 Apr 2022 14:57:31 -0700 (PDT) Received-SPF: pass (google.com: domain of mptcp+bounces-4902-wpasupplicant.patchew=gmail.com@lists.linux.dev designates 2604:1380:4040:4f00::1 as permitted sender) client-ip=2604:1380:4040:4f00::1; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=V0eSC4yv; spf=pass (google.com: domain of mptcp+bounces-4902-wpasupplicant.patchew=gmail.com@lists.linux.dev designates 2604:1380:4040:4f00::1 as permitted sender) smtp.mailfrom="mptcp+bounces-4902-wpasupplicant.patchew=gmail.com@lists.linux.dev"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by da.mirrors.kernel.org (Postfix) with ESMTPS id 13EA22E0334 for ; Tue, 26 Apr 2022 21:57:30 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id EE10533C3; Tue, 26 Apr 2022 21:57:27 +0000 (UTC) X-Original-To: mptcp@lists.linux.dev Received: from mga06.intel.com (mga06b.intel.com [134.134.136.31]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id E434133DC for ; Tue, 26 Apr 2022 21:57:26 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1651010246; x=1682546246; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version:content-transfer-encoding; bh=JYk3TyUbDhDUxu3NzojGlAGOTE6VhZ0AbqCyRH92EY8=; b=V0eSC4yvGl3D6nHqZRWNRlGfdDkqrrRj08APG8MYLtfdJcAkeCeHImNY zR9eckhutv0tj9Fv/+MVlzggJmKOG+4KyeIq5rtoARcYyQw0btVANe9oW qElucYPNOWxQL5OkN+51j+mD299CNhe8Y9hjshJJ8VM0EFFiK1eyKwSQb NZNqcGYwfUf8y/2YrHS2KGRWWvLZ2hh3V9Mqo41fkj4KC7rbqv8bjhaEi oUiSNv+yLY38Qh4Nu9TxSAtO+U43AQo36fbA7wPX0RRo3v+lJc+7FFtE5 aok1dekQjiu1/fkryUmQXcQaSigd8SQXKQpUhUsukyJuJ/oGd1aLWDuM5 Q==; X-IronPort-AV: E=McAfee;i="6400,9594,10329"; a="326222715" X-IronPort-AV: E=Sophos;i="5.90,292,1643702400"; d="scan'208";a="326222715" Received: from orsmga006.jf.intel.com ([10.7.209.51]) by orsmga104.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 26 Apr 2022 14:57:23 -0700 X-IronPort-AV: E=Sophos;i="5.90,292,1643702400"; d="scan'208";a="532878096" Received: from mjmartin-desk2.amr.corp.intel.com (HELO mjmartin-desk2.intel.com) ([10.209.10.176]) by orsmga006-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 26 Apr 2022 14:57:23 -0700 From: Mat Martineau To: netdev@vger.kernel.org Cc: Geliang Tang , davem@davemloft.net, kuba@kernel.org, pabeni@redhat.com, matthieu.baerts@tessares.net, mptcp@lists.linux.dev, Mat Martineau Subject: [PATCH net-next 3/7] mptcp: add data lock for sk timers Date: Tue, 26 Apr 2022 14:57:13 -0700 Message-Id: <20220426215717.129506-4-mathew.j.martineau@linux.intel.com> X-Mailer: git-send-email 2.36.0 In-Reply-To: <20220426215717.129506-1-mathew.j.martineau@linux.intel.com> References: <20220426215717.129506-1-mathew.j.martineau@linux.intel.com> Precedence: bulk X-Mailing-List: mptcp@lists.linux.dev List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Content-Type: text/plain; charset="utf-8" From: Geliang Tang mptcp_data_lock() needs to be held when manipulating the msk retransmit_timer or the sk sk_timer. This patch adds the data lock for the both timers. Signed-off-by: Geliang Tang Signed-off-by: Mat Martineau --- net/mptcp/protocol.c | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/net/mptcp/protocol.c b/net/mptcp/protocol.c index e3db319ce92e..ea74122065f1 100644 --- a/net/mptcp/protocol.c +++ b/net/mptcp/protocol.c @@ -1605,8 +1605,10 @@ void __mptcp_push_pending(struct sock *sk, unsigned = int flags) =20 out: /* ensure the rtx timer is running */ + mptcp_data_lock(sk); if (!mptcp_timer_pending(sk)) mptcp_reset_timer(sk); + mptcp_data_unlock(sk); if (copied) __mptcp_check_send_data_fin(sk); } @@ -2491,8 +2493,10 @@ static void __mptcp_retrans(struct sock *sk) reset_timer: mptcp_check_and_set_pending(sk); =20 + mptcp_data_lock(sk); if (!mptcp_timer_pending(sk)) mptcp_reset_timer(sk); + mptcp_data_unlock(sk); } =20 static void mptcp_worker(struct work_struct *work) @@ -2651,8 +2655,10 @@ void mptcp_subflow_shutdown(struct sock *sk, struct = sock *ssk, int how) } else { pr_debug("Sending DATA_FIN on subflow %p", ssk); tcp_send_ack(ssk); + mptcp_data_lock(sk); if (!mptcp_timer_pending(sk)) mptcp_reset_timer(sk); + mptcp_data_unlock(sk); } break; } @@ -2753,8 +2759,10 @@ static void __mptcp_destroy_sock(struct sock *sk) /* join list will be eventually flushed (with rst) at sock lock release t= ime*/ list_splice_init(&msk->conn_list, &conn_list); =20 + mptcp_data_lock(sk); mptcp_stop_timer(sk); sk_stop_timer(sk, &sk->sk_timer); + mptcp_data_unlock(sk); msk->pm.status =3D 0; =20 /* clears msk->subflow, allowing the following loop to close @@ -2816,7 +2824,9 @@ static void mptcp_close(struct sock *sk, long timeout) __mptcp_destroy_sock(sk); do_cancel_work =3D true; } else { + mptcp_data_lock(sk); sk_reset_timer(sk, &sk->sk_timer, jiffies + TCP_TIMEWAIT_LEN); + mptcp_data_unlock(sk); } release_sock(sk); if (do_cancel_work) @@ -2861,8 +2871,10 @@ static int mptcp_disconnect(struct sock *sk, int fla= gs) __mptcp_close_ssk(sk, ssk, subflow, MPTCP_CF_FASTCLOSE); } =20 + mptcp_data_lock(sk); mptcp_stop_timer(sk); sk_stop_timer(sk, &sk->sk_timer); + mptcp_data_unlock(sk); =20 if (mptcp_sk(sk)->token) mptcp_event(MPTCP_EVENT_CLOSED, mptcp_sk(sk), NULL, GFP_KERNEL); --=20 2.36.0