Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp5690723pxv; Wed, 7 Jul 2021 09:30:11 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwRaKERnoUCitbi+V+/3/u2JaVf/7ZQl/rW9CK6L+0Wk3jwEZr0qT/Z18ilYJXLhWxtMVWI X-Received: by 2002:a05:6402:1591:: with SMTP id c17mr5749424edv.146.1625675411417; Wed, 07 Jul 2021 09:30:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1625675411; cv=none; d=google.com; s=arc-20160816; b=PNEQU/sS/X21W/afv71ShJvWyEQZetAC2mDHB73fp1lZsHiNpCjmrGxuUYiJ3eDrvx 6Xus8VoI0akLzhyAGW1bS1Gt8+skIjYrLIG41rnwFawhf6+gVajuWcAXToOv26CYqfan 0J1rUhOZY31cAguwJkzs2pZyM47BdcINsUn9TGqldIUx/YCsFCliuquYs1nlI4CLsOyp RsHmetU9CNWLgmKktcS4/8BVboBBUhlGlLQsFur8pDe1DYUjx2G4Nq6VnvPcogBEwA4h rBYJcSNFawScCQbdqHS7NaLHjLgaSr6DNKbSHniL0sAPx8c+eEaL0Bokf80vhr7/AVpF c5AA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=IQ1JO5SgftBxpvbjzlMUebykV/K1Qnrlq0r2EX22vjI=; b=qzUVP0XhuSzzoOOjrXICt0Jsu7pryCSS6n6XwN0yBR9kssT0rJsiSHAHcgKGOPr+Ok vBiTPUUHGGzc2NwZAj+KnQxb7atL2ft2K5QKAve6v2Wh9eC0ttvmc0HLwj7jEElsenSB AzSTjqg/eTntl5OqR2R8kUGv2EZZ5A9uFGODSCQFubCNw6XFc199Ndoycaf/X+VYJ8j4 eLBQaTtu+H8FavvjsSvfwxSdguh6bCuSutiWwsTiEMeeTdWBdj6bGu9y2Ak1xv2fcIkt RTOOVBiV58WAzra0RleV79BrVfM2c2anVy/WMzVaE9dHnallV9fHjgjNP+0T1IOJLUqK hGaQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@infradead.org header.s=casper.20170209 header.b=DabP41+n; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id js8si6596370ejc.484.2021.07.07.09.29.48; Wed, 07 Jul 2021 09:30:11 -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=@infradead.org header.s=casper.20170209 header.b=DabP41+n; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230123AbhGGQ2l (ORCPT + 99 others); Wed, 7 Jul 2021 12:28:41 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38572 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229519AbhGGQ2k (ORCPT ); Wed, 7 Jul 2021 12:28:40 -0400 Received: from casper.infradead.org (casper.infradead.org [IPv6:2001:8b0:10b:1236::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E2524C061574; Wed, 7 Jul 2021 09:25:59 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=casper.20170209; h=In-Reply-To:Content-Type:MIME-Version: References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description; bh=IQ1JO5SgftBxpvbjzlMUebykV/K1Qnrlq0r2EX22vjI=; b=DabP41+nfmcpS1CqBiX1rbY32A YBLsCE0gnzQx+37CpiGV1B5gLtsve8sW9v2l5kSTQx4QT12xLn/4iYvkUdMJFEzHmltvnsz3jQZC5 v7hTy3bEiQoO8IH+oErXkF7m8PKcq+Et0bLPx/i9IUbu24iybFm7G1gOYR7l0Z9k0VuwNXToUithg VlFDwyosRqgyyXBXPChHbIs4f32mnxpvbf/kI4DS/32w/lNYyzM3jAGZM6ORNpEbic8hkJivJvuen 9dapv8RPH7N9vk+oGoGnwRWAVwT/GynCpvEkSsrqnNAi52/FBDdDPPg0DQYmnm9ZlA+vGuSJRO+Yg OufdAN+Q==; Received: from willy by casper.infradead.org with local (Exim 4.94.2 #2 (Red Hat Linux)) id 1m1AMR-00Ca1T-Mr; Wed, 07 Jul 2021 16:25:22 +0000 Date: Wed, 7 Jul 2021 17:25:19 +0100 From: Matthew Wilcox To: Jeff Layton Cc: Greg KH , "J. Bruce Fields" , Desmond Cheong Zhi Xi , viro@zeniv.linux.org.uk, linux-fsdevel@vger.kernel.org, linux-kernel@vger.kernel.org, skhan@linuxfoundation.org, linux-kernel-mentees@lists.linuxfoundation.org, syzbot+e6d5398a02c516ce5e70@syzkaller.appspotmail.com Subject: Re: [PATCH v2 1/2] fcntl: fix potential deadlocks for &fown_struct.lock Message-ID: References: <14633c3be87286d811263892375f2dfa9a8ed40a.camel@kernel.org> <4dda1cad6348fced5fcfcb6140186795ed07d948.camel@kernel.org> <20210707135129.GA9446@fieldses.org> <20210707151936.GB9911@fieldses.org> <20210707153417.GA10570@fieldses.org> <03748f0bf038826f879b4429441d5a0fa8331969.camel@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <03748f0bf038826f879b4429441d5a0fa8331969.camel@kernel.org> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Jul 07, 2021 at 12:18:45PM -0400, Jeff Layton wrote: > On Wed, 2021-07-07 at 17:46 +0200, Greg KH wrote: > > On Wed, Jul 07, 2021 at 11:34:17AM -0400, J. Bruce Fields wrote: > > > On Wed, Jul 07, 2021 at 05:31:06PM +0200, Greg KH wrote: > > > > On Wed, Jul 07, 2021 at 11:19:36AM -0400, J. Bruce Fields wrote: > > > > > On Wed, Jul 07, 2021 at 05:06:45PM +0200, Greg KH wrote: > > > > > > On Wed, Jul 07, 2021 at 09:51:29AM -0400, J. Bruce Fields wrote: > > > > > > > On Wed, Jul 07, 2021 at 07:40:47AM -0400, Jeff Layton wrote: > > > > > > > > On Wed, 2021-07-07 at 12:51 +0200, Greg KH wrote: > > > > > > > > > On Wed, Jul 07, 2021 at 06:44:42AM -0400, Jeff Layton wrote: > > > > > > > > > > On Wed, 2021-07-07 at 08:05 +0200, Greg KH wrote: > > > > > > > > > > > On Wed, Jul 07, 2021 at 10:35:47AM +0800, Desmond Cheong Zhi Xi wrote: > > > > > > > > > > > > + WARN_ON_ONCE(irqs_disabled()); > > > > > > > > > > > > > > > > > > > > > > If this triggers, you just rebooted the box :( > > > > > > > > > > > > > > > > > > > > > > Please never do this, either properly handle the problem and return an > > > > > > > > > > > error, or do not check for this. It is not any type of "fix" at all, > > > > > > > > > > > and at most, a debugging aid while you work on the root problem. > > > > > > > > > > > > > > > > > > > > > > thanks, > > > > > > > > > > > > > > > > > > > > > > greg k-h > > > > > > > > > > > > > > > > > > > > Wait, what? Why would testing for irqs being disabled and throwing a > > > > > > > > > > WARN_ON in that case crash the box? > > > > > > > > > > > > > > > > > > If panic-on-warn is enabled, which is a common setting for systems these > > > > > > > > > days. > > > > > > > > > > > > > > > > Ok, that makes some sense. > > > > > > > > > > > > > > Wait, I don't get it. > > > > > > > > > > > > > > How are we supposed to decide when to use WARN, when to use BUG, and > > > > > > > when to panic? Do we really want to treat them all as equivalent? And > > > > > > > who exactly is turning on panic-on-warn? > > > > > > > > > > > > You never use WARN or BUG, unless the system is so messed up that you > > > > > > can not possibly recover from the issue. > > > > > > > > > > I've heard similar advice for BUG before, but this is the first I've > > > > > heard it for WARN. Do we have any guidelines for how to choose between > > > > > WARN and BUG? > > > > > > > > Never use either :) > > > > > > I can't tell if you're kidding. > > > > I am not. > > > > > Is there some plan to remove them? > > > > Over time, yes. And any WARN that userspace can ever hit should be > > removed today. > > > > > There are definitely cases where I've been able to resolve a problem > > > more quickly because I got a backtrace from a WARN. > > > > If you want a backtrace, ask for that, recover from the error, and move > > on. Do not allow userspace to reboot a machine for no good reason as > > again, panic-on-warn is a common setting that people use now. > > > > This is what all of the syzbot work has been doing, it triggers things > > that cause WARN() to be hit and so we have to fix them. > > > > This seems really draconian. Clearly we do want to fix things that show > a WARN (otherwise we wouldn't bother warning about it), but I don't > think that's a reason to completely avoid them. My understanding has > always been: > > BUG: for when you reach some condition where the kernel (probably) can't > carry on > > WARN: for when you reach some condition that is problematic but where > the machine can probably soldier on. > > Over the last several years, I've changed a lot of BUGs into WARNs to > avoid crashing the box unnecessarily. If someone is setting > panic_on_warn, then aren't they just getting what they asked for? > > While I don't feel that strongly about this particular WARN in this > patch, it seems like a reasonable thing to do. If someone calls these > functions with IRQs disabled, then they might end up with some subtle > problems that could be hard to detect otherwise. Don't we already have a debugging option that would catch this? config DEBUG_IRQFLAGS bool "Debug IRQ flag manipulation" help Enables checks for potentially unsafe enabling or disabling of interrupts, such as calling raw_local_irq_restore() when interrupts are enabled. so I think this particular warn is unnecessary. But I also disagree with Greg. Normal users aren't setting panic-on-warn. Various build bots are setting panic-on-warn -- and they should -- because we shouldn't be able to trigger these kinds of warnings from userspace. Those are bugs that should be fixed. But there's no reason to shy away from using a WARN when it's the right thing to do.