diff options
| author | Martin Schwidefsky <schwidefsky@de.ibm.com> | 2008-12-25 07:38:36 -0500 |
|---|---|---|
| committer | Martin Schwidefsky <schwidefsky@de.ibm.com> | 2008-12-25 07:38:55 -0500 |
| commit | b020632e40c3ed5e8c0c066d022672907e8401cf (patch) | |
| tree | d7f805bd27e8378436fbba7e7457afbd10c22ed8 /arch/s390/kernel/vdso32 | |
| parent | fc5243d98ac2575ad14a974b3c097e9ba874c03d (diff) | |
[S390] introduce vdso on s390
Add a vdso to speed up gettimeofday and clock_getres/clock_gettime for
CLOCK_REALTIME/CLOCK_MONOTONIC.
Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
Diffstat (limited to 'arch/s390/kernel/vdso32')
| -rw-r--r-- | arch/s390/kernel/vdso32/Makefile | 55 | ||||
| -rw-r--r-- | arch/s390/kernel/vdso32/clock_getres.S | 39 | ||||
| -rw-r--r-- | arch/s390/kernel/vdso32/clock_gettime.S | 128 | ||||
| -rw-r--r-- | arch/s390/kernel/vdso32/gettimeofday.S | 82 | ||||
| -rw-r--r-- | arch/s390/kernel/vdso32/note.S | 12 | ||||
| -rw-r--r-- | arch/s390/kernel/vdso32/vdso32.lds.S | 138 | ||||
| -rw-r--r-- | arch/s390/kernel/vdso32/vdso32_wrapper.S | 13 |
7 files changed, 467 insertions, 0 deletions
diff --git a/arch/s390/kernel/vdso32/Makefile b/arch/s390/kernel/vdso32/Makefile new file mode 100644 index 000000000000..ca78ad60ba24 --- /dev/null +++ b/arch/s390/kernel/vdso32/Makefile | |||
| @@ -0,0 +1,55 @@ | |||
| 1 | # List of files in the vdso, has to be asm only for now | ||
| 2 | |||
| 3 | obj-vdso32 = gettimeofday.o clock_getres.o clock_gettime.o note.o | ||
| 4 | |||
| 5 | # Build rules | ||
| 6 | |||
| 7 | targets := $(obj-vdso32) vdso32.so vdso32.so.dbg | ||
| 8 | obj-vdso32 := $(addprefix $(obj)/, $(obj-vdso32)) | ||
| 9 | |||
| 10 | KBUILD_AFLAGS_31 := $(filter-out -m64,$(KBUILD_AFLAGS)) | ||
| 11 | KBUILD_AFLAGS_31 += -m31 -s | ||
| 12 | |||
| 13 | KBUILD_CFLAGS_31 := $(filter-out -m64,$(KBUILD_CFLAGS)) | ||
| 14 | KBUILD_CFLAGS_31 += -m31 -fPIC -shared -fno-common -fno-builtin | ||
| 15 | KBUILD_CFLAGS_31 += -nostdlib -Wl,-soname=linux-vdso32.so.1 \ | ||
| 16 | $(call ld-option, -Wl$(comma)--hash-style=sysv) | ||
| 17 | |||
| 18 | $(targets:%=$(obj)/%.dbg): KBUILD_CFLAGS = $(KBUILD_CFLAGS_31) | ||
| 19 | $(targets:%=$(obj)/%.dbg): KBUILD_AFLAGS = $(KBUILD_AFLAGS_31) | ||
| 20 | |||
| 21 | obj-y += vdso32_wrapper.o | ||
| 22 | extra-y += vdso32.lds | ||
| 23 | CPPFLAGS_vdso32.lds += -P -C -U$(ARCH) | ||
| 24 | |||
| 25 | # Force dependency (incbin is bad) | ||
| 26 | $(obj)/vdso32_wrapper.o : $(obj)/vdso32.so | ||
| 27 | |||
| 28 | # link rule for the .so file, .lds has to be first | ||
| 29 | $(obj)/vdso32.so.dbg: $(src)/vdso32.lds $(obj-vdso32) | ||
| 30 | $(call if_changed,vdso32ld) | ||
| 31 | |||
| 32 | # strip rule for the .so file | ||
| 33 | $(obj)/%.so: OBJCOPYFLAGS := -S | ||
| 34 | $(obj)/%.so: $(obj)/%.so.dbg FORCE | ||
| 35 | $(call if_changed,objcopy) | ||
| 36 | |||
| 37 | # assembly rules for the .S files | ||
| 38 | $(obj-vdso32): %.o: %.S | ||
| 39 | $(call if_changed_dep,vdso32as) | ||
| 40 | |||
| 41 | # actual build commands | ||
| 42 | quiet_cmd_vdso32ld = VDSO32L $@ | ||
| 43 | cmd_vdso32ld = $(CC) $(c_flags) -Wl,-T $^ -o $@ | ||
| 44 | quiet_cmd_vdso32as = VDSO32A $@ | ||
| 45 | cmd_vdso32as = $(CC) $(a_flags) -c -o $@ $< | ||
| 46 | |||
| 47 | # install commands for the unstripped file | ||
| 48 | quiet_cmd_vdso_install = INSTALL $@ | ||
| 49 | cmd_vdso_install = cp $(obj)/$@.dbg $(MODLIB)/vdso/$@ | ||
| 50 | |||
| 51 | vdso32.so: $(obj)/vdso32.so.dbg | ||
| 52 | @mkdir -p $(MODLIB)/vdso | ||
| 53 | $(call cmd,vdso_install) | ||
| 54 | |||
| 55 | vdso_install: vdso32.so | ||
diff --git a/arch/s390/kernel/vdso32/clock_getres.S b/arch/s390/kernel/vdso32/clock_getres.S new file mode 100644 index 000000000000..9532c4e6a9d2 --- /dev/null +++ b/arch/s390/kernel/vdso32/clock_getres.S | |||
| @@ -0,0 +1,39 @@ | |||
| 1 | /* | ||
| 2 | * Userland implementation of clock_getres() for 32 bits processes in a | ||
| 3 | * s390 kernel for use in the vDSO | ||
| 4 | * | ||
| 5 | * Copyright IBM Corp. 2008 | ||
| 6 | * Author(s): Martin Schwidefsky (schwidefsky@de.ibm.com) | ||
| 7 | * | ||
| 8 | * This program is free software; you can redistribute it and/or modify | ||
| 9 | * it under the terms of the GNU General Public License (version 2 only) | ||
| 10 | * as published by the Free Software Foundation. | ||
| 11 | */ | ||
| 12 | #include <asm/vdso.h> | ||
| 13 | #include <asm/asm-offsets.h> | ||
| 14 | #include <asm/unistd.h> | ||
| 15 | |||
| 16 | .text | ||
| 17 | .align 4 | ||
| 18 | .globl __kernel_clock_getres | ||
| 19 | .type __kernel_clock_getres,@function | ||
| 20 | __kernel_clock_getres: | ||
| 21 | .cfi_startproc | ||
| 22 | chi %r2,CLOCK_REALTIME | ||
| 23 | je 0f | ||
| 24 | chi %r2,CLOCK_MONOTONIC | ||
| 25 | jne 3f | ||
| 26 | 0: ltr %r3,%r3 | ||
| 27 | jz 2f /* res == NULL */ | ||
| 28 | basr %r1,0 | ||
| 29 | 1: l %r0,4f-1b(%r1) | ||
| 30 | xc 0(4,%r3),0(%r3) /* set tp->tv_sec to zero */ | ||
| 31 | st %r0,4(%r3) /* store tp->tv_usec */ | ||
| 32 | 2: lhi %r2,0 | ||
| 33 | br %r14 | ||
| 34 | 3: lhi %r1,__NR_clock_getres /* fallback to svc */ | ||
| 35 | svc 0 | ||
| 36 | br %r14 | ||
| 37 | 4: .long CLOCK_REALTIME_RES | ||
| 38 | .cfi_endproc | ||
| 39 | .size __kernel_clock_getres,.-__kernel_clock_getres | ||
diff --git a/arch/s390/kernel/vdso32/clock_gettime.S b/arch/s390/kernel/vdso32/clock_gettime.S new file mode 100644 index 000000000000..4a98909a8310 --- /dev/null +++ b/arch/s390/kernel/vdso32/clock_gettime.S | |||
| @@ -0,0 +1,128 @@ | |||
| 1 | /* | ||
| 2 | * Userland implementation of clock_gettime() for 32 bits processes in a | ||
| 3 | * s390 kernel for use in the vDSO | ||
| 4 | * | ||
| 5 | * Copyright IBM Corp. 2008 | ||
| 6 | * Author(s): Martin Schwidefsky (schwidefsky@de.ibm.com) | ||
| 7 | * | ||
| 8 | * This program is free software; you can redistribute it and/or modify | ||
| 9 | * it under the terms of the GNU General Public License (version 2 only) | ||
| 10 | * as published by the Free Software Foundation. | ||
| 11 | */ | ||
| 12 | #include <asm/vdso.h> | ||
| 13 | #include <asm/asm-offsets.h> | ||
| 14 | #include <asm/unistd.h> | ||
| 15 | |||
| 16 | .text | ||
| 17 | .align 4 | ||
| 18 | .globl __kernel_clock_gettime | ||
| 19 | .type __kernel_clock_gettime,@function | ||
| 20 | __kernel_clock_gettime: | ||
| 21 | .cfi_startproc | ||
| 22 | basr %r5,0 | ||
| 23 | 0: al %r5,21f-0b(%r5) /* get &_vdso_data */ | ||
| 24 | chi %r2,CLOCK_REALTIME | ||
| 25 | je 10f | ||
| 26 | chi %r2,CLOCK_MONOTONIC | ||
| 27 | jne 19f | ||
| 28 | |||
| 29 | /* CLOCK_MONOTONIC */ | ||
| 30 | ltr %r3,%r3 | ||
| 31 | jz 9f /* tp == NULL */ | ||
| 32 | 1: l %r4,__VDSO_UPD_COUNT+4(%r5) /* load update counter */ | ||
| 33 | tml %r4,0x0001 /* pending update ? loop */ | ||
| 34 | jnz 1b | ||
| 35 | stck 24(%r15) /* Store TOD clock */ | ||
| 36 | lm %r0,%r1,24(%r15) | ||
| 37 | s %r0,__VDSO_XTIME_STAMP(%r5) /* TOD - cycle_last */ | ||
| 38 | sl %r1,__VDSO_XTIME_STAMP+4(%r5) | ||
| 39 | brc 3,2f | ||
| 40 | ahi %r0,-1 | ||
| 41 | 2: mhi %r0,1000 /* cyc2ns(clock,cycle_delta) */ | ||
| 42 | lr %r2,%r0 | ||
| 43 | lhi %r0,1000 | ||
| 44 | ltr %r1,%r1 | ||
| 45 | mr %r0,%r0 | ||
| 46 | jnm 3f | ||
| 47 | ahi %r0,1000 | ||
| 48 | 3: alr %r0,%r2 | ||
| 49 | srdl %r0,12 | ||
| 50 | al %r0,__VDSO_XTIME_NSEC(%r5) /* + xtime */ | ||
| 51 | al %r1,__VDSO_XTIME_NSEC+4(%r5) | ||
| 52 | brc 12,4f | ||
| 53 | ahi %r0,1 | ||
| 54 | 4: l %r2,__VDSO_XTIME_SEC+4(%r5) | ||
| 55 | al %r0,__VDSO_WTOM_NSEC(%r5) /* + wall_to_monotonic */ | ||
| 56 | al %r1,__VDSO_WTOM_NSEC+4(%r5) | ||
| 57 | brc 12,5f | ||
| 58 | ahi %r0,1 | ||
| 59 | 5: al %r2,__VDSO_WTOM_SEC+4(%r5) | ||
| 60 | cl %r4,__VDSO_UPD_COUNT+4(%r5) /* check update counter */ | ||
| 61 | jne 1b | ||
| 62 | basr %r5,0 | ||
| 63 | 6: ltr %r0,%r0 | ||
| 64 | jnz 7f | ||
| 65 | cl %r1,20f-6b(%r5) | ||
| 66 | jl 8f | ||
| 67 | 7: ahi %r2,1 | ||
| 68 | sl %r1,20f-6b(%r5) | ||
| 69 | brc 3,6b | ||
| 70 | ahi %r0,-1 | ||
| 71 | j 6b | ||
| 72 | 8: st %r2,0(%r3) /* store tp->tv_sec */ | ||
| 73 | st %r1,4(%r3) /* store tp->tv_nsec */ | ||
| 74 | 9: lhi %r2,0 | ||
| 75 | br %r14 | ||
| 76 | |||
| 77 | /* CLOCK_REALTIME */ | ||
| 78 | 10: ltr %r3,%r3 /* tp == NULL */ | ||
| 79 | jz 18f | ||
| 80 | 11: l %r4,__VDSO_UPD_COUNT+4(%r5) /* load update counter */ | ||
| 81 | tml %r4,0x0001 /* pending update ? loop */ | ||
| 82 | jnz 11b | ||
| 83 | stck 24(%r15) /* Store TOD clock */ | ||
| 84 | lm %r0,%r1,24(%r15) | ||
| 85 | s %r0,__VDSO_XTIME_STAMP(%r5) /* TOD - cycle_last */ | ||
| 86 | sl %r1,__VDSO_XTIME_STAMP+4(%r5) | ||
| 87 | brc 3,12f | ||
| 88 | ahi %r0,-1 | ||
| 89 | 12: mhi %r0,1000 /* cyc2ns(clock,cycle_delta) */ | ||
| 90 | lr %r2,%r0 | ||
| 91 | lhi %r0,1000 | ||
| 92 | ltr %r1,%r1 | ||
| 93 | mr %r0,%r0 | ||
| 94 | jnm 13f | ||
| 95 | ahi %r0,1000 | ||
| 96 | 13: alr %r0,%r2 | ||
| 97 | srdl %r0,12 | ||
| 98 | al %r0,__VDSO_XTIME_NSEC(%r5) /* + xtime */ | ||
| 99 | al %r1,__VDSO_XTIME_NSEC+4(%r5) | ||
| 100 | brc 12,14f | ||
| 101 | ahi %r0,1 | ||
| 102 | 14: l %r2,__VDSO_XTIME_SEC+4(%r5) | ||
| 103 | cl %r4,__VDSO_UPD_COUNT+4(%r5) /* check update counter */ | ||
| 104 | jne 11b | ||
| 105 | basr %r5,0 | ||
| 106 | 15: ltr %r0,%r0 | ||
| 107 | jnz 16f | ||
| 108 | cl %r1,20f-15b(%r5) | ||
| 109 | jl 17f | ||
| 110 | 16: ahi %r2,1 | ||
| 111 | sl %r1,20f-15b(%r5) | ||
| 112 | brc 3,15b | ||
| 113 | ahi %r0,-1 | ||
| 114 | j 15b | ||
| 115 | 17: st %r2,0(%r3) /* store tp->tv_sec */ | ||
| 116 | st %r1,4(%r3) /* store tp->tv_nsec */ | ||
| 117 | 18: lhi %r2,0 | ||
| 118 | br %r14 | ||
| 119 | |||
| 120 | /* Fallback to system call */ | ||
| 121 | 19: lhi %r1,__NR_clock_gettime | ||
| 122 | svc 0 | ||
| 123 | br %r14 | ||
| 124 | |||
| 125 | 20: .long 1000000000 | ||
| 126 | 21: .long _vdso_data - 0b | ||
| 127 | .cfi_endproc | ||
| 128 | .size __kernel_clock_gettime,.-__kernel_clock_gettime | ||
diff --git a/arch/s390/kernel/vdso32/gettimeofday.S b/arch/s390/kernel/vdso32/gettimeofday.S new file mode 100644 index 000000000000..c32f29c3d70c --- /dev/null +++ b/arch/s390/kernel/vdso32/gettimeofday.S | |||
| @@ -0,0 +1,82 @@ | |||
| 1 | /* | ||
| 2 | * Userland implementation of gettimeofday() for 32 bits processes in a | ||
| 3 | * s390 kernel for use in the vDSO | ||
| 4 | * | ||
| 5 | * Copyright IBM Corp. 2008 | ||
| 6 | * Author(s): Martin Schwidefsky (schwidefsky@de.ibm.com) | ||
| 7 | * | ||
| 8 | * This program is free software; you can redistribute it and/or modify | ||
| 9 | * it under the terms of the GNU General Public License (version 2 only) | ||
| 10 | * as published by the Free Software Foundation. | ||
| 11 | */ | ||
| 12 | #include <asm/vdso.h> | ||
| 13 | #include <asm/asm-offsets.h> | ||
| 14 | #include <asm/unistd.h> | ||
| 15 | |||
| 16 | #include <asm/vdso.h> | ||
| 17 | #include <asm/asm-offsets.h> | ||
| 18 | #include <asm/unistd.h> | ||
| 19 | |||
| 20 | .text | ||
| 21 | .align 4 | ||
| 22 | .globl __kernel_gettimeofday | ||
| 23 | .type __kernel_gettimeofday,@function | ||
| 24 | __kernel_gettimeofday: | ||
| 25 | .cfi_startproc | ||
| 26 | basr %r5,0 | ||
| 27 | 0: al %r5,13f-0b(%r5) /* get &_vdso_data */ | ||
| 28 | 1: ltr %r3,%r3 /* check if tz is NULL */ | ||
| 29 | je 2f | ||
| 30 | mvc 0(8,%r3),__VDSO_TIMEZONE(%r5) | ||
| 31 | 2: ltr %r2,%r2 /* check if tv is NULL */ | ||
| 32 | je 10f | ||
| 33 | l %r4,__VDSO_UPD_COUNT+4(%r5) /* load update counter */ | ||
| 34 | tml %r4,0x0001 /* pending update ? loop */ | ||
| 35 | jnz 1b | ||
| 36 | stck 24(%r15) /* Store TOD clock */ | ||
| 37 | lm %r0,%r1,24(%r15) | ||
| 38 | s %r0,__VDSO_XTIME_STAMP(%r5) /* TOD - cycle_last */ | ||
| 39 | sl %r1,__VDSO_XTIME_STAMP+4(%r5) | ||
| 40 | brc 3,3f | ||
| 41 | ahi %r0,-1 | ||
| 42 | 3: mhi %r0,1000 /* cyc2ns(clock,cycle_delta) */ | ||
| 43 | st %r0,24(%r15) | ||
| 44 | lhi %r0,1000 | ||
| 45 | ltr %r1,%r1 | ||
| 46 | mr %r0,%r0 | ||
| 47 | jnm 4f | ||
| 48 | ahi %r0,1000 | ||
| 49 | 4: al %r0,24(%r15) | ||
| 50 | srdl %r0,12 | ||
| 51 | al %r0,__VDSO_XTIME_NSEC(%r5) /* + xtime */ | ||
| 52 | al %r1,__VDSO_XTIME_NSEC+4(%r5) | ||
| 53 | brc 12,5f | ||
| 54 | ahi %r0,1 | ||
| 55 | 5: mvc 24(4,%r15),__VDSO_XTIME_SEC+4(%r5) | ||
| 56 | cl %r4,__VDSO_UPD_COUNT+4(%r5) /* check update counter */ | ||
| 57 | jne 1b | ||
| 58 | l %r4,24(%r15) /* get tv_sec from stack */ | ||
| 59 | basr %r5,0 | ||
| 60 | 6: ltr %r0,%r0 | ||
| 61 | jnz 7f | ||
| 62 | cl %r1,11f-6b(%r5) | ||
| 63 | jl 8f | ||
| 64 | 7: ahi %r4,1 | ||
| 65 | sl %r1,11f-6b(%r5) | ||
| 66 | brc 3,6b | ||
| 67 | ahi %r0,-1 | ||
| 68 | j 6b | ||
| 69 | 8: st %r4,0(%r2) /* store tv->tv_sec */ | ||
| 70 | ltr %r1,%r1 | ||
| 71 | m %r0,12f-6b(%r5) | ||
| 72 | jnm 9f | ||
| 73 | al %r0,12f-6b(%r5) | ||
| 74 | 9: srl %r0,6 | ||
| 75 | st %r0,4(%r2) /* store tv->tv_usec */ | ||
| 76 | 10: slr %r2,%r2 | ||
| 77 | br %r14 | ||
| 78 | 11: .long 1000000000 | ||
| 79 | 12: .long 274877907 | ||
| 80 | 13: .long _vdso_data - 0b | ||
| 81 | .cfi_endproc | ||
| 82 | .size __kernel_gettimeofday,.-__kernel_gettimeofday | ||
diff --git a/arch/s390/kernel/vdso32/note.S b/arch/s390/kernel/vdso32/note.S new file mode 100644 index 000000000000..79a071e4357e --- /dev/null +++ b/arch/s390/kernel/vdso32/note.S | |||
| @@ -0,0 +1,12 @@ | |||
| 1 | /* | ||
| 2 | * This supplies .note.* sections to go into the PT_NOTE inside the vDSO text. | ||
| 3 | * Here we can supply some information useful to userland. | ||
| 4 | */ | ||
| 5 | |||
| 6 | #include <linux/uts.h> | ||
| 7 | #include <linux/version.h> | ||
| 8 | #include <linux/elfnote.h> | ||
| 9 | |||
| 10 | ELFNOTE_START(Linux, 0, "a") | ||
| 11 | .long LINUX_VERSION_CODE | ||
| 12 | ELFNOTE_END | ||
diff --git a/arch/s390/kernel/vdso32/vdso32.lds.S b/arch/s390/kernel/vdso32/vdso32.lds.S new file mode 100644 index 000000000000..a8c379fa1247 --- /dev/null +++ b/arch/s390/kernel/vdso32/vdso32.lds.S | |||
| @@ -0,0 +1,138 @@ | |||
| 1 | /* | ||
| 2 | * This is the infamous ld script for the 32 bits vdso | ||
| 3 | * library | ||
| 4 | */ | ||
| 5 | #include <asm/vdso.h> | ||
| 6 | |||
| 7 | OUTPUT_FORMAT("elf32-s390", "elf32-s390", "elf32-s390") | ||
| 8 | OUTPUT_ARCH(s390:31-bit) | ||
| 9 | ENTRY(_start) | ||
| 10 | |||
| 11 | SECTIONS | ||
| 12 | { | ||
| 13 | . = VDSO32_LBASE + SIZEOF_HEADERS; | ||
| 14 | |||
| 15 | .hash : { *(.hash) } :text | ||
| 16 | .gnu.hash : { *(.gnu.hash) } | ||
| 17 | .dynsym : { *(.dynsym) } | ||
| 18 | .dynstr : { *(.dynstr) } | ||
| 19 | .gnu.version : { *(.gnu.version) } | ||
| 20 | .gnu.version_d : { *(.gnu.version_d) } | ||
| 21 | .gnu.version_r : { *(.gnu.version_r) } | ||
| 22 | |||
| 23 | .note : { *(.note.*) } :text :note | ||
| 24 | |||
| 25 | . = ALIGN(16); | ||
| 26 | .text : { | ||
| 27 | *(.text .stub .text.* .gnu.linkonce.t.*) | ||
| 28 | } :text | ||
| 29 | PROVIDE(__etext = .); | ||
| 30 | PROVIDE(_etext = .); | ||
| 31 | PROVIDE(etext = .); | ||
| 32 | |||
| 33 | /* | ||
| 34 | * Other stuff is appended to the text segment: | ||
| 35 | */ | ||
| 36 | .rodata : { *(.rodata .rodata.* .gnu.linkonce.r.*) } | ||
| 37 | .rodata1 : { *(.rodata1) } | ||
| 38 | |||
| 39 | .dynamic : { *(.dynamic) } :text :dynamic | ||
| 40 | |||
| 41 | .eh_frame_hdr : { *(.eh_frame_hdr) } :text :eh_frame_hdr | ||
| 42 | .eh_frame : { KEEP (*(.eh_frame)) } :text | ||
| 43 | .gcc_except_table : { *(.gcc_except_table .gcc_except_table.*) } | ||
| 44 | |||
| 45 | .rela.dyn ALIGN(8) : { *(.rela.dyn) } | ||
| 46 | .got ALIGN(8) : { *(.got .toc) } | ||
| 47 | |||
| 48 | _end = .; | ||
| 49 | PROVIDE(end = .); | ||
| 50 | |||
| 51 | /* | ||
| 52 | * Stabs debugging sections are here too. | ||
| 53 | */ | ||
| 54 | .stab 0 : { *(.stab) } | ||
| 55 | .stabstr 0 : { *(.stabstr) } | ||
| 56 | .stab.excl 0 : { *(.stab.excl) } | ||
| 57 | .stab.exclstr 0 : { *(.stab.exclstr) } | ||
| 58 | .stab.index 0 : { *(.stab.index) } | ||
| 59 | .stab.indexstr 0 : { *(.stab.indexstr) } | ||
| 60 | .comment 0 : { *(.comment) } | ||
| 61 | |||
| 62 | /* | ||
| 63 | * DWARF debug sections. | ||
| 64 | * Symbols in the DWARF debugging sections are relative to the | ||
| 65 | * beginning of the section so we begin them at 0. | ||
| 66 | */ | ||
| 67 | /* DWARF 1 */ | ||
| 68 | .debug 0 : { *(.debug) } | ||
| 69 | .line 0 : { *(.line) } | ||
| 70 | /* GNU DWARF 1 extensions */ | ||
| 71 | .debug_srcinfo 0 : { *(.debug_srcinfo) } | ||
| 72 | .debug_sfnames 0 : { *(.debug_sfnames) } | ||
| 73 | /* DWARF 1.1 and DWARF 2 */ | ||
| 74 | .debug_aranges 0 : { *(.debug_aranges) } | ||
| 75 | .debug_pubnames 0 : { *(.debug_pubnames) } | ||
| 76 | /* DWARF 2 */ | ||
| 77 | .debug_info 0 : { *(.debug_info .gnu.linkonce.wi.*) } | ||
| 78 | .debug_abbrev 0 : { *(.debug_abbrev) } | ||
| 79 | .debug_line 0 : { *(.debug_line) } | ||
| 80 | .debug_frame 0 : { *(.debug_frame) } | ||
| 81 | .debug_str 0 : { *(.debug_str) } | ||
| 82 | .debug_loc 0 : { *(.debug_loc) } | ||
| 83 | .debug_macinfo 0 : { *(.debug_macinfo) } | ||
| 84 | /* SGI/MIPS DWARF 2 extensions */ | ||
| 85 | .debug_weaknames 0 : { *(.debug_weaknames) } | ||
| 86 | .debug_funcnames 0 : { *(.debug_funcnames) } | ||
| 87 | .debug_typenames 0 : { *(.debug_typenames) } | ||
| 88 | .debug_varnames 0 : { *(.debug_varnames) } | ||
| 89 | /* DWARF 3 */ | ||
| 90 | .debug_pubtypes 0 : { *(.debug_pubtypes) } | ||
| 91 | .debug_ranges 0 : { *(.debug_ranges) } | ||
| 92 | .gnu.attributes 0 : { KEEP (*(.gnu.attributes)) } | ||
| 93 | |||
| 94 | . = ALIGN(4096); | ||
| 95 | PROVIDE(_vdso_data = .); | ||
| 96 | |||
| 97 | /DISCARD/ : { | ||
| 98 | *(.note.GNU-stack) | ||
| 99 | *(.branch_lt) | ||
| 100 | *(.data .data.* .gnu.linkonce.d.* .sdata*) | ||
| 101 | *(.bss .sbss .dynbss .dynsbss) | ||
| 102 | } | ||
| 103 | } | ||
| 104 | |||
| 105 | /* | ||
| 106 | * Very old versions of ld do not recognize this name token; use the constant. | ||
| 107 | */ | ||
| 108 | #define PT_GNU_EH_FRAME 0x6474e550 | ||
| 109 | |||
| 110 | /* | ||
| 111 | * We must supply the ELF program headers explicitly to get just one | ||
| 112 | * PT_LOAD segment, and set the flags explicitly to make segments read-only. | ||
| 113 | */ | ||
| 114 | PHDRS | ||
| 115 | { | ||
| 116 | text PT_LOAD FILEHDR PHDRS FLAGS(5); /* PF_R|PF_X */ | ||
| 117 | dynamic PT_DYNAMIC FLAGS(4); /* PF_R */ | ||
| 118 | note PT_NOTE FLAGS(4); /* PF_R */ | ||
| 119 | eh_frame_hdr PT_GNU_EH_FRAME; | ||
| 120 | } | ||
| 121 | |||
| 122 | /* | ||
| 123 | * This controls what symbols we export from the DSO. | ||
| 124 | */ | ||
| 125 | VERSION | ||
| 126 | { | ||
| 127 | VDSO_VERSION_STRING { | ||
| 128 | global: | ||
| 129 | /* | ||
| 130 | * Has to be there for the kernel to find | ||
| 131 | */ | ||
| 132 | __kernel_gettimeofday; | ||
| 133 | __kernel_clock_gettime; | ||
| 134 | __kernel_clock_getres; | ||
| 135 | |||
| 136 | local: *; | ||
| 137 | }; | ||
| 138 | } | ||
diff --git a/arch/s390/kernel/vdso32/vdso32_wrapper.S b/arch/s390/kernel/vdso32/vdso32_wrapper.S new file mode 100644 index 000000000000..61639a89e70b --- /dev/null +++ b/arch/s390/kernel/vdso32/vdso32_wrapper.S | |||
| @@ -0,0 +1,13 @@ | |||
| 1 | #include <linux/init.h> | ||
| 2 | #include <asm/page.h> | ||
| 3 | |||
| 4 | .section ".data.page_aligned" | ||
| 5 | |||
| 6 | .globl vdso32_start, vdso32_end | ||
| 7 | .balign PAGE_SIZE | ||
| 8 | vdso32_start: | ||
| 9 | .incbin "arch/s390/kernel/vdso32/vdso32.so" | ||
| 10 | .balign PAGE_SIZE | ||
| 11 | vdso32_end: | ||
| 12 | |||
| 13 | .previous | ||
