[PATCH] arm64: spinlock: serialise spin_unlock_wait against concurrent lockers
From: Will Deacon <hidden>
Date: 2015-12-03 16:32:43
Hi Peter, Paul, Firstly, thanks for writing that up. I agree that you have something that can work in theory, but see below. On Thu, Dec 03, 2015 at 02:28:39PM +0100, Peter Zijlstra wrote:
On Wed, Dec 02, 2015 at 04:11:41PM -0800, Paul E. McKenney wrote:quoted
This looks architecture-agnostic to me: a. TSO systems have smp_mb__after_unlock_lock() be a no-op, and have a read-only implementation for spin_unlock_wait(). b. Small-scale weakly ordered systems can also have smp_mb__after_unlock_lock() be a no-op, but must instead have spin_unlock_wait() acquire the lock and immediately release it, or some optimized implementation of this. c. Large-scale weakly ordered systems are required to define smp_mb__after_unlock_lock() as smp_mb(), but can have a read-only implementation of spin_unlock_wait().This would still require all relevant spin_lock() sites to be annotated with smp_mb__after_unlock_lock(), which is going to be a painful (no warning when done wrong) exercise and expensive (added MBs all over the place). But yes, I think the proposal is technically sound, just not quite sure how far we'll want to push this.
When I said that the solution isn't architecture-agnostic, I was referring
to the fact that spin_unlock_wait acts as a LOCK operation on all
architectures other than those using case (c) above. You've resolved
this by requiring smp_mb__after_unlock_lock() after every LOCK, but I
share Peter's concerns that this isn't going to work in practice because:
1. The smp_mb__after_unlock_lock additions aren't necessarily in the
code where the spin_unlock_wait() is being added, so it's going to
require a lot of diligence for developers to get this right
2. Only PowerPC is going to see the (very occassional) failures, so
testing this is nigh on impossible :(
3. We've now made the kernel memory model even more difficult to
understand, so people might not even bother with this addition
Will