diff options
author | David Howells <dhowells@redhat.com> | 2012-03-28 13:30:02 -0400 |
---|---|---|
committer | David Howells <dhowells@redhat.com> | 2012-03-28 13:30:02 -0400 |
commit | a0616cdebcfd575dcd4c46102d1b52fbb827fc29 (patch) | |
tree | 49c67a23f3bcdb72a94317ddeff65e450b574746 /arch/s390/include/asm/barrier.h | |
parent | ae3a197e3d0bfe3f4bf1693723e82dc018c096f3 (diff) |
Disintegrate asm/system.h for S390
Disintegrate asm/system.h for S390.
Signed-off-by: David Howells <dhowells@redhat.com>
cc: linux-s390@vger.kernel.org
Diffstat (limited to 'arch/s390/include/asm/barrier.h')
-rw-r--r-- | arch/s390/include/asm/barrier.h | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/arch/s390/include/asm/barrier.h b/arch/s390/include/asm/barrier.h new file mode 100644 index 000000000000..451273ad4d34 --- /dev/null +++ b/arch/s390/include/asm/barrier.h | |||
@@ -0,0 +1,35 @@ | |||
1 | /* | ||
2 | * Copyright IBM Corp. 1999, 2009 | ||
3 | * | ||
4 | * Author(s): Martin Schwidefsky <schwidefsky@de.ibm.com> | ||
5 | */ | ||
6 | |||
7 | #ifndef __ASM_BARRIER_H | ||
8 | #define __ASM_BARRIER_H | ||
9 | |||
10 | /* | ||
11 | * Force strict CPU ordering. | ||
12 | * And yes, this is required on UP too when we're talking | ||
13 | * to devices. | ||
14 | * | ||
15 | * This is very similar to the ppc eieio/sync instruction in that is | ||
16 | * does a checkpoint syncronisation & makes sure that | ||
17 | * all memory ops have completed wrt other CPU's ( see 7-15 POP DJB ). | ||
18 | */ | ||
19 | |||
20 | #define eieio() asm volatile("bcr 15,0" : : : "memory") | ||
21 | #define SYNC_OTHER_CORES(x) eieio() | ||
22 | #define mb() eieio() | ||
23 | #define rmb() eieio() | ||
24 | #define wmb() eieio() | ||
25 | #define read_barrier_depends() do { } while(0) | ||
26 | #define smp_mb() mb() | ||
27 | #define smp_rmb() rmb() | ||
28 | #define smp_wmb() wmb() | ||
29 | #define smp_read_barrier_depends() read_barrier_depends() | ||
30 | #define smp_mb__before_clear_bit() smp_mb() | ||
31 | #define smp_mb__after_clear_bit() smp_mb() | ||
32 | |||
33 | #define set_mb(var, value) do { var = value; mb(); } while (0) | ||
34 | |||
35 | #endif /* __ASM_BARRIER_H */ | ||