Received: by 2002:a05:6a10:6d25:0:0:0:0 with SMTP id gq37csp1903533pxb; Mon, 13 Sep 2021 07:52:21 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzn/4U9Q+bWkonKJaEn+8bYb0i1guQL+VfwORTIeqMWaQ1L8vkz7GHE70qKfHixkN9Dfg/D X-Received: by 2002:a5d:851a:: with SMTP id q26mr9201863ion.163.1631544740892; Mon, 13 Sep 2021 07:52:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1631544740; cv=none; d=google.com; s=arc-20160816; b=g//myskCGvqWMuGDhQggThw6fShaXY9j9qbgdvkP2bdEom7wt5SawDf80ahcZEywTo 9fp0pTa1K9fiRzzGRY5V0FCAEKQBzIj/noIK6UZeWfOz9T/1nAyENKQlporqkHtUQQKZ tNsO8GHLbGSvD5q1NXwdT5aO2LDFIcgcSuzI3MoNCq+Bkwy57BObDT8Xj5oq3pZwQBT4 ViaUDhzIECwvm+r74n/+e9XbMAEWuvTmCyy19e+4Jq9ovhDr5XEYmypq8KVJ0a/4Dtu7 WeYDlrJvHYPKE93TydB/+CqBK5z7VyrFF4/76m99y1u7AIPgKL7KtM/y8lX5qIu+kxo8 c4aQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=Dwc+e4HImzIXogLFLZ8d2AYvB5eRc5L1bZ+pEAHuP98=; b=v4XTZqSUtb22YgxpOKnViohM4XMiJdMRu6TxRYanrXmZL6MNRj/rsj928aLx2h96UC JVk1m4xLoK2L69TZLGwmz9dLnlCpeSSBlQ/AKPWb6m5b12AmI2Ab85rfZtaOfXSqb067 5wK4A/UxWQ7omwOHw1TFRIMlAtwveMh3U99pTxmKY/s+Nwkciw/pNNmls8lqrrd0UGtb 884fS8DjKm0WGAFxVf64hq2SxG6z3nXJGTerMpQmwp/s1DD+/m7ec0zY2QjUQ5S8yZJ/ 0b2VryT9JFtPSKG8w+hrcsyZNEUpFsoKOWFJrcxhWcqQDWdb23z1U1fRMHbM3P97jty5 39xA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=msAVgGT3; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id k3si7005289ilh.176.2021.09.13.07.52.06; Mon, 13 Sep 2021 07:52:20 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=msAVgGT3; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1348504AbhIMOuk (ORCPT + 99 others); Mon, 13 Sep 2021 10:50:40 -0400 Received: from mail.kernel.org ([198.145.29.99]:60460 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1346229AbhIMOpS (ORCPT ); Mon, 13 Sep 2021 10:45:18 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 79CF66138D; Mon, 13 Sep 2021 13:58:16 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1631541496; bh=7cPgit04OnoYTxOk+CS+U8wiG3J4aHNe3jVdPZIM02Q=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=msAVgGT3AC47eIDESfH6a9RQ++3Z14knTnRNxkaduCB5UQCez2+/vrFEZqmdzicWZ XNH2LO6vSKF0XSBTjdCdrOcVSOHkbZB6UZbBYZMiOuCixtwtATVJS0buhZoKjJEjo8 Ou+YOUYgQRdzd+yAmlP+2U1BkFjUBkSKwQy7Z3RI= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Xiao Ni , Guoqing Jiang , Song Liu Subject: [PATCH 5.14 321/334] md/raid10: Remove unnecessary rcu_dereference in raid10_handle_discard Date: Mon, 13 Sep 2021 15:16:15 +0200 Message-Id: <20210913131124.279825906@linuxfoundation.org> X-Mailer: git-send-email 2.33.0 In-Reply-To: <20210913131113.390368911@linuxfoundation.org> References: <20210913131113.390368911@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Xiao Ni commit 46d4703b1db4c86ab5acb2331b10df999f005e8e upstream. We are seeing the following warning in raid10_handle_discard. [ 695.110751] ============================= [ 695.131439] WARNING: suspicious RCU usage [ 695.151389] 4.18.0-319.el8.x86_64+debug #1 Not tainted [ 695.174413] ----------------------------- [ 695.192603] drivers/md/raid10.c:1776 suspicious rcu_dereference_check() usage! [ 695.225107] other info that might help us debug this: [ 695.260940] rcu_scheduler_active = 2, debug_locks = 1 [ 695.290157] no locks held by mkfs.xfs/10186. In the first loop of function raid10_handle_discard. It already determines which disk need to handle discard request and add the rdev reference count rdev->nr_pending. So the conf->mirrors will not change until all bios come back from underlayer disks. It doesn't need to use rcu_dereference to get rdev. Cc: stable@vger.kernel.org Fixes: d30588b2731f ('md/raid10: improve raid10 discard request') Signed-off-by: Xiao Ni Acked-by: Guoqing Jiang Signed-off-by: Song Liu Signed-off-by: Greg Kroah-Hartman --- drivers/md/raid10.c | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) --- a/drivers/md/raid10.c +++ b/drivers/md/raid10.c @@ -1712,6 +1712,11 @@ retry_discard: } else r10_bio->master_bio = (struct bio *)first_r10bio; + /* + * first select target devices under rcu_lock and + * inc refcount on their rdev. Record them by setting + * bios[x] to bio + */ rcu_read_lock(); for (disk = 0; disk < geo->raid_disks; disk++) { struct md_rdev *rdev = rcu_dereference(conf->mirrors[disk].rdev); @@ -1743,9 +1748,6 @@ retry_discard: for (disk = 0; disk < geo->raid_disks; disk++) { sector_t dev_start, dev_end; struct bio *mbio, *rbio = NULL; - struct md_rdev *rdev = rcu_dereference(conf->mirrors[disk].rdev); - struct md_rdev *rrdev = rcu_dereference( - conf->mirrors[disk].replacement); /* * Now start to calculate the start and end address for each disk. @@ -1775,9 +1777,12 @@ retry_discard: /* * It only handles discard bio which size is >= stripe size, so - * dev_end > dev_start all the time + * dev_end > dev_start all the time. + * It doesn't need to use rcu lock to get rdev here. We already + * add rdev->nr_pending in the first loop. */ if (r10_bio->devs[disk].bio) { + struct md_rdev *rdev = conf->mirrors[disk].rdev; mbio = bio_clone_fast(bio, GFP_NOIO, &mddev->bio_set); mbio->bi_end_io = raid10_end_discard_request; mbio->bi_private = r10_bio; @@ -1790,6 +1795,7 @@ retry_discard: bio_endio(mbio); } if (r10_bio->devs[disk].repl_bio) { + struct md_rdev *rrdev = conf->mirrors[disk].replacement; rbio = bio_clone_fast(bio, GFP_NOIO, &mddev->bio_set); rbio->bi_end_io = raid10_end_discard_request; rbio->bi_private = r10_bio;