Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1757014AbdLWNG2 (ORCPT ); Sat, 23 Dec 2017 08:06:28 -0500 Received: from bombadil.infradead.org ([65.50.211.133]:43315 "EHLO bombadil.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1756971AbdLWNGY (ORCPT ); Sat, 23 Dec 2017 08:06:24 -0500 Date: Sat, 23 Dec 2017 05:06:21 -0800 From: Matthew Wilcox To: Josh Triplett Cc: Ross Zwisler , linux-kernel@vger.kernel.org, Dave Hansen , linux-mm@kvack.org, Matthew Wilcox , linux-sparse@vger.kernel.org Subject: Re: [PATCH 2/2] Introduce __cond_lock_err Message-ID: <20171223130621.GA3994@bombadil.infradead.org> References: <20171219165823.24243-1-willy@infradead.org> <20171219165823.24243-2-willy@infradead.org> <20171221214810.GC9087@linux.intel.com> <20171222011000.GB23624@bombadil.infradead.org> <20171222042120.GA18036@localhost> <20171222123112.GA6401@bombadil.infradead.org> <20171222133634.GE6401@bombadil.infradead.org> <20171223093910.GB6160@localhost> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20171223093910.GB6160@localhost> User-Agent: Mutt/1.9.1 (2017-09-22) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2243 Lines: 63 On Sat, Dec 23, 2017 at 01:39:11AM -0800, Josh Triplett wrote: > +linux-sparse Ehh ... we've probably trimmed too much to give linux-sparse a good summary. Here're the important lines from my patch: +# define __cond_lock_err(x,c) ((c) ? 1 : ({ __acquire(x); 0; })) + return __cond_lock_err(*ptlp, __follow_pte_pmd(mm, address, start, end, + ptepp, pmdpp, ptlp)); This is supposed to be "If "c" is an error value, we don't have a lock, otherwise we have a lock". And to translate from linux-speak into sparse-speak: # define __acquire(x) __context__(x,1) Josh & Ross pointed out (quite correctly) that code which does something like if (foo()) return; will work with this, but code that does if (foo() < 0) return; will not because we're now returning 1 instead of -ENOMEM (for example). So they made the very sensible suggestion that I change the definition of __cond_lock to: # define __cond_lock_err(x,c) ((c) ?: ({ __acquire(x); 0; })) Unfortunately, when I do that, the context imbalance warning returns. As I said below, this is with sparse 0.5.1. > On Fri, Dec 22, 2017 at 05:36:34AM -0800, Matthew Wilcox wrote: > > On Fri, Dec 22, 2017 at 04:31:12AM -0800, Matthew Wilcox wrote: > > > On Thu, Dec 21, 2017 at 08:21:20PM -0800, Josh Triplett wrote: > > > > On Thu, Dec 21, 2017 at 05:10:00PM -0800, Matthew Wilcox wrote: > > > > > Yes, but this define is only #if __CHECKER__, so it doesn't matter what we > > > > > return as this code will never run. > > > > > > > > It does matter slightly, as Sparse does some (very limited) value-based > > > > analyses. Let's future-proof it. > > > > > > > > > That said, if sparse supports the GNU syntax of ?: then I have no > > > > > objection to doing that. > > > > > > > > Sparse does support that syntax. > > > > > > Great, I'll fix that and resubmit. > > > > Except the context imbalance warning comes back if I do. This is sparse > > 0.5.1 (Debian's 0.5.1-2 package). > > -- > To unsubscribe, send a message with 'unsubscribe linux-mm' in > the body to majordomo@kvack.org. For more info on Linux MM, > see: http://www.linux-mm.org/ . > Don't email: email@kvack.org