/* * Copyright IBM Corp. 1999, 2009 * * Author(s): Martin Schwidefsky <schwidefsky@de.ibm.com> */ #ifndef __ASM_BARRIER_H #define __ASM_BARRIER_H /* * Force strict CPU ordering. * And yes, this is required on UP too when we're talking * to devices. */ #ifdef CONFIG_HAVE_MARCH_Z196_FEATURES /* Fast-BCR without checkpoint synchronization */ #define __ASM_BARRIER "bcr 14,0\n" #else #define __ASM_BARRIER "bcr 15,0\n" #endif #define mb() do { asm volatile(__ASM_BARRIER : : : "memory"); } while (0) #define rmb() barrier() #define wmb() barrier() #define dma_rmb() mb() #define dma_wmb() mb() #define __smp_mb() mb() #define __smp_rmb() rmb() #define __smp_wmb() wmb() #define __smp_store_release(p, v) \ do { \ compiletime_assert_atomic_type(*p); \ barrier(); \ WRITE_ONCE(*p, v); \ } while (0) #define __smp_load_acquire(p) \ ({ \ typeof(*p) ___p1 = READ_ONCE(*p); \ compiletime_assert_atomic_type(*p); \ barrier(); \ ___p1; \ }) #define __smp_mb__before_atomic() barrier() #define __smp_mb__after_atomic() barrier() #include <asm-generic/barrier.h> #endif /* __ASM_BARRIER_H */Overall Contributors
Person | Tokens | Prop | Commits | CommitProp |
Michael S. Tsirkin | 30 | 30.61% | 3 | 25.00% |
Heiko Carstens | 22 | 22.45% | 4 | 33.33% |
David Howells | 18 | 18.37% | 1 | 8.33% |
Peter Zijlstra | 14 | 14.29% | 1 | 8.33% |
Alexander Duyck | 8 | 8.16% | 1 | 8.33% |
Christian Bornträger | 4 | 4.08% | 1 | 8.33% |
Andrey Konovalov | 2 | 2.04% | 1 | 8.33% |
Total | 98 | 100.00% | 12 | 100.00% |