diff options
author | Tejun Heo <tj@kernel.org> | 2009-01-13 06:41:35 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2009-01-16 08:20:22 -0500 |
commit | 49357d19e4fb31e28796eaff83499e7584c26878 (patch) | |
tree | c0b425a5f3a187ae25ebc662816aa7c95c9cc59f /arch/x86/include/asm/percpu.h | |
parent | b12d8db8fbfaed1e8222a15333a3645599636854 (diff) |
x86: convert pda ops to wrappers around x86 percpu accessors
pda is now a percpu variable and there's no reason it can't use plain
x86 percpu accessors. Add x86_test_and_clear_bit_percpu() and replace
pda op implementations with wrappers around x86 percpu accessors.
Signed-off-by: Tejun Heo <tj@kernel.org>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/x86/include/asm/percpu.h')
-rw-r--r-- | arch/x86/include/asm/percpu.h | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/arch/x86/include/asm/percpu.h b/arch/x86/include/asm/percpu.h index 556f84b9ea96..328b31a429d7 100644 --- a/arch/x86/include/asm/percpu.h +++ b/arch/x86/include/asm/percpu.h | |||
@@ -121,6 +121,16 @@ do { \ | |||
121 | #define x86_sub_percpu(var, val) percpu_to_op("sub", per_cpu__##var, val) | 121 | #define x86_sub_percpu(var, val) percpu_to_op("sub", per_cpu__##var, val) |
122 | #define x86_or_percpu(var, val) percpu_to_op("or", per_cpu__##var, val) | 122 | #define x86_or_percpu(var, val) percpu_to_op("or", per_cpu__##var, val) |
123 | 123 | ||
124 | /* This is not atomic against other CPUs -- CPU preemption needs to be off */ | ||
125 | #define x86_test_and_clear_bit_percpu(bit, var) \ | ||
126 | ({ \ | ||
127 | int old__; \ | ||
128 | asm volatile("btr %1,"__percpu_seg_str"%c2\n\tsbbl %0,%0" \ | ||
129 | : "=r" (old__) \ | ||
130 | : "dIr" (bit), "i" (&per_cpu__##var) : "memory"); \ | ||
131 | old__; \ | ||
132 | }) | ||
133 | |||
124 | #ifdef CONFIG_X86_64 | 134 | #ifdef CONFIG_X86_64 |
125 | extern void load_pda_offset(int cpu); | 135 | extern void load_pda_offset(int cpu); |
126 | #else | 136 | #else |