diff options
author | Thomas Gleixner <tglx@linutronix.de> | 2008-01-30 07:30:20 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-01-30 07:30:20 -0500 |
commit | 2f18e47c89f1a29cc815cd225b72dd7fd86acffe (patch) | |
tree | 9bb4bfc8a7acf15aa351d3b0574e727cd4e2497a /include/asm-x86/futex_32.h | |
parent | 2f2239d1d53b06dd475634f79e1905f3775fcedc (diff) |
x86: merge futex_32/64.h
Finally merge them together.
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'include/asm-x86/futex_32.h')
-rw-r--r-- | include/asm-x86/futex_32.h | 133 |
1 files changed, 0 insertions, 133 deletions
diff --git a/include/asm-x86/futex_32.h b/include/asm-x86/futex_32.h deleted file mode 100644 index c80013e19c21..000000000000 --- a/include/asm-x86/futex_32.h +++ /dev/null | |||
@@ -1,133 +0,0 @@ | |||
1 | #ifndef _ASM_FUTEX_H | ||
2 | #define _ASM_FUTEX_H | ||
3 | |||
4 | #ifdef __KERNEL__ | ||
5 | |||
6 | #include <linux/futex.h> | ||
7 | |||
8 | #include <asm/asm.h> | ||
9 | #include <asm/errno.h> | ||
10 | #include <asm/system.h> | ||
11 | #include <asm/processor.h> | ||
12 | #include <asm/uaccess.h> | ||
13 | |||
14 | #define __futex_atomic_op1(insn, ret, oldval, uaddr, oparg) \ | ||
15 | __asm__ __volatile ( \ | ||
16 | "1: " insn "\n" \ | ||
17 | "2: .section .fixup,\"ax\"\n\ | ||
18 | 3: mov %3, %1\n\ | ||
19 | jmp 2b\n\ | ||
20 | .previous\n\ | ||
21 | .section __ex_table,\"a\"\n\ | ||
22 | .align 8\n" \ | ||
23 | _ASM_PTR "1b,3b\n \ | ||
24 | .previous" \ | ||
25 | : "=r" (oldval), "=r" (ret), "+m" (*uaddr) \ | ||
26 | : "i" (-EFAULT), "0" (oparg), "1" (0)) | ||
27 | |||
28 | #define __futex_atomic_op2(insn, ret, oldval, uaddr, oparg) \ | ||
29 | __asm__ __volatile ( \ | ||
30 | "1: movl %2, %0\n\ | ||
31 | movl %0, %3\n" \ | ||
32 | insn "\n" \ | ||
33 | "2: " LOCK_PREFIX "cmpxchgl %3, %2\n\ | ||
34 | jnz 1b\n\ | ||
35 | 3: .section .fixup,\"ax\"\n\ | ||
36 | 4: mov %5, %1\n\ | ||
37 | jmp 3b\n\ | ||
38 | .previous\n\ | ||
39 | .section __ex_table,\"a\"\n\ | ||
40 | .align 8\n" \ | ||
41 | _ASM_PTR "1b,4b,2b,4b\n \ | ||
42 | .previous" \ | ||
43 | : "=&a" (oldval), "=&r" (ret), "+m" (*uaddr), \ | ||
44 | "=&r" (tem) \ | ||
45 | : "r" (oparg), "i" (-EFAULT), "1" (0)) | ||
46 | |||
47 | static inline int | ||
48 | futex_atomic_op_inuser (int encoded_op, int __user *uaddr) | ||
49 | { | ||
50 | int op = (encoded_op >> 28) & 7; | ||
51 | int cmp = (encoded_op >> 24) & 15; | ||
52 | int oparg = (encoded_op << 8) >> 20; | ||
53 | int cmparg = (encoded_op << 20) >> 20; | ||
54 | int oldval = 0, ret, tem; | ||
55 | if (encoded_op & (FUTEX_OP_OPARG_SHIFT << 28)) | ||
56 | oparg = 1 << oparg; | ||
57 | |||
58 | if (! access_ok (VERIFY_WRITE, uaddr, sizeof(int))) | ||
59 | return -EFAULT; | ||
60 | |||
61 | #ifndef CONFIG_X86_BSWAP | ||
62 | if (op == FUTEX_OP_SET && boot_cpu_data.x86 == 3) | ||
63 | return -ENOSYS; | ||
64 | #endif | ||
65 | |||
66 | pagefault_disable(); | ||
67 | |||
68 | switch (op) { | ||
69 | case FUTEX_OP_SET: | ||
70 | __futex_atomic_op1("xchgl %0, %2", ret, oldval, uaddr, oparg); | ||
71 | break; | ||
72 | case FUTEX_OP_ADD: | ||
73 | __futex_atomic_op1(LOCK_PREFIX "xaddl %0, %2", ret, oldval, | ||
74 | uaddr, oparg); | ||
75 | break; | ||
76 | case FUTEX_OP_OR: | ||
77 | __futex_atomic_op2("orl %4, %3", ret, oldval, uaddr, oparg); | ||
78 | break; | ||
79 | case FUTEX_OP_ANDN: | ||
80 | __futex_atomic_op2("andl %4, %3", ret, oldval, uaddr, ~oparg); | ||
81 | break; | ||
82 | case FUTEX_OP_XOR: | ||
83 | __futex_atomic_op2("xorl %4, %3", ret, oldval, uaddr, oparg); | ||
84 | break; | ||
85 | default: | ||
86 | ret = -ENOSYS; | ||
87 | } | ||
88 | |||
89 | pagefault_enable(); | ||
90 | |||
91 | if (!ret) { | ||
92 | switch (cmp) { | ||
93 | case FUTEX_OP_CMP_EQ: ret = (oldval == cmparg); break; | ||
94 | case FUTEX_OP_CMP_NE: ret = (oldval != cmparg); break; | ||
95 | case FUTEX_OP_CMP_LT: ret = (oldval < cmparg); break; | ||
96 | case FUTEX_OP_CMP_GE: ret = (oldval >= cmparg); break; | ||
97 | case FUTEX_OP_CMP_LE: ret = (oldval <= cmparg); break; | ||
98 | case FUTEX_OP_CMP_GT: ret = (oldval > cmparg); break; | ||
99 | default: ret = -ENOSYS; | ||
100 | } | ||
101 | } | ||
102 | return ret; | ||
103 | } | ||
104 | |||
105 | static inline int | ||
106 | futex_atomic_cmpxchg_inatomic(int __user *uaddr, int oldval, int newval) | ||
107 | { | ||
108 | if (!access_ok(VERIFY_WRITE, uaddr, sizeof(int))) | ||
109 | return -EFAULT; | ||
110 | |||
111 | __asm__ __volatile__( | ||
112 | "1: " LOCK_PREFIX "cmpxchgl %3, %1 \n" | ||
113 | |||
114 | "2: .section .fixup, \"ax\" \n" | ||
115 | "3: mov %2, %0 \n" | ||
116 | " jmp 2b \n" | ||
117 | " .previous \n" | ||
118 | |||
119 | " .section __ex_table, \"a\" \n" | ||
120 | " .align 8 \n" | ||
121 | _ASM_PTR " 1b,3b \n" | ||
122 | " .previous \n" | ||
123 | |||
124 | : "=a" (oldval), "+m" (*uaddr) | ||
125 | : "i" (-EFAULT), "r" (newval), "0" (oldval) | ||
126 | : "memory" | ||
127 | ); | ||
128 | |||
129 | return oldval; | ||
130 | } | ||
131 | |||
132 | #endif | ||
133 | #endif | ||