* Re: [PATCH 2/2] Introduce __cond_lock_err [not found] ` <20171222133634.GE6401@bombadil.infradead.org> @ 2017-12-23 9:39 ` Josh Triplett 2017-12-23 13:06 ` Matthew Wilcox 0 siblings, 1 reply; 3+ messages in thread From: Josh Triplett @ 2017-12-23 9:39 UTC (permalink / raw) To: Matthew Wilcox Cc: Ross Zwisler, linux-kernel, Dave Hansen, linux-mm, Matthew Wilcox, linux-sparse +linux-sparse 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: <a href=mailto:"dont@kvack.org"> email@kvack.org </a> ^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH 2/2] Introduce __cond_lock_err 2017-12-23 9:39 ` [PATCH 2/2] Introduce __cond_lock_err Josh Triplett @ 2017-12-23 13:06 ` Matthew Wilcox 2017-12-27 14:38 ` Luc Van Oostenryck 0 siblings, 1 reply; 3+ messages in thread From: Matthew Wilcox @ 2017-12-23 13:06 UTC (permalink / raw) To: Josh Triplett Cc: Ross Zwisler, linux-kernel, Dave Hansen, linux-mm, Matthew Wilcox, linux-sparse 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: <a href=mailto:"dont@kvack.org"> email@kvack.org </a> -- 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: <a href=mailto:"dont@kvack.org"> email@kvack.org </a> ^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH 2/2] Introduce __cond_lock_err 2017-12-23 13:06 ` Matthew Wilcox @ 2017-12-27 14:38 ` Luc Van Oostenryck 0 siblings, 0 replies; 3+ messages in thread From: Luc Van Oostenryck @ 2017-12-27 14:38 UTC (permalink / raw) To: Matthew Wilcox Cc: Josh Triplett, Ross Zwisler, linux-kernel, Dave Hansen, linux-mm, Matthew Wilcox, linux-sparse On Sat, Dec 23, 2017 at 05:06:21AM -0800, Matthew Wilcox wrote: > 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. I think this __cond_lock_err() is now OK (but some comment about how its use is different from __cond_lock() would be welcome). For the context imbalance, I would really need a concrete example to be able to help more because it depends heavily on what the test is and what code is before and after. If you can point me to a tree, a .config and a specific warning, I'll be glad to take a look. -- Luc Van Oostenryck -- 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: <a href=mailto:"dont@kvack.org"> email@kvack.org </a> ^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2017-12-27 14:38 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <20171219165823.24243-1-willy@infradead.org>
[not found] ` <20171219165823.24243-2-willy@infradead.org>
[not found] ` <20171221214810.GC9087@linux.intel.com>
[not found] ` <20171222011000.GB23624@bombadil.infradead.org>
[not found] ` <20171222042120.GA18036@localhost>
[not found] ` <20171222123112.GA6401@bombadil.infradead.org>
[not found] ` <20171222133634.GE6401@bombadil.infradead.org>
2017-12-23 9:39 ` [PATCH 2/2] Introduce __cond_lock_err Josh Triplett
2017-12-23 13:06 ` Matthew Wilcox
2017-12-27 14:38 ` Luc Van Oostenryck
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).