Merge branch 'topic/docs-next' into v4l_for_linus
[sfrench/cifs-2.6.git] / arch / tile / lib / spinlock_32.c
index 88c2a53362e738110913134b840e1abe01df9fd9..076c6cc431136fc8475b0fa0b768bb7a6083dc66 100644 (file)
@@ -76,6 +76,12 @@ void arch_spin_unlock_wait(arch_spinlock_t *lock)
        do {
                delay_backoff(iterations++);
        } while (READ_ONCE(lock->current_ticket) == curr);
+
+       /*
+        * The TILE architecture doesn't do read speculation; therefore
+        * a control dependency guarantees a LOAD->{LOAD,STORE} order.
+        */
+       barrier();
 }
 EXPORT_SYMBOL(arch_spin_unlock_wait);