diff options
-rw-r--r-- | arch/um/Makefile | 3 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/archsetjmp.h | 5 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/archsetjmp_32.h (renamed from arch/um/sys-i386/shared/sysdep/archsetjmp.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/archsetjmp_64.h (renamed from arch/um/sys-x86_64/shared/sysdep/archsetjmp.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/barrier.h | 5 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/barrier_32.h (renamed from arch/um/sys-i386/shared/sysdep/barrier.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/barrier_64.h (renamed from arch/um/sys-x86_64/shared/sysdep/barrier.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/faultinfo.h | 5 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/faultinfo_32.h (renamed from arch/um/sys-i386/shared/sysdep/faultinfo.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/faultinfo_64.h (renamed from arch/um/sys-x86_64/shared/sysdep/faultinfo.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/host_ldt.h | 5 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/host_ldt_32.h (renamed from arch/um/sys-i386/shared/sysdep/host_ldt.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/host_ldt_64.h (renamed from arch/um/sys-x86_64/shared/sysdep/host_ldt.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/kernel-offsets.h | 5 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/kernel-offsets_32.h (renamed from arch/um/sys-i386/shared/sysdep/kernel-offsets.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/kernel-offsets_64.h (renamed from arch/um/sys-x86_64/shared/sysdep/kernel-offsets.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/ptrace.h | 5 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/ptrace_32.h (renamed from arch/um/sys-i386/shared/sysdep/ptrace.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/ptrace_64.h (renamed from arch/um/sys-x86_64/shared/sysdep/ptrace.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/ptrace_user.h | 5 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/ptrace_user_32.h (renamed from arch/um/sys-i386/shared/sysdep/ptrace_user.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/ptrace_user_64.h (renamed from arch/um/sys-x86_64/shared/sysdep/ptrace_user.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/sigcontext.h | 5 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/sigcontext_32.h (renamed from arch/um/sys-i386/shared/sysdep/sigcontext.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/sigcontext_64.h (renamed from arch/um/sys-x86_64/shared/sysdep/sigcontext.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/skas_ptrace.h | 5 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/skas_ptrace_32.h (renamed from arch/um/sys-i386/shared/sysdep/skas_ptrace.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/skas_ptrace_64.h (renamed from arch/um/sys-x86_64/shared/sysdep/skas_ptrace.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/stub.h | 5 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/stub_32.h (renamed from arch/um/sys-i386/shared/sysdep/stub.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/stub_64.h (renamed from arch/um/sys-x86_64/shared/sysdep/stub.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/syscalls.h | 5 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/syscalls_32.h (renamed from arch/um/sys-i386/shared/sysdep/syscalls.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/syscalls_64.h (renamed from arch/um/sys-x86_64/shared/sysdep/syscalls.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/system.h (renamed from arch/um/sys-i386/shared/sysdep/system.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/tls.h | 5 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/tls_32.h (renamed from arch/um/sys-i386/shared/sysdep/tls.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86/shared/sysdep/tls_64.h (renamed from arch/um/sys-x86_64/shared/sysdep/tls.h) | 0 | ||||
-rw-r--r-- | arch/um/sys-x86_64/shared/sysdep/system.h | 132 |
39 files changed, 61 insertions, 134 deletions
diff --git a/arch/um/Makefile b/arch/um/Makefile index c1218705c2d3..184494d890b6 100644 --- a/arch/um/Makefile +++ b/arch/um/Makefile | |||
@@ -25,9 +25,8 @@ include $(srctree)/$(ARCH_DIR)/Makefile-$(SUBARCH) | |||
25 | 25 | ||
26 | SHARED_HEADERS := $(ARCH_DIR)/include/shared | 26 | SHARED_HEADERS := $(ARCH_DIR)/include/shared |
27 | ARCH_INCLUDE := -I$(srctree)/$(SHARED_HEADERS) | 27 | ARCH_INCLUDE := -I$(srctree)/$(SHARED_HEADERS) |
28 | ARCH_INCLUDE += -I$(srctree)/$(ARCH_DIR)/sys-$(SUBARCH)/shared | 28 | ARCH_INCLUDE += -I$(srctree)/$(ARCH_DIR)/sys-$(HEADER_ARCH)/shared |
29 | KBUILD_CPPFLAGS += -I$(srctree)/$(ARCH_DIR)/sys-$(HEADER_ARCH) | 29 | KBUILD_CPPFLAGS += -I$(srctree)/$(ARCH_DIR)/sys-$(HEADER_ARCH) |
30 | KBUILD_CPPFLAGS += -I$(srctree)/$(ARCH_DIR)/sys-$(SUBARCH) | ||
31 | 30 | ||
32 | # -Dvmap=kernel_vmap prevents anything from referencing the libpcap.o symbol so | 31 | # -Dvmap=kernel_vmap prevents anything from referencing the libpcap.o symbol so |
33 | # named - it's a common symbol in libpcap, so we get a binary which crashes. | 32 | # named - it's a common symbol in libpcap, so we get a binary which crashes. |
diff --git a/arch/um/sys-x86/shared/sysdep/archsetjmp.h b/arch/um/sys-x86/shared/sysdep/archsetjmp.h new file mode 100644 index 000000000000..ff7766d28226 --- /dev/null +++ b/arch/um/sys-x86/shared/sysdep/archsetjmp.h | |||
@@ -0,0 +1,5 @@ | |||
1 | #ifdef __i386__ | ||
2 | #include "archsetjmp_32.h" | ||
3 | #else | ||
4 | #include "archsetjmp_64.h" | ||
5 | #endif | ||
diff --git a/arch/um/sys-i386/shared/sysdep/archsetjmp.h b/arch/um/sys-x86/shared/sysdep/archsetjmp_32.h index 0f312085ce1d..0f312085ce1d 100644 --- a/arch/um/sys-i386/shared/sysdep/archsetjmp.h +++ b/arch/um/sys-x86/shared/sysdep/archsetjmp_32.h | |||
diff --git a/arch/um/sys-x86_64/shared/sysdep/archsetjmp.h b/arch/um/sys-x86/shared/sysdep/archsetjmp_64.h index 2af8f12ca161..2af8f12ca161 100644 --- a/arch/um/sys-x86_64/shared/sysdep/archsetjmp.h +++ b/arch/um/sys-x86/shared/sysdep/archsetjmp_64.h | |||
diff --git a/arch/um/sys-x86/shared/sysdep/barrier.h b/arch/um/sys-x86/shared/sysdep/barrier.h new file mode 100644 index 000000000000..89ee23bc8da4 --- /dev/null +++ b/arch/um/sys-x86/shared/sysdep/barrier.h | |||
@@ -0,0 +1,5 @@ | |||
1 | #ifdef __i386__ | ||
2 | #include "barrier_32.h" | ||
3 | #else | ||
4 | #include "barrier_64.h" | ||
5 | #endif | ||
diff --git a/arch/um/sys-i386/shared/sysdep/barrier.h b/arch/um/sys-x86/shared/sysdep/barrier_32.h index b58d52c5b2f4..b58d52c5b2f4 100644 --- a/arch/um/sys-i386/shared/sysdep/barrier.h +++ b/arch/um/sys-x86/shared/sysdep/barrier_32.h | |||
diff --git a/arch/um/sys-x86_64/shared/sysdep/barrier.h b/arch/um/sys-x86/shared/sysdep/barrier_64.h index 7b610befdc8f..7b610befdc8f 100644 --- a/arch/um/sys-x86_64/shared/sysdep/barrier.h +++ b/arch/um/sys-x86/shared/sysdep/barrier_64.h | |||
diff --git a/arch/um/sys-x86/shared/sysdep/faultinfo.h b/arch/um/sys-x86/shared/sysdep/faultinfo.h new file mode 100644 index 000000000000..862ecb1c7781 --- /dev/null +++ b/arch/um/sys-x86/shared/sysdep/faultinfo.h | |||
@@ -0,0 +1,5 @@ | |||
1 | #ifdef __i386__ | ||
2 | #include "faultinfo_32.h" | ||
3 | #else | ||
4 | #include "faultinfo_64.h" | ||
5 | #endif | ||
diff --git a/arch/um/sys-i386/shared/sysdep/faultinfo.h b/arch/um/sys-x86/shared/sysdep/faultinfo_32.h index db437cc373bc..db437cc373bc 100644 --- a/arch/um/sys-i386/shared/sysdep/faultinfo.h +++ b/arch/um/sys-x86/shared/sysdep/faultinfo_32.h | |||
diff --git a/arch/um/sys-x86_64/shared/sysdep/faultinfo.h b/arch/um/sys-x86/shared/sysdep/faultinfo_64.h index cb917b0d5660..cb917b0d5660 100644 --- a/arch/um/sys-x86_64/shared/sysdep/faultinfo.h +++ b/arch/um/sys-x86/shared/sysdep/faultinfo_64.h | |||
diff --git a/arch/um/sys-x86/shared/sysdep/host_ldt.h b/arch/um/sys-x86/shared/sysdep/host_ldt.h new file mode 100644 index 000000000000..94518b3e0da5 --- /dev/null +++ b/arch/um/sys-x86/shared/sysdep/host_ldt.h | |||
@@ -0,0 +1,5 @@ | |||
1 | #ifdef __i386__ | ||
2 | #include "host_ldt_32.h" | ||
3 | #else | ||
4 | #include "host_ldt_64.h" | ||
5 | #endif | ||
diff --git a/arch/um/sys-i386/shared/sysdep/host_ldt.h b/arch/um/sys-x86/shared/sysdep/host_ldt_32.h index 0953cc4df652..0953cc4df652 100644 --- a/arch/um/sys-i386/shared/sysdep/host_ldt.h +++ b/arch/um/sys-x86/shared/sysdep/host_ldt_32.h | |||
diff --git a/arch/um/sys-x86_64/shared/sysdep/host_ldt.h b/arch/um/sys-x86/shared/sysdep/host_ldt_64.h index e8b1be1e154f..e8b1be1e154f 100644 --- a/arch/um/sys-x86_64/shared/sysdep/host_ldt.h +++ b/arch/um/sys-x86/shared/sysdep/host_ldt_64.h | |||
diff --git a/arch/um/sys-x86/shared/sysdep/kernel-offsets.h b/arch/um/sys-x86/shared/sysdep/kernel-offsets.h new file mode 100644 index 000000000000..346bc086fb91 --- /dev/null +++ b/arch/um/sys-x86/shared/sysdep/kernel-offsets.h | |||
@@ -0,0 +1,5 @@ | |||
1 | #ifdef __i386__ | ||
2 | #include "kernel-offsets_32.h" | ||
3 | #else | ||
4 | #include "kernel-offsets_64.h" | ||
5 | #endif | ||
diff --git a/arch/um/sys-i386/shared/sysdep/kernel-offsets.h b/arch/um/sys-x86/shared/sysdep/kernel-offsets_32.h index 5868526b5eef..5868526b5eef 100644 --- a/arch/um/sys-i386/shared/sysdep/kernel-offsets.h +++ b/arch/um/sys-x86/shared/sysdep/kernel-offsets_32.h | |||
diff --git a/arch/um/sys-x86_64/shared/sysdep/kernel-offsets.h b/arch/um/sys-x86/shared/sysdep/kernel-offsets_64.h index a307237b7964..a307237b7964 100644 --- a/arch/um/sys-x86_64/shared/sysdep/kernel-offsets.h +++ b/arch/um/sys-x86/shared/sysdep/kernel-offsets_64.h | |||
diff --git a/arch/um/sys-x86/shared/sysdep/ptrace.h b/arch/um/sys-x86/shared/sysdep/ptrace.h new file mode 100644 index 000000000000..711b1621747f --- /dev/null +++ b/arch/um/sys-x86/shared/sysdep/ptrace.h | |||
@@ -0,0 +1,5 @@ | |||
1 | #ifdef __i386__ | ||
2 | #include "ptrace_32.h" | ||
3 | #else | ||
4 | #include "ptrace_64.h" | ||
5 | #endif | ||
diff --git a/arch/um/sys-i386/shared/sysdep/ptrace.h b/arch/um/sys-x86/shared/sysdep/ptrace_32.h index 6096c8f89f4f..6096c8f89f4f 100644 --- a/arch/um/sys-i386/shared/sysdep/ptrace.h +++ b/arch/um/sys-x86/shared/sysdep/ptrace_32.h | |||
diff --git a/arch/um/sys-x86_64/shared/sysdep/ptrace.h b/arch/um/sys-x86/shared/sysdep/ptrace_64.h index 9ed4597fa942..9ed4597fa942 100644 --- a/arch/um/sys-x86_64/shared/sysdep/ptrace.h +++ b/arch/um/sys-x86/shared/sysdep/ptrace_64.h | |||
diff --git a/arch/um/sys-x86/shared/sysdep/ptrace_user.h b/arch/um/sys-x86/shared/sysdep/ptrace_user.h new file mode 100644 index 000000000000..a92f883264ed --- /dev/null +++ b/arch/um/sys-x86/shared/sysdep/ptrace_user.h | |||
@@ -0,0 +1,5 @@ | |||
1 | #ifdef __i386__ | ||
2 | #include "ptrace_user_32.h" | ||
3 | #else | ||
4 | #include "ptrace_user_64.h" | ||
5 | #endif | ||
diff --git a/arch/um/sys-i386/shared/sysdep/ptrace_user.h b/arch/um/sys-x86/shared/sysdep/ptrace_user_32.h index 9d88a79a138b..9d88a79a138b 100644 --- a/arch/um/sys-i386/shared/sysdep/ptrace_user.h +++ b/arch/um/sys-x86/shared/sysdep/ptrace_user_32.h | |||
diff --git a/arch/um/sys-x86_64/shared/sysdep/ptrace_user.h b/arch/um/sys-x86/shared/sysdep/ptrace_user_64.h index 2f1b6e33d590..2f1b6e33d590 100644 --- a/arch/um/sys-x86_64/shared/sysdep/ptrace_user.h +++ b/arch/um/sys-x86/shared/sysdep/ptrace_user_64.h | |||
diff --git a/arch/um/sys-x86/shared/sysdep/sigcontext.h b/arch/um/sys-x86/shared/sysdep/sigcontext.h new file mode 100644 index 000000000000..f7f49f46c23d --- /dev/null +++ b/arch/um/sys-x86/shared/sysdep/sigcontext.h | |||
@@ -0,0 +1,5 @@ | |||
1 | #ifdef __i386__ | ||
2 | #include "sigcontext_32.h" | ||
3 | #else | ||
4 | #include "sigcontext_64.h" | ||
5 | #endif | ||
diff --git a/arch/um/sys-i386/shared/sysdep/sigcontext.h b/arch/um/sys-x86/shared/sysdep/sigcontext_32.h index 382786436194..382786436194 100644 --- a/arch/um/sys-i386/shared/sysdep/sigcontext.h +++ b/arch/um/sys-x86/shared/sysdep/sigcontext_32.h | |||
diff --git a/arch/um/sys-x86_64/shared/sysdep/sigcontext.h b/arch/um/sys-x86/shared/sysdep/sigcontext_64.h index 9fb527713efb..9fb527713efb 100644 --- a/arch/um/sys-x86_64/shared/sysdep/sigcontext.h +++ b/arch/um/sys-x86/shared/sysdep/sigcontext_64.h | |||
diff --git a/arch/um/sys-x86/shared/sysdep/skas_ptrace.h b/arch/um/sys-x86/shared/sysdep/skas_ptrace.h new file mode 100644 index 000000000000..e63b575492ee --- /dev/null +++ b/arch/um/sys-x86/shared/sysdep/skas_ptrace.h | |||
@@ -0,0 +1,5 @@ | |||
1 | #ifdef __i386__ | ||
2 | #include "skas_ptrace_32.h" | ||
3 | #else | ||
4 | #include "skas_ptrace_64.h" | ||
5 | #endif | ||
diff --git a/arch/um/sys-i386/shared/sysdep/skas_ptrace.h b/arch/um/sys-x86/shared/sysdep/skas_ptrace_32.h index e27b8a791773..e27b8a791773 100644 --- a/arch/um/sys-i386/shared/sysdep/skas_ptrace.h +++ b/arch/um/sys-x86/shared/sysdep/skas_ptrace_32.h | |||
diff --git a/arch/um/sys-x86_64/shared/sysdep/skas_ptrace.h b/arch/um/sys-x86/shared/sysdep/skas_ptrace_64.h index 95db4be786e4..95db4be786e4 100644 --- a/arch/um/sys-x86_64/shared/sysdep/skas_ptrace.h +++ b/arch/um/sys-x86/shared/sysdep/skas_ptrace_64.h | |||
diff --git a/arch/um/sys-x86/shared/sysdep/stub.h b/arch/um/sys-x86/shared/sysdep/stub.h new file mode 100644 index 000000000000..13f523a3fcfa --- /dev/null +++ b/arch/um/sys-x86/shared/sysdep/stub.h | |||
@@ -0,0 +1,5 @@ | |||
1 | #ifdef __i386__ | ||
2 | #include "stub_32.h" | ||
3 | #else | ||
4 | #include "stub_64.h" | ||
5 | #endif | ||
diff --git a/arch/um/sys-i386/shared/sysdep/stub.h b/arch/um/sys-x86/shared/sysdep/stub_32.h index cca14d4ddf52..cca14d4ddf52 100644 --- a/arch/um/sys-i386/shared/sysdep/stub.h +++ b/arch/um/sys-x86/shared/sysdep/stub_32.h | |||
diff --git a/arch/um/sys-x86_64/shared/sysdep/stub.h b/arch/um/sys-x86/shared/sysdep/stub_64.h index 922a5702c8d8..922a5702c8d8 100644 --- a/arch/um/sys-x86_64/shared/sysdep/stub.h +++ b/arch/um/sys-x86/shared/sysdep/stub_64.h | |||
diff --git a/arch/um/sys-x86/shared/sysdep/syscalls.h b/arch/um/sys-x86/shared/sysdep/syscalls.h new file mode 100644 index 000000000000..bd9a89b67e41 --- /dev/null +++ b/arch/um/sys-x86/shared/sysdep/syscalls.h | |||
@@ -0,0 +1,5 @@ | |||
1 | #ifdef __i386__ | ||
2 | #include "syscalls_32.h" | ||
3 | #else | ||
4 | #include "syscalls_64.h" | ||
5 | #endif | ||
diff --git a/arch/um/sys-i386/shared/sysdep/syscalls.h b/arch/um/sys-x86/shared/sysdep/syscalls_32.h index 05cb796aecb5..05cb796aecb5 100644 --- a/arch/um/sys-i386/shared/sysdep/syscalls.h +++ b/arch/um/sys-x86/shared/sysdep/syscalls_32.h | |||
diff --git a/arch/um/sys-x86_64/shared/sysdep/syscalls.h b/arch/um/sys-x86/shared/sysdep/syscalls_64.h index 8a7d5e1da98e..8a7d5e1da98e 100644 --- a/arch/um/sys-x86_64/shared/sysdep/syscalls.h +++ b/arch/um/sys-x86/shared/sysdep/syscalls_64.h | |||
diff --git a/arch/um/sys-i386/shared/sysdep/system.h b/arch/um/sys-x86/shared/sysdep/system.h index d1b93c436200..d1b93c436200 100644 --- a/arch/um/sys-i386/shared/sysdep/system.h +++ b/arch/um/sys-x86/shared/sysdep/system.h | |||
diff --git a/arch/um/sys-x86/shared/sysdep/tls.h b/arch/um/sys-x86/shared/sysdep/tls.h new file mode 100644 index 000000000000..4d8f75262370 --- /dev/null +++ b/arch/um/sys-x86/shared/sysdep/tls.h | |||
@@ -0,0 +1,5 @@ | |||
1 | #ifdef __i386__ | ||
2 | #include "tls_32.h" | ||
3 | #else | ||
4 | #include "tls_64.h" | ||
5 | #endif | ||
diff --git a/arch/um/sys-i386/shared/sysdep/tls.h b/arch/um/sys-x86/shared/sysdep/tls_32.h index 34550755b2a1..34550755b2a1 100644 --- a/arch/um/sys-i386/shared/sysdep/tls.h +++ b/arch/um/sys-x86/shared/sysdep/tls_32.h | |||
diff --git a/arch/um/sys-x86_64/shared/sysdep/tls.h b/arch/um/sys-x86/shared/sysdep/tls_64.h index 18c000d0357a..18c000d0357a 100644 --- a/arch/um/sys-x86_64/shared/sysdep/tls.h +++ b/arch/um/sys-x86/shared/sysdep/tls_64.h | |||
diff --git a/arch/um/sys-x86_64/shared/sysdep/system.h b/arch/um/sys-x86_64/shared/sysdep/system.h deleted file mode 100644 index d1b93c436200..000000000000 --- a/arch/um/sys-x86_64/shared/sysdep/system.h +++ /dev/null | |||
@@ -1,132 +0,0 @@ | |||
1 | #ifndef _ASM_X86_SYSTEM_H_ | ||
2 | #define _ASM_X86_SYSTEM_H_ | ||
3 | |||
4 | #include <asm/asm.h> | ||
5 | #include <asm/segment.h> | ||
6 | #include <asm/cpufeature.h> | ||
7 | #include <asm/cmpxchg.h> | ||
8 | #include <asm/nops.h> | ||
9 | |||
10 | #include <linux/kernel.h> | ||
11 | #include <linux/irqflags.h> | ||
12 | |||
13 | /* entries in ARCH_DLINFO: */ | ||
14 | #ifdef CONFIG_IA32_EMULATION | ||
15 | # define AT_VECTOR_SIZE_ARCH 2 | ||
16 | #else | ||
17 | # define AT_VECTOR_SIZE_ARCH 1 | ||
18 | #endif | ||
19 | |||
20 | extern unsigned long arch_align_stack(unsigned long sp); | ||
21 | |||
22 | void default_idle(void); | ||
23 | |||
24 | /* | ||
25 | * Force strict CPU ordering. | ||
26 | * And yes, this is required on UP too when we're talking | ||
27 | * to devices. | ||
28 | */ | ||
29 | #ifdef CONFIG_X86_32 | ||
30 | /* | ||
31 | * Some non-Intel clones support out of order store. wmb() ceases to be a | ||
32 | * nop for these. | ||
33 | */ | ||
34 | #define mb() alternative("lock; addl $0,0(%%esp)", "mfence", X86_FEATURE_XMM2) | ||
35 | #define rmb() alternative("lock; addl $0,0(%%esp)", "lfence", X86_FEATURE_XMM2) | ||
36 | #define wmb() alternative("lock; addl $0,0(%%esp)", "sfence", X86_FEATURE_XMM) | ||
37 | #else | ||
38 | #define mb() asm volatile("mfence":::"memory") | ||
39 | #define rmb() asm volatile("lfence":::"memory") | ||
40 | #define wmb() asm volatile("sfence" ::: "memory") | ||
41 | #endif | ||
42 | |||
43 | /** | ||
44 | * read_barrier_depends - Flush all pending reads that subsequents reads | ||
45 | * depend on. | ||
46 | * | ||
47 | * No data-dependent reads from memory-like regions are ever reordered | ||
48 | * over this barrier. All reads preceding this primitive are guaranteed | ||
49 | * to access memory (but not necessarily other CPUs' caches) before any | ||
50 | * reads following this primitive that depend on the data return by | ||
51 | * any of the preceding reads. This primitive is much lighter weight than | ||
52 | * rmb() on most CPUs, and is never heavier weight than is | ||
53 | * rmb(). | ||
54 | * | ||
55 | * These ordering constraints are respected by both the local CPU | ||
56 | * and the compiler. | ||
57 | * | ||
58 | * Ordering is not guaranteed by anything other than these primitives, | ||
59 | * not even by data dependencies. See the documentation for | ||
60 | * memory_barrier() for examples and URLs to more information. | ||
61 | * | ||
62 | * For example, the following code would force ordering (the initial | ||
63 | * value of "a" is zero, "b" is one, and "p" is "&a"): | ||
64 | * | ||
65 | * <programlisting> | ||
66 | * CPU 0 CPU 1 | ||
67 | * | ||
68 | * b = 2; | ||
69 | * memory_barrier(); | ||
70 | * p = &b; q = p; | ||
71 | * read_barrier_depends(); | ||
72 | * d = *q; | ||
73 | * </programlisting> | ||
74 | * | ||
75 | * because the read of "*q" depends on the read of "p" and these | ||
76 | * two reads are separated by a read_barrier_depends(). However, | ||
77 | * the following code, with the same initial values for "a" and "b": | ||
78 | * | ||
79 | * <programlisting> | ||
80 | * CPU 0 CPU 1 | ||
81 | * | ||
82 | * a = 2; | ||
83 | * memory_barrier(); | ||
84 | * b = 3; y = b; | ||
85 | * read_barrier_depends(); | ||
86 | * x = a; | ||
87 | * </programlisting> | ||
88 | * | ||
89 | * does not enforce ordering, since there is no data dependency between | ||
90 | * the read of "a" and the read of "b". Therefore, on some CPUs, such | ||
91 | * as Alpha, "y" could be set to 3 and "x" to 0. Use rmb() | ||
92 | * in cases like this where there are no data dependencies. | ||
93 | **/ | ||
94 | |||
95 | #define read_barrier_depends() do { } while (0) | ||
96 | |||
97 | #ifdef CONFIG_SMP | ||
98 | #define smp_mb() mb() | ||
99 | #ifdef CONFIG_X86_PPRO_FENCE | ||
100 | # define smp_rmb() rmb() | ||
101 | #else | ||
102 | # define smp_rmb() barrier() | ||
103 | #endif | ||
104 | #ifdef CONFIG_X86_OOSTORE | ||
105 | # define smp_wmb() wmb() | ||
106 | #else | ||
107 | # define smp_wmb() barrier() | ||
108 | #endif | ||
109 | #define smp_read_barrier_depends() read_barrier_depends() | ||
110 | #define set_mb(var, value) do { (void)xchg(&var, value); } while (0) | ||
111 | #else | ||
112 | #define smp_mb() barrier() | ||
113 | #define smp_rmb() barrier() | ||
114 | #define smp_wmb() barrier() | ||
115 | #define smp_read_barrier_depends() do { } while (0) | ||
116 | #define set_mb(var, value) do { var = value; barrier(); } while (0) | ||
117 | #endif | ||
118 | |||
119 | /* | ||
120 | * Stop RDTSC speculation. This is needed when you need to use RDTSC | ||
121 | * (or get_cycles or vread that possibly accesses the TSC) in a defined | ||
122 | * code region. | ||
123 | * | ||
124 | * (Could use an alternative three way for this if there was one.) | ||
125 | */ | ||
126 | static inline void rdtsc_barrier(void) | ||
127 | { | ||
128 | alternative(ASM_NOP3, "mfence", X86_FEATURE_MFENCE_RDTSC); | ||
129 | alternative(ASM_NOP3, "lfence", X86_FEATURE_LFENCE_RDTSC); | ||
130 | } | ||
131 | |||
132 | #endif | ||