[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-id: <alpine.LFD.2.02.1208071405590.5231@xanadu.home>
Date: Tue, 07 Aug 2012 14:28:31 -0400 (EDT)
From: Nicolas Pitre <nico@...xnic.net>
To: Will Deacon <will.deacon@....com>
Cc: "linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>,
Peter Zijlstra <a.p.zijlstra@...llo.nl>,
Ingo Molnar <mingo@...e.hu>,
Thomas Gleixner <tglx@...utronix.de>,
Chris Mason <chris.mason@...ionio.com>,
Arnd Bergmann <arnd@...db.de>,
"linux-arm-kernel@...ts.infradead.org"
<linux-arm-kernel@...ts.infradead.org>
Subject: Re: RFC: mutex: hung tasks on SMP platforms with
asm-generic/mutex-xchg.h
On Tue, 7 Aug 2012, Will Deacon wrote:
> On Tue, Aug 07, 2012 at 06:14:36PM +0100, Nicolas Pitre wrote:
> > On Tue, 7 Aug 2012, Will Deacon wrote:
> > > The symptoms are that a bunch of hackbench tasks are left waiting on an
> > > unlocked mutex and therefore never get woken up to claim it. I think this
> > > boils down to the following sequence:
> > >
> > >
> > > Task A Task B Task C Lock value
> > > 0 1
> > > 1 lock() 0
> > > 2 lock() 0
> > > 3 spin(A) 0
> > > 4 unlock() 1
> > > 5 lock() 0
> > > 6 cmpxchg(1,0) 0
> > > 7 contended() -1
> > > 8 lock() 0
> > > 9 spin(C) 0
> > > 10 unlock() 1
> > > 11 cmpxchg(1,0) 0
> > > 12 unlock() 1
> > >
> > >
> > > At this point, the lock is unlocked, but Task B is in an uninterruptible
> > > sleep with nobody to wake it up.
> >
> > I fail to see how the lock value would go from -1 to 0 on line 8. How
> > does that happen?
>
> [...]
Forget that. I assumed cmpxchg when it is just xchg.
(And, for that matter, I'm even the original author for some of that
code.: http://lkml.org/lkml/2005/12/26/83).
Back to thinking.
Nicolas
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists