Received: by 2002:ab2:3350:0:b0:1f4:6588:b3a7 with SMTP id o16csp847335lqe; Sun, 7 Apr 2024 06:45:18 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCWWITdzGCL+T0nNiXDXIXCijWrfDOBBJFQlJ7gCHhPQxbDl3NpdeKcOoLipxHOdIe2Z4taqNnh8jYuZ3KOX9hb+JkR5oUTKCR6kbLzvHA== X-Google-Smtp-Source: AGHT+IGu/AvRsm0UD0mARPrvuLivDdH9Abc57CGtwsQdQUpN2UpgPRAXloKRGFMp2yc2tkpdLpfa X-Received: by 2002:a05:6e02:17cd:b0:36a:64c:6d15 with SMTP id z13-20020a056e0217cd00b0036a064c6d15mr7838194ilu.6.1712497518385; Sun, 07 Apr 2024 06:45:18 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1712497518; cv=pass; d=google.com; s=arc-20160816; b=tuLXjRrq9lZiKLXC5DDcfLwAk8U83eOdmlTitbcVSwRXvnHiWjuumbiuj+H5LiC/eC JVTfBiITgDSoDXaFppfDMhwJzNJSIgeDpwQkLQh1Piq3+bFbb9VNN+CKWmc3g/2FbTaX FmFjyPwLDqk9cbCxAautcXa60TOVa2nQqm4gnWTbmLu2T6f5pBEBLTlBUWdl6j+P8Qrh Bg7wutOC9kkqgA58S25AIs1/Gf9S1u+2Py644vUuyNhxDB/X16wM7etksHHTrVkkbOaC p2yVql/agDY7ofGr+FqDEDf61ga0lxb3fjKEwP8jKYhcPxBVjHKmub8uMettgX74N0yC SHoA== ARC-Message-Signature: i=2; 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=CK4D/uu0jCgc/STQfQFK6prjXA9wJ5ei9FQJHC4OzUs=; fh=Mrov6VoeCAhgJr0JkxqHZ6IWKlxE211Gu2NjcxNxDKw=; b=uErmTr7c09Tm2J+QHW23v+W8Sy2d8zJ+Emwjx6d1hyI7WtpXWRYnbY4pnM15dwMXsp /whQyc0nEmZmDatwBlMbHIFBl9gl6QIp6rHiMm6sL/LyHKQ6q8U/i+lgkjZEVlYfUITv HkUamQiyZGAKu+5p/FZgbIEe6Bd+/bJOFPz/JTHM3+AOML1W6uOwn55sGR8+iYPEu3mM JymaedAmv4eOT+jp5Y9zwA5WI4+eu3NFH3JtvtjunspKtjRe06WXTRLOIn1JIp2J2gTN dX0wuS56np7G5iWxccRLO9mayBwgV5FnkR1dMNqMUp/y7pWlyb+XQj9WX0MjcjMttlti r/EA==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=Weg4CN19; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-134493-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-134493-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [2604:1380:40f1:3f00::1]) by mx.google.com with ESMTPS id t2-20020a63eb02000000b005d39e412039si4624555pgh.8.2024.04.07.06.45.17 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 07 Apr 2024 06:45:18 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-134493-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) client-ip=2604:1380:40f1:3f00::1; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=Weg4CN19; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-134493-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:40f1:3f00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-134493-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org 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 sy.mirrors.kernel.org (Postfix) with ESMTPS id 09BC7B21D6C for ; Sun, 7 Apr 2024 13:40:32 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id BF92113A263; Sun, 7 Apr 2024 13:14:23 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="Weg4CN19" Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (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 E35F113A254; Sun, 7 Apr 2024 13:14:22 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1712495663; cv=none; b=UL/tGzQ8T7bXxtdlNBcSS6lUPExUyZx1p7FEOL//fhbUxiLH3naMZTv23XB8+8RbAAD2nN/p9Q2dWuz/o4f3y6PtF0i9RLWBSKTo8kNKDxxY/fLKbQUlRCRgJEVf7R7iKTd/NC+tJWLAaUHX9QYkoAGkhp5YcgmSNN4V6k03QI8= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1712495663; c=relaxed/simple; bh=epT7Kmq/2yLTGhfFtDS4b2fXc/1yb8F+ExvuFkDp7kI=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=seDbLRSRtQEN1scq95GlAbsWpo0DCBMTSe4F3wbhARf7yED9agmcm7G5nKWMPy/ye+sYYrcpBfvORVjUNWyV28Zy10S5Tg6tRdA7GVeJsef4AcXWq0bbdWGdCN1460j4GIPFRiPNdryfrE7N3wDIoIg+sd2rdRcvdjbgNq7ElXI= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=Weg4CN19; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id 2B712C43390; Sun, 7 Apr 2024 13:14:21 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1712495662; bh=epT7Kmq/2yLTGhfFtDS4b2fXc/1yb8F+ExvuFkDp7kI=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Weg4CN19D7jNTxO2gEPIE9z6w8ROn4BpwEAxEQAaPWyF+jVgnc3wuba2/FUhHyHvc jLXVU6qZwNmQTWJHpuKs9JlRyYKQOK85+ZEQf8hd3avwZ2Lb8R/5NDpJtlIprhgoyw MZrF9OyZerFlQm9EWCPsZhJWRP0EOqtFCfZJUgao49GjBm6bFHEBLYpN3MiH5Dd/FQ J7F0/AKubINIKjDceo3kch4pdKOutgvy4EZw7zlOMLs3orGxsPdosBzljfCAOVkzZ5 YbqPOeaA+VEkSkRetlC+bX2DcGJ3ELnuKL2xayXY6dnweJpSNwX626t7S4ki5Nqg9w Z9S6iLlexcl3w== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: linke li , Eric Dumazet , "David S . Miller" , Sasha Levin , kuba@kernel.org, pabeni@redhat.com, kuniyu@amazon.com, wuyun.abel@bytedance.com, leitao@debian.org, alexander@mihalicyn.com, dhowells@redhat.com, netdev@vger.kernel.org Subject: [PATCH AUTOSEL 5.4 5/6] net: mark racy access on sk->sk_rcvbuf Date: Sun, 7 Apr 2024 09:14:11 -0400 Message-ID: <20240407131414.1053600-5-sashal@kernel.org> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20240407131414.1053600-1-sashal@kernel.org> References: <20240407131414.1053600-1-sashal@kernel.org> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore X-stable-base: Linux 5.4.273 Content-Transfer-Encoding: 8bit From: linke li [ Upstream commit c2deb2e971f5d9aca941ef13ee05566979e337a4 ] sk->sk_rcvbuf in __sock_queue_rcv_skb() and __sk_receive_skb() can be changed by other threads. Mark this as benign using READ_ONCE(). This patch is aimed at reducing the number of benign races reported by KCSAN in order to focus future debugging effort on harmful races. Signed-off-by: linke li Reviewed-by: Eric Dumazet Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- net/core/sock.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/net/core/sock.c b/net/core/sock.c index daeb0e69c71b4..2b68a93adfa8d 100644 --- a/net/core/sock.c +++ b/net/core/sock.c @@ -453,7 +453,7 @@ int __sock_queue_rcv_skb(struct sock *sk, struct sk_buff *skb) unsigned long flags; struct sk_buff_head *list = &sk->sk_receive_queue; - if (atomic_read(&sk->sk_rmem_alloc) >= sk->sk_rcvbuf) { + if (atomic_read(&sk->sk_rmem_alloc) >= READ_ONCE(sk->sk_rcvbuf)) { atomic_inc(&sk->sk_drops); trace_sock_rcvqueue_full(sk, skb); return -ENOMEM; @@ -505,7 +505,7 @@ int __sk_receive_skb(struct sock *sk, struct sk_buff *skb, skb->dev = NULL; - if (sk_rcvqueues_full(sk, sk->sk_rcvbuf)) { + if (sk_rcvqueues_full(sk, READ_ONCE(sk->sk_rcvbuf))) { atomic_inc(&sk->sk_drops); goto discard_and_relse; } -- 2.43.0