From mboxrd@z Thu Jan 1 00:00:00 1970 From: Ingo Molnar Subject: Re: [PATCH 2/2] mutex: Apply adaptive spinning on mutex_trylock() Date: Fri, 25 Mar 2011 20:51:36 +0100 Message-ID: <20110325195136.GA7346@elte.hu> References: <20110323153727.GB12003@htj.dyndns.org> <20110324094119.GD12038@htj.dyndns.org> <20110324094151.GE12038@htj.dyndns.org> <20110325033956.GB9313@home.goodmis.org> <1301058727.14261.174.camel@gandalf.stny.rr.com> <1301061918.14261.188.camel@gandalf.stny.rr.com> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Cc: Andrey Kuzmin , Tejun Heo , Peter Zijlstra , Ingo Molnar , Linus Torvalds , Andrew Morton , Chris Mason , linux-kernel@vger.kernel.org, linux-btrfs@vger.kernel.org To: Steven Rostedt Return-path: In-Reply-To: <1301061918.14261.188.camel@gandalf.stny.rr.com> List-ID: * Steven Rostedt wrote: > On Fri, 2011-03-25 at 16:50 +0300, Andrey Kuzmin wrote: > > On Fri, Mar 25, 2011 at 4:12 PM, Steven Rostedt wrote: > > > On Fri, 2011-03-25 at 14:13 +0300, Andrey Kuzmin wrote: > > >> Turning try_lock into indefinitely spinning one breaks its semantics, > > >> so deadlock is to be expected. But what's wrong in this scenario if > > >> try_lock spins a bit before giving up? > > > > > > Because that will cause this scenario to spin that "little longer" > > > always, and introduce latencies that did not exist before. Either the > > > solution does not break this scenario, or it should not go in. > > > > Broken semantics and extra latency are two separate issues. If the > > former is fixed, the latter is easily handled by introducing new > > mutex_trylock_spin call that lets one either stick to existing > > behavior (try/fail) or choose a new one where latency penalty is > > justified by locking patterns. > > > > For those wanting a more RT deterministic OS, I will argue against > latency penalties. Later mails from Tejun suggest that the benchmark results are varied, and that it's not a clear win after all. It's possible that if useless spinning is introduced then that might explain such workload variations. I.e. it's not really 'latencies' but 'unnecessary overhead spent spinning' - and also 'extra non-deterministic noise' - none of which help consistent performance. Thanks, Ingo