diff options
Diffstat (limited to 'arch/x86/vdso')
| -rw-r--r-- | arch/x86/vdso/Makefile | 17 | ||||
| -rw-r--r-- | arch/x86/vdso/vdso.lds.S | 16 | ||||
| -rw-r--r-- | arch/x86/vdso/vvar.c | 2 |
3 files changed, 26 insertions, 9 deletions
diff --git a/arch/x86/vdso/Makefile b/arch/x86/vdso/Makefile index dcd6bb9e0bb3..7a2ba4583939 100644 --- a/arch/x86/vdso/Makefile +++ b/arch/x86/vdso/Makefile | |||
| @@ -13,7 +13,7 @@ vobjs := $(foreach F,$(vobjs-y),$(obj)/$F) | |||
| 13 | 13 | ||
| 14 | $(obj)/vdso.o: $(obj)/vdso.so | 14 | $(obj)/vdso.o: $(obj)/vdso.so |
| 15 | 15 | ||
| 16 | targets += vdso.so vdso.lds $(vobjs-y) vdso-syms.o | 16 | targets += vdso.so vdso.so.dbg vdso.lds $(vobjs-y) vdso-syms.o |
| 17 | 17 | ||
| 18 | # The DSO images are built using a special linker script. | 18 | # The DSO images are built using a special linker script. |
| 19 | quiet_cmd_syscall = SYSCALL $@ | 19 | quiet_cmd_syscall = SYSCALL $@ |
| @@ -26,12 +26,19 @@ vdso-flags = -fPIC -shared -Wl,-soname=linux-vdso.so.1 \ | |||
| 26 | $(call ld-option, -Wl$(comma)--hash-style=sysv) \ | 26 | $(call ld-option, -Wl$(comma)--hash-style=sysv) \ |
| 27 | -Wl,-z,max-page-size=4096 -Wl,-z,common-page-size=4096 | 27 | -Wl,-z,max-page-size=4096 -Wl,-z,common-page-size=4096 |
| 28 | SYSCFLAGS_vdso.so = $(vdso-flags) | 28 | SYSCFLAGS_vdso.so = $(vdso-flags) |
| 29 | SYSCFLAGS_vdso.so.dbg = $(vdso-flags) | ||
| 29 | 30 | ||
| 30 | $(obj)/vdso.o: $(src)/vdso.S $(obj)/vdso.so | 31 | $(obj)/vdso.o: $(src)/vdso.S $(obj)/vdso.so |
| 31 | 32 | ||
| 32 | $(obj)/vdso.so: $(src)/vdso.lds $(vobjs) FORCE | 33 | $(obj)/vdso.so: $(src)/vdso.lds $(vobjs) FORCE |
| 34 | |||
| 35 | $(obj)/vdso.so.dbg: $(src)/vdso.lds $(vobjs) FORCE | ||
| 33 | $(call if_changed,syscall) | 36 | $(call if_changed,syscall) |
| 34 | 37 | ||
| 38 | $(obj)/%.so: OBJCOPYFLAGS := -S | ||
| 39 | $(obj)/%.so: $(obj)/%.so.dbg FORCE | ||
| 40 | $(call if_changed,objcopy) | ||
| 41 | |||
| 35 | CFL := $(PROFILING) -mcmodel=small -fPIC -g0 -O2 -fasynchronous-unwind-tables -m64 | 42 | CFL := $(PROFILING) -mcmodel=small -fPIC -g0 -O2 -fasynchronous-unwind-tables -m64 |
| 36 | 43 | ||
| 37 | $(obj)/vclock_gettime.o: KBUILD_CFLAGS = $(CFL) | 44 | $(obj)/vclock_gettime.o: KBUILD_CFLAGS = $(CFL) |
| @@ -47,3 +54,11 @@ $(obj)/built-in.o: ld_flags += -R $(obj)/vdso-syms.o | |||
| 47 | SYSCFLAGS_vdso-syms.o = -r -d | 54 | SYSCFLAGS_vdso-syms.o = -r -d |
| 48 | $(obj)/vdso-syms.o: $(src)/vdso.lds $(vobjs) FORCE | 55 | $(obj)/vdso-syms.o: $(src)/vdso.lds $(vobjs) FORCE |
| 49 | $(call if_changed,syscall) | 56 | $(call if_changed,syscall) |
| 57 | |||
| 58 | quiet_cmd_vdso_install = INSTALL $@ | ||
| 59 | cmd_vdso_install = cp $(obj)/$@.dbg $(MODLIB)/vdso/$@ | ||
| 60 | vdso.so: | ||
| 61 | @mkdir -p $(MODLIB)/vdso | ||
| 62 | $(call cmd,vdso_install) | ||
| 63 | |||
| 64 | vdso_install: vdso.so | ||
diff --git a/arch/x86/vdso/vdso.lds.S b/arch/x86/vdso/vdso.lds.S index b9a60e665d08..667d3245d972 100644 --- a/arch/x86/vdso/vdso.lds.S +++ b/arch/x86/vdso/vdso.lds.S | |||
| @@ -26,13 +26,16 @@ SECTIONS | |||
| 26 | is insufficient, ld -shared will barf. Just increase it here. */ | 26 | is insufficient, ld -shared will barf. Just increase it here. */ |
| 27 | . = VDSO_PRELINK + VDSO_TEXT_OFFSET; | 27 | . = VDSO_PRELINK + VDSO_TEXT_OFFSET; |
| 28 | 28 | ||
| 29 | .text : { *(.text) } :text | 29 | .text : { *(.text*) } :text |
| 30 | .text.ptr : { *(.text.ptr) } :text | 30 | .rodata : { *(.rodata*) } :text |
| 31 | . = VDSO_PRELINK + 0x900; | 31 | .data : { |
| 32 | .data : { *(.data) } :text | 32 | *(.data*) |
| 33 | .bss : { *(.bss) } :text | 33 | *(.sdata*) |
| 34 | *(.bss*) | ||
| 35 | *(.dynbss*) | ||
| 36 | } :text | ||
| 34 | 37 | ||
| 35 | .altinstructions : { *(.altinstructions) } :text | 38 | .altinstructions : { *(.altinstructions) } :text |
| 36 | .altinstr_replacement : { *(.altinstr_replacement) } :text | 39 | .altinstr_replacement : { *(.altinstr_replacement) } :text |
| 37 | 40 | ||
| 38 | .note : { *(.note.*) } :text :note | 41 | .note : { *(.note.*) } :text :note |
| @@ -42,7 +45,6 @@ SECTIONS | |||
| 42 | .useless : { | 45 | .useless : { |
| 43 | *(.got.plt) *(.got) | 46 | *(.got.plt) *(.got) |
| 44 | *(.gnu.linkonce.d.*) | 47 | *(.gnu.linkonce.d.*) |
| 45 | *(.dynbss) | ||
| 46 | *(.gnu.linkonce.b.*) | 48 | *(.gnu.linkonce.b.*) |
| 47 | } :text | 49 | } :text |
| 48 | } | 50 | } |
diff --git a/arch/x86/vdso/vvar.c b/arch/x86/vdso/vvar.c index 6fc22219a472..1b7e703684f9 100644 --- a/arch/x86/vdso/vvar.c +++ b/arch/x86/vdso/vvar.c | |||
| @@ -8,5 +8,5 @@ | |||
| 8 | #include <asm/timex.h> | 8 | #include <asm/timex.h> |
| 9 | #include <asm/vgtod.h> | 9 | #include <asm/vgtod.h> |
| 10 | 10 | ||
| 11 | #define VEXTERN(x) typeof (__ ## x) *vdso_ ## x = (void *)VMAGIC; | 11 | #define VEXTERN(x) typeof (__ ## x) *const vdso_ ## x = (void *)VMAGIC; |
| 12 | #include "vextern.h" | 12 | #include "vextern.h" |
