Received: by 2002:a25:c205:0:0:0:0:0 with SMTP id s5csp6944634ybf; Fri, 6 Mar 2020 07:28:10 -0800 (PST) X-Google-Smtp-Source: ADFU+vs9nqlIbjN/mfvIoIFv2h4egBpLgifqjmmu/LoZNqaOikFBjWTNfbglFdIxOd65pYhIsc59 X-Received: by 2002:a05:6830:16c8:: with SMTP id l8mr2930385otr.2.1583508490202; Fri, 06 Mar 2020 07:28:10 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1583508490; cv=none; d=google.com; s=arc-20160816; b=u3LTenIUywxeyrti+dL0zCzAaAtTktkkOJqTwKa8Ndpnd6TBT6udonz9OnldMEbzV7 nxL8/VZhK3x1qPOvsT7bCH7P4/8Ksr6LqNAW4iyYu3B+XUc8o63OgNEJQokSr44v4R2a U0pybpCZQ12Xyewvssq+0nZxvj/5fdXEGjsG1hKMd5TJHZ0EGd/9yWpYBZF2DSEgGioI T5RSP4AzozGSJDDG/SFhMLntvnmteY28OCeoksA174JppzXDk7Hz7pCv1dsa9sKZRi+I WUY/wV9C1T1EhpJ+WlwwX3U6Ec8u9Jm9N1TcPCJXAGhVY28maxwWD7vDO21j8S+OBhMx 6TLw== 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:mail-followup-to:reply-to:message-id:subject:cc:to:from :date; bh=ONQvxdCAIvyRp1MIvBLpYWi+o5/zc1oFv6duHNNm/jA=; b=XgSdMCW8SE0l5oR5ipSKBxxA8gx+DOQQePCCWn8KtTwtEb2KOcpSMsuL/8jhe38iY3 K+omqiRSBrjgd9rX8i01X/F8ocPkyxKzWqZlplwsONleCK+9yRuhJwuqSyP97JUCF1bp BaNBi2+9Kt+Q7/4Ywvq0ayNWas9iUSvlkOS2kmoAgwiRjvE3lzTaA/nqKc9IBCM3s8LI vuSDallNrDXlgnjdFnsxWHaTFUameB1hHFrhfiN6bRtyiRUYofg7Ppxf8DaUwj5hvJIs iT7BaaIeilK16aKODYqR3noZro6UxpNytzIyklM5FU6oEngqqN6R0BbDkU0KVAblf06v cx2A== ARC-Authentication-Results: i=1; mx.google.com; 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 x68si1559214oix.277.2020.03.06.07.27.59; Fri, 06 Mar 2020 07:28:10 -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; 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 S1727125AbgCFPZz (ORCPT + 99 others); Fri, 6 Mar 2020 10:25:55 -0500 Received: from mx2.suse.de ([195.135.220.15]:47178 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727067AbgCFPZx (ORCPT ); Fri, 6 Mar 2020 10:25:53 -0500 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.220.254]) by mx2.suse.de (Postfix) with ESMTP id 8478BAD88; Fri, 6 Mar 2020 15:25:51 +0000 (UTC) Received: by ds.suse.cz (Postfix, from userid 10065) id 0DAE8DA728; Fri, 6 Mar 2020 16:25:27 +0100 (CET) Date: Fri, 6 Mar 2020 16:25:27 +0100 From: David Sterba To: Madhuparna Bhowmik Cc: Qu Wenruo , clm@fb.com, josef@toxicpanda.com, dsterba@suse.com, linux-btrfs@vger.kernel.org, linux-kernel@vger.kernel.org, joel@joelfernandes.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: <20200306152527.GH2902@twin.jikos.cz> Reply-To: dsterba@suse.cz Mail-Followup-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, joel@joelfernandes.org, linux-kernel-mentees@lists.linuxfoundation.org, paulmck@kernel.org, frextrite@gmail.com, linux@roeck-us.net References: <20200306065243.11699-1-madhuparnabhowmik10@gmail.com> <20200306140023.GA14186@madhuparna-HP-Notebook> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <20200306140023.GA14186@madhuparna-HP-Notebook> User-Agent: Mutt/1.5.23.1-rc1 (2014-03-12) 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 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.