diff options
author | Roland McGrath <roland@redhat.com> | 2008-01-30 07:30:42 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-01-30 07:30:42 -0500 |
commit | 6c3652efcafa6a6d795093362cb4290c84994b5c (patch) | |
tree | 1587379f45a7145a64c3103b40e12b01c46ea559 /include/asm-x86 | |
parent | 0249c9c1e7505c2b020bcc6deaf1e0415de9943e (diff) |
x86 vDSO: i386 vdso32
This makes the i386 kernel use the new vDSO build in arch/x86/vdso/vdso32/
to replace the old one from arch/x86/kernel/.
Signed-off-by: Roland McGrath <roland@redhat.com>
Cc: Andrew Morton <akpm@linux-foundation.org>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'include/asm-x86')
-rw-r--r-- | include/asm-x86/elf.h | 13 | ||||
-rw-r--r-- | include/asm-x86/vdso.h | 14 |
2 files changed, 17 insertions, 10 deletions
diff --git a/include/asm-x86/elf.h b/include/asm-x86/elf.h index cd3204ebbbdd..70edff2d5671 100644 --- a/include/asm-x86/elf.h +++ b/include/asm-x86/elf.h | |||
@@ -78,6 +78,7 @@ typedef struct user_fxsr_struct elf_fpxregset_t; | |||
78 | #include <asm/processor.h> | 78 | #include <asm/processor.h> |
79 | #include <asm/system.h> /* for savesegment */ | 79 | #include <asm/system.h> /* for savesegment */ |
80 | #include <asm/desc.h> | 80 | #include <asm/desc.h> |
81 | #include <asm/vdso.h> | ||
81 | 82 | ||
82 | /* | 83 | /* |
83 | * This is used to ensure we don't load something for the wrong architecture. | 84 | * This is used to ensure we don't load something for the wrong architecture. |
@@ -247,17 +248,9 @@ extern int dump_task_extended_fpu (struct task_struct *, | |||
247 | 248 | ||
248 | #define VDSO_HIGH_BASE (__fix_to_virt(FIX_VDSO)) | 249 | #define VDSO_HIGH_BASE (__fix_to_virt(FIX_VDSO)) |
249 | #define VDSO_CURRENT_BASE ((unsigned long)current->mm->context.vdso) | 250 | #define VDSO_CURRENT_BASE ((unsigned long)current->mm->context.vdso) |
250 | #define VDSO_PRELINK 0 | ||
251 | 251 | ||
252 | #define VDSO_SYM(x) \ | 252 | #define VDSO_ENTRY \ |
253 | (VDSO_CURRENT_BASE + (unsigned long)(x) - VDSO_PRELINK) | 253 | ((unsigned long) VDSO32_SYMBOL(VDSO_CURRENT_BASE, vsyscall)) |
254 | |||
255 | #define VDSO_HIGH_EHDR ((const struct elfhdr *) VDSO_HIGH_BASE) | ||
256 | #define VDSO_EHDR ((const struct elfhdr *) VDSO_CURRENT_BASE) | ||
257 | |||
258 | extern void __kernel_vsyscall; | ||
259 | |||
260 | #define VDSO_ENTRY VDSO_SYM(&__kernel_vsyscall) | ||
261 | 254 | ||
262 | /* update AT_VECTOR_SIZE_ARCH if the number of NEW_AUX_ENT entries changes */ | 255 | /* update AT_VECTOR_SIZE_ARCH if the number of NEW_AUX_ENT entries changes */ |
263 | 256 | ||
diff --git a/include/asm-x86/vdso.h b/include/asm-x86/vdso.h index 9379ec06fd1f..629bcb6e8e45 100644 --- a/include/asm-x86/vdso.h +++ b/include/asm-x86/vdso.h | |||
@@ -1,6 +1,7 @@ | |||
1 | #ifndef _ASM_X86_VDSO_H | 1 | #ifndef _ASM_X86_VDSO_H |
2 | #define _ASM_X86_VDSO_H 1 | 2 | #define _ASM_X86_VDSO_H 1 |
3 | 3 | ||
4 | #ifdef CONFIG_X86_64 | ||
4 | extern const char VDSO64_PRELINK[]; | 5 | extern const char VDSO64_PRELINK[]; |
5 | 6 | ||
6 | /* | 7 | /* |
@@ -10,5 +11,18 @@ extern const char VDSO64_PRELINK[]; | |||
10 | #define VDSO64_SYMBOL(base, name) ({ \ | 11 | #define VDSO64_SYMBOL(base, name) ({ \ |
11 | extern const char VDSO64_##name[]; \ | 12 | extern const char VDSO64_##name[]; \ |
12 | (void *) (VDSO64_##name - VDSO64_PRELINK + (unsigned long) (base)); }) | 13 | (void *) (VDSO64_##name - VDSO64_PRELINK + (unsigned long) (base)); }) |
14 | #endif | ||
15 | |||
16 | #if defined CONFIG_X86_32 || defined CONFIG_COMPAT | ||
17 | extern const char VDSO32_PRELINK[]; | ||
18 | |||
19 | /* | ||
20 | * Given a pointer to the vDSO image, find the pointer to VDSO32_name | ||
21 | * as that symbol is defined in the vDSO sources or linker script. | ||
22 | */ | ||
23 | #define VDSO32_SYMBOL(base, name) ({ \ | ||
24 | extern const char VDSO32_##name[]; \ | ||
25 | (void *) (VDSO32_##name - VDSO32_PRELINK + (unsigned long) (base)); }) | ||
26 | #endif | ||
13 | 27 | ||
14 | #endif /* asm-x86/vdso.h */ | 28 | #endif /* asm-x86/vdso.h */ |