From: Jason Low <jason.low2@hp.com>
To: Davidlohr Bueso <davidlohr@hp.com>
Cc: mingo@redhat.com, peterz@infradead.org,
paulmck@linux.vnet.ibm.com, Waiman.Long@hp.com,
torvalds@linux-foundation.org, tglx@linutronix.de,
linux-kernel@vger.kernel.org, riel@redhat.com,
akpm@linux-foundation.org, hpa@zytor.com, aswin@hp.com,
scott.norton@hp.com
Subject: Re: [RFC 3/3] mutex: When there is no owner, stop spinning after too many tries
Date: Tue, 14 Jan 2014 23:34:48 -0800 [thread overview]
Message-ID: <1389771288.2944.58.camel@j-VirtualBox> (raw)
In-Reply-To: <1389747999.4971.27.camel@buesod1.americas.hpqcorp.net>
On Tue, 2014-01-14 at 17:06 -0800, Davidlohr Bueso wrote:
> On Tue, 2014-01-14 at 16:33 -0800, Jason Low wrote:
> > When running workloads that have high contention in mutexes on an 8 socket
> > machine, spinners would often spin for a long time with no lock owner.
> >
> > One of the potential reasons for this is because a thread can be preempted
> > after clearing lock->owner but before releasing the lock
>
> What happens if you invert the order here? So mutex_clear_owner() is
> called after the actual unlocking (__mutex_fastpath_unlock).
Reversing the mutex_fastpath_unlock and mutex_clear_owner resulted in a
20+% performance improvement to Ingo's test-mutex application at 160
threads on an 8 socket box.
I have tried this method before, but what I was initially concerned
about with clearing the owner after unlocking was that the following
scenario may occur.
thread 1 releases the lock
thread 2 acquires the lock (in the fastpath)
thread 2 sets the owner
thread 1 clears owner
In this situation, lock owner is NULL but thread 2 has the lock.
> > or preempted after
> > acquiring the mutex but before setting lock->owner.
>
> That would be the case _only_ for the fastpath. For the slowpath
> (including optimistic spinning) preemption is already disabled at that
> point.
Right, for just the fastpath_lock.
> > In those cases, the
> > spinner cannot check if owner is not on_cpu because lock->owner is NULL.
> >
> > A solution that would address the preemption part of this problem would
> > be to disable preemption between acquiring/releasing the mutex and
> > setting/clearing the lock->owner. However, that will require adding overhead
> > to the mutex fastpath.
>
> It's not uncommon to disable preemption in hotpaths, the overhead should
> be quite smaller, actually.
>
> >
> > The solution used in this patch is to limit the # of times thread can spin on
> > lock->count when !owner.
> >
> > The threshold used in this patch for each spinner was 128, which appeared to
> > be a generous value, but any suggestions on another method to determine
> > the threshold are welcomed.
>
> Hmm generous compared to what? Could you elaborate further on how you
> reached this value? These kind of magic numbers have produced
> significant debate in the past.
I've observed that when running workloads which don't exhibit this
behavior (long spins with no owner), threads rarely take more than 100
extra spins. So I went with 128 based on those number.
next prev parent reply other threads:[~2014-01-15 7:34 UTC|newest]
Thread overview: 19+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-01-15 0:33 [RFC 0/3] mutex: Reduce spinning contention when there is no lock owner Jason Low
2014-01-15 0:33 ` [RFC 1/3] mutex: In mutex_can_spin_on_owner(), return false if task need_resched() Jason Low
2014-01-15 7:44 ` Peter Zijlstra
2014-01-15 7:48 ` Peter Zijlstra
2014-01-15 20:37 ` Paul E. McKenney
2014-01-15 0:33 ` [RFC 2/3] mutex: Modify the way optimistic spinners are queued Jason Low
2014-01-15 15:10 ` Waiman Long
2014-01-15 19:23 ` Jason Low
2014-01-15 0:33 ` [RFC 3/3] mutex: When there is no owner, stop spinning after too many tries Jason Low
2014-01-15 1:00 ` Andrew Morton
2014-01-15 7:04 ` Jason Low
2014-01-15 1:06 ` Davidlohr Bueso
2014-01-15 7:34 ` Jason Low [this message]
2014-01-15 15:19 ` Waiman Long
2014-01-16 2:45 ` Jason Low
2014-01-16 3:14 ` Linus Torvalds
2014-01-16 6:46 ` Jason Low
2014-01-16 12:05 ` Peter Zijlstra
2014-01-16 20:48 ` Jason Low
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1389771288.2944.58.camel@j-VirtualBox \
--to=jason.low2@hp.com \
--cc=Waiman.Long@hp.com \
--cc=akpm@linux-foundation.org \
--cc=aswin@hp.com \
--cc=davidlohr@hp.com \
--cc=hpa@zytor.com \
--cc=linux-kernel@vger.kernel.org \
--cc=mingo@redhat.com \
--cc=paulmck@linux.vnet.ibm.com \
--cc=peterz@infradead.org \
--cc=riel@redhat.com \
--cc=scott.norton@hp.com \
--cc=tglx@linutronix.de \
--cc=torvalds@linux-foundation.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.