Received: by 2002:a25:c205:0:0:0:0:0 with SMTP id s5csp7176551ybf; Fri, 6 Mar 2020 11:54:07 -0800 (PST) X-Google-Smtp-Source: ADFU+vsO7GeVP5pb+WVYUVZUxl9VzRDhhR84XTS/P/Jc8F6YJm+cS6w/aeueLxWpYsB2XgL5VRUf X-Received: by 2002:a9d:6c94:: with SMTP id c20mr4016697otr.285.1583524447726; Fri, 06 Mar 2020 11:54:07 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1583524447; cv=none; d=google.com; s=arc-20160816; b=qb7CyNyCTMc2fqQlor2JFwhKZ0Z9vwuKuXm6ovEeIAurKAHwskZeRrBqpPgS+HLVHG FeYkwFb5UXPBH9e+EmkdEsnISyo/aI3Cgkk1rWot4PlPPvCSX1yT818Y0iATBJa+a1iq 8l6c6aPrChnWhsjyDEUMZ7YGnyFSPojmC8wb708mSMimcaA7Yc2fIFfkx0fuBCST8Yt7 Df3hfCIrMpYF0oPcVkOLfBuv7YqLI4HI9kPwj8o9xY/pCSOA5z4bjlpuekuFF4JX4y+b lximEN0igdwPHeYlh+Q1G4rlfa1BH/Jm6ah99LS2jPbz5ejteJUWTvsqxcbESxVGBzi8 JwfQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-transfer-encoding:content-disposition:mime-version :references:message-id:subject:to:from:date:dkim-signature; bh=QaNxcQb7Gg+vxIHDRqfm2dfWV4oEZhj/ZtvsBzj/+Bk=; b=K8DG2ZZaXj+9u+foDWKbZ4STIB1/lm7DhqpE1+mCBWU98+JCL7ygW3L40jE/4FTs70 GFZm5Cp2pBYNTRvwV+nYh8V8P7WODpO2hxQ8Rh8ZiwtMHP6z4Q76AJsIFVZ+bGoVxtgv ji6F20UuGsplVJ4bFDigNWorJT6I6qf3ktos05h/qdOs05+qBuXWgnyOXhthtn4jitQN nLYSMHqE8QxBG8ioZJLjfXsrptqBvTt/kHRLfKUURUnxcHLkgJP984kUBuiWMFg6B/Xx 108uUSBBq9NecOHah5Hmk4hIHCt8qPh48+lvMlAwZKihUfOvPqgP2uk6ZSxNVQOSLVgz PcSQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@joelfernandes.org header.s=google header.b=qk06El3J; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id y2si1806144otb.139.2020.03.06.11.53.55; Fri, 06 Mar 2020 11:54:07 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@joelfernandes.org header.s=google header.b=qk06El3J; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726314AbgCFTxZ (ORCPT + 99 others); Fri, 6 Mar 2020 14:53:25 -0500 Received: from mail-qv1-f66.google.com ([209.85.219.66]:39034 "EHLO mail-qv1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726162AbgCFTxZ (ORCPT ); Fri, 6 Mar 2020 14:53:25 -0500 Received: by mail-qv1-f66.google.com with SMTP id fc12so1515308qvb.6 for ; Fri, 06 Mar 2020 11:53:24 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=joelfernandes.org; s=google; h=date:from:to:subject:message-id:references:mime-version :content-disposition:content-transfer-encoding:in-reply-to :user-agent; bh=QaNxcQb7Gg+vxIHDRqfm2dfWV4oEZhj/ZtvsBzj/+Bk=; b=qk06El3JD3uD38dR/+KpHsLyQqx2wruXRJgkstX2ahhw9X3IFGj5nLe2Z+o4giq/pM ldJs5F7oyuhAevtUXI557hIOqP78gga6BNTgb4Smwr0CdmuPgHBd9R/mpRAuAVFgT6Si FO4sdeP9aVDm3bSjSYygt3LXsi7uG2og5cDNg= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:subject:message-id:references :mime-version:content-disposition:content-transfer-encoding :in-reply-to:user-agent; bh=QaNxcQb7Gg+vxIHDRqfm2dfWV4oEZhj/ZtvsBzj/+Bk=; b=KCmPmstc+KK8Tnct5yIPRZgaLs4FmqSA7kUvRHoD90FS9/ghViW9ao4OJcriHwEbTV QtOJm2e9+2Zo22XDFuRj+MF5oNNakhiwEBGhKK10u2ikB0EG7FzoXDEYixUd8mhm8iAZ ADBj+2rH9uqNhafd5ooq9rw2YUKygbNLWdjBFpCh8Q1z8YJFDtAtGhiZUAVZbA/qSrmK b1uVZjl1m1shH5/aoi6iq0wDVMxmVeZXTcj7l6iZk7BjGcLsdh6IZHHPIL2v1xIGCB9s cWOcnvlG3JB6lxWGtr1qPN7j9NtCqnzUFQboST78ejKExjqQV4d9y8p5om3aSBzZX07k a0GA== X-Gm-Message-State: ANhLgQ1A1Eo6aVJp7FrZ1jYsAD06n741BBOoU8covk/i2KMlF22qh+gF /AW8+INQnAX4GiyrH9FfFCsoqQ== X-Received: by 2002:a05:6214:1051:: with SMTP id l17mr4508705qvr.175.1583524404428; Fri, 06 Mar 2020 11:53:24 -0800 (PST) Received: from localhost ([2620:15c:6:12:9c46:e0da:efbf:69cc]) by smtp.gmail.com with ESMTPSA id x188sm8961139qka.53.2020.03.06.11.53.23 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 06 Mar 2020 11:53:23 -0800 (PST) Date: Fri, 6 Mar 2020 14:53:23 -0500 From: Joel Fernandes To: dsterba@suse.cz, Madhuparna Bhowmik , Qu Wenruo , clm@fb.com, josef@toxicpanda.com, dsterba@suse.com, linux-btrfs@vger.kernel.org, linux-kernel@vger.kernel.org, linux-kernel-mentees@lists.linuxfoundation.org, paulmck@kernel.org, frextrite@gmail.com, linux@roeck-us.net Subject: Re: [PATCH] fs: btrfs: block-group.c: Fix suspicious RCU usage warning Message-ID: <20200306195323.GE60713@google.com> References: <20200306065243.11699-1-madhuparnabhowmik10@gmail.com> <20200306140023.GA14186@madhuparna-HP-Notebook> <20200306152527.GH2902@twin.jikos.cz> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <20200306152527.GH2902@twin.jikos.cz> User-Agent: Mutt/1.12.2 (2019-09-21) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Mar 06, 2020 at 04:25:27PM +0100, David Sterba wrote: > On Fri, Mar 06, 2020 at 07:30:24PM +0530, Madhuparna Bhowmik wrote: > > On Fri, Mar 06, 2020 at 03:16:53PM +0800, Qu Wenruo wrote: > > > > > > > > > On 2020/3/6 下午2:52, madhuparnabhowmik10@gmail.com wrote: > > > > From: Madhuparna Bhowmik > > > > > > > > The space_info list is rcu protected. > > > > Hence, it should be traversed with rcu_read_lock held. > > > > > > > > Warning: > > > > [ 29.104591] ============================= > > > > [ 29.104756] WARNING: suspicious RCU usage > > > > [ 29.105046] 5.6.0-rc4-next-20200305 #1 Not tainted > > > > [ 29.105231] ----------------------------- > > > > [ 29.105401] fs/btrfs/block-group.c:2011 RCU-list traversed in non-reader section!! > > > > > > > > Reported-by: Guenter Roeck > > > > Signed-off-by: Madhuparna Bhowmik > > > > --- > > > > fs/btrfs/block-group.c | 4 +++- > > > > 1 file changed, 3 insertions(+), 1 deletion(-) > > > > > > > > diff --git a/fs/btrfs/block-group.c b/fs/btrfs/block-group.c > > > > index 404e050ce8ee..9cabeef66f5b 100644 > > > > --- a/fs/btrfs/block-group.c > > > > +++ b/fs/btrfs/block-group.c > > > > @@ -1987,6 +1987,7 @@ int btrfs_read_block_groups(struct btrfs_fs_info *info) > > > > > > This function is only triggered at mount time, where no other rcu > > > operation can happen. > > > > > Thanks Qu. > > > > Joel and Paul, what should we do in this case? > > Should we just pass cond = true or use list_for_each_entry instead? > > I think we can afford to add rcu lock/unlock, even if it's not strictly > necessary due to the single threaded context where the function is run. > There are some lightweight operations inside and inc_block_group starts > with two spin locks so there's nothing we'd be losing with disabled > preemption from the caller. I think use list_for_each_entry(). thanks, - Joel