diff options
author | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2005-11-11 05:15:21 -0500 |
---|---|---|
committer | Paul Mackerras <paulus@samba.org> | 2005-11-11 06:25:39 -0500 |
commit | a7f290dad32ee34d931561b7943c858fe2aae503 (patch) | |
tree | 850f04ed9ffba8aef6e151fa9c9e8a0c667bb795 /arch/powerpc/kernel/vdso32/vdso32.lds.S | |
parent | 6761c4a07378e19e3710bb69cea65795774529b1 (diff) |
[PATCH] powerpc: Merge vdso's and add vdso support to 32 bits kernel
This patch moves the vdso's to arch/powerpc, adds support for the 32
bits vdso to the 32 bits kernel, rename systemcfg (finally !), and adds
some new (still untested) routines to both vdso's: clock_gettime() with
support for CLOCK_REALTIME and CLOCK_MONOTONIC, clock_getres() (same
clocks) and get_tbfreq() for glibc to retreive the timebase frequency.
Tom,Steve: The implementation of get_tbfreq() I've done for 32 bits
returns a long long (r3, r4) not a long. This is such that if we ever
add support for >4Ghz timebases on ppc32, the userland interface won't
have to change.
I have tested gettimeofday() using some glibc patches in both ppc32 and
ppc64 kernels using 32 bits userland (I haven't had a chance to test a
64 bits userland yet, but the implementation didn't change and was
tested earlier). I haven't tested yet the new functions.
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Signed-off-by: Paul Mackerras <paulus@samba.org>
Diffstat (limited to 'arch/powerpc/kernel/vdso32/vdso32.lds.S')
-rw-r--r-- | arch/powerpc/kernel/vdso32/vdso32.lds.S | 117 |
1 files changed, 117 insertions, 0 deletions
diff --git a/arch/powerpc/kernel/vdso32/vdso32.lds.S b/arch/powerpc/kernel/vdso32/vdso32.lds.S new file mode 100644 index 000000000000..f4bad720cb0a --- /dev/null +++ b/arch/powerpc/kernel/vdso32/vdso32.lds.S | |||
@@ -0,0 +1,117 @@ | |||
1 | |||
2 | /* | ||
3 | * This is the infamous ld script for the 32 bits vdso | ||
4 | * library | ||
5 | */ | ||
6 | #include <asm/vdso.h> | ||
7 | |||
8 | /* Default link addresses for the vDSOs */ | ||
9 | OUTPUT_FORMAT("elf32-powerpc", "elf32-powerpc", "elf32-powerpc") | ||
10 | OUTPUT_ARCH(powerpc:common) | ||
11 | ENTRY(_start) | ||
12 | |||
13 | SECTIONS | ||
14 | { | ||
15 | . = VDSO32_LBASE + SIZEOF_HEADERS; | ||
16 | .hash : { *(.hash) } :text | ||
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 | { | ||
28 | *(.text .stub .text.* .gnu.linkonce.t.*) | ||
29 | } | ||
30 | PROVIDE (__etext = .); | ||
31 | PROVIDE (_etext = .); | ||
32 | PROVIDE (etext = .); | ||
33 | |||
34 | /* Other stuff is appended to the text segment: */ | ||
35 | .rodata : { *(.rodata .rodata.* .gnu.linkonce.r.*) } | ||
36 | .rodata1 : { *(.rodata1) } | ||
37 | |||
38 | .eh_frame_hdr : { *(.eh_frame_hdr) } :text :eh_frame_hdr | ||
39 | .eh_frame : { KEEP (*(.eh_frame)) } :text | ||
40 | .gcc_except_table : { *(.gcc_except_table) } | ||
41 | .fixup : { *(.fixup) } | ||
42 | |||
43 | .dynamic : { *(.dynamic) } :text :dynamic | ||
44 | .got : { *(.got) } | ||
45 | .plt : { *(.plt) } | ||
46 | |||
47 | _end = .; | ||
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 | .debug 0 : { *(.debug) } | ||
62 | .line 0 : { *(.line) } | ||
63 | |||
64 | .debug_srcinfo 0 : { *(.debug_srcinfo) } | ||
65 | .debug_sfnames 0 : { *(.debug_sfnames) } | ||
66 | |||
67 | .debug_aranges 0 : { *(.debug_aranges) } | ||
68 | .debug_pubnames 0 : { *(.debug_pubnames) } | ||
69 | |||
70 | .debug_info 0 : { *(.debug_info .gnu.linkonce.wi.*) } | ||
71 | .debug_abbrev 0 : { *(.debug_abbrev) } | ||
72 | .debug_line 0 : { *(.debug_line) } | ||
73 | .debug_frame 0 : { *(.debug_frame) } | ||
74 | .debug_str 0 : { *(.debug_str) } | ||
75 | .debug_loc 0 : { *(.debug_loc) } | ||
76 | .debug_macinfo 0 : { *(.debug_macinfo) } | ||
77 | |||
78 | .debug_weaknames 0 : { *(.debug_weaknames) } | ||
79 | .debug_funcnames 0 : { *(.debug_funcnames) } | ||
80 | .debug_typenames 0 : { *(.debug_typenames) } | ||
81 | .debug_varnames 0 : { *(.debug_varnames) } | ||
82 | |||
83 | /DISCARD/ : { *(.note.GNU-stack) } | ||
84 | /DISCARD/ : { *(.data .data.* .gnu.linkonce.d.* .sdata*) } | ||
85 | /DISCARD/ : { *(.bss .sbss .dynbss .dynsbss) } | ||
86 | } | ||
87 | |||
88 | |||
89 | PHDRS | ||
90 | { | ||
91 | text PT_LOAD FILEHDR PHDRS FLAGS(5); /* PF_R|PF_X */ | ||
92 | note PT_NOTE FLAGS(4); /* PF_R */ | ||
93 | dynamic PT_DYNAMIC FLAGS(4); /* PF_R */ | ||
94 | eh_frame_hdr 0x6474e550; /* PT_GNU_EH_FRAME, but ld doesn't match the name */ | ||
95 | } | ||
96 | |||
97 | |||
98 | /* | ||
99 | * This controls what symbols we export from the DSO. | ||
100 | */ | ||
101 | VERSION | ||
102 | { | ||
103 | VDSO_VERSION_STRING { | ||
104 | global: | ||
105 | __kernel_datapage_offset; /* Has to be there for the kernel to find */ | ||
106 | __kernel_get_syscall_map; | ||
107 | __kernel_gettimeofday; | ||
108 | __kernel_clock_gettime; | ||
109 | __kernel_clock_getres; | ||
110 | __kernel_get_tbfreq; | ||
111 | __kernel_sync_dicache; | ||
112 | __kernel_sync_dicache_p5; | ||
113 | __kernel_sigtramp32; | ||
114 | __kernel_sigtramp_rt32; | ||
115 | local: *; | ||
116 | }; | ||
117 | } | ||