Received: by 2002:a05:6a10:6d25:0:0:0:0 with SMTP id gq37csp1876857pxb; Mon, 13 Sep 2021 07:23:01 -0700 (PDT) X-Google-Smtp-Source: ABdhPJySiu92JGj+J5whYUNX9FYMKmSaloZ0Xu9MdC2M1bYorE2fE3uQ16ZSNOfTiSyG8y4Wxx92 X-Received: by 2002:a05:6e02:2145:: with SMTP id d5mr8361860ilv.23.1631542980856; Mon, 13 Sep 2021 07:23:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1631542980; cv=none; d=google.com; s=arc-20160816; b=qo8nHpzjzlZOgqejmCyFfLV8GCG+aSVEbd5tgOW2HHGchnilnSzLUk5ZY5LiMhSxOD jhhADCBZ3LDH/v91AB292Suu3pWfoavj25SGMaVyV2lOywEiGZJKjblNn9wH7LG0SWvU Z53uGaPR4WtNO5AOBzJy4AkQXAZ0C2hp4F99GHK2BBjLVs1SD6qaPA//UcCG4ffj1dCv NwS3cnAbq4eJ8IIIm8PX3d3cJhEU0iPstpnwW3KTh1GOJAfHOT1Uvq3Dok+dejxiiQm2 QmKktvQ8RCzM9iiVADhjb7wmwRjSd1t7eeC06hVKAUSoMxuVUPn+ibuV1V3+ka84BWQ8 EkRw== 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=YTDDIUFSrpj7jDjommlfDj8YDnwEQ55HWXW47suffg4=; b=WoC4m4MqrFCOg7KPC8d8RJ7y/0B6UuNcDQtHCdWNm+KgQsIj9M/wPGxv84HTKQkyKb BJNoqNdVeyXmC3/bVrC8UdYRbH4s3blbv1o2yKlunXeGcLDQUz6vx/WvrHSTGdtH6s1J TXwnL00yWEq9EcFZfGL/pLVQzyGyQ9tbd9Yfq8+3LnMFsPTnUMpK1mMjNeCHnMe94hSC nJc6YF2x0eGaD177rFDPMnalwhu82TSVojlGOUTsWWLgQPmyRw8zNPWyB3Rc3I6c7n0S VW/TGbwDDMKQdJV0V31SgJ3+iBODfS001IrU7ReuQVyjEidz4lhfvEMYch/i0g8ZLGCr r4Ww== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=vnHe4WeE; 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 q17si7169054ilc.49.2021.09.13.07.22.46; Mon, 13 Sep 2021 07:23:00 -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=vnHe4WeE; 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 S244529AbhIMOVd (ORCPT + 99 others); Mon, 13 Sep 2021 10:21:33 -0400 Received: from mail.kernel.org ([198.145.29.99]:39640 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1345254AbhIMOQr (ORCPT ); Mon, 13 Sep 2021 10:16:47 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id D78A961B05; Mon, 13 Sep 2021 13:44:35 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1631540676; bh=VHjgErEbN1Pui1iU8zpNd8JtYds3OM4XuPv/wfa26Qw=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=vnHe4WeEZQzhrJoe4pOAkF3iZERFLMwBlW7khaHtl+0BDQ7D0D557zWLsnm9wXGLk GJBqnN3VP9wMxRl9HC4EZOUmQ77Ap0bp73cWvoslBgHfjBVB9clPvUIF5Glgogz3cj MC3CS51bqVhhMKlz78HkWLO1kXkURTTmACTbwaMg= 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.13 290/300] md/raid10: Remove unnecessary rcu_dereference in raid10_handle_discard Date: Mon, 13 Sep 2021 15:15:51 +0200 Message-Id: <20210913131119.147624433@linuxfoundation.org> X-Mailer: git-send-email 2.33.0 In-Reply-To: <20210913131109.253835823@linuxfoundation.org> References: <20210913131109.253835823@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 @@ -1706,6 +1706,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); @@ -1737,9 +1742,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. @@ -1769,9 +1771,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; @@ -1784,6 +1789,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;