1
2 #include <asm/vdso.h>
3
4
5
6
7
8
9
10 SECTIONS
11 {
12
13
14
15
16
17
18
19 vvar_start = . - 3 * PAGE_SIZE;
20 vvar_page = vvar_start;
21
22
23 #define EMIT_VVAR(name, offset) vvar_ ## name = vvar_page + offset;
24 #define __VVAR_KERNEL_LDS
25 #include <asm/vvar.h>
26 #undef __VVAR_KERNEL_LDS
27 #undef EMIT_VVAR
28
29 pvclock_page = vvar_start + PAGE_SIZE;
30 hvclock_page = vvar_start + 2 * PAGE_SIZE;
31
32 . = SIZEOF_HEADERS;
33
34 .hash : { *(.hash) } :text
35 .gnu.hash : { *(.gnu.hash) }
36 .dynsym : { *(.dynsym) }
37 .dynstr : { *(.dynstr) }
38 .gnu.version : { *(.gnu.version) }
39 .gnu.version_d : { *(.gnu.version_d) }
40 .gnu.version_r : { *(.gnu.version_r) }
41
42 .dynamic : { *(.dynamic) } :text :dynamic
43
44 .rodata : {
45 *(.rodata*)
46 *(.data*)
47 *(.sdata*)
48 *(.got.plt) *(.got)
49 *(.gnu.linkonce.d.*)
50 *(.bss*)
51 *(.dynbss*)
52 *(.gnu.linkonce.b.*)
53 } :text
54
55 .note : { *(.note.*) } :text :note
56
57 .eh_frame_hdr : { *(.eh_frame_hdr) } :text :eh_frame_hdr
58 .eh_frame : { KEEP (*(.eh_frame)) } :text
59
60
61
62
63
64
65
66 .text : { *(.text*) } :text =0x90909090,
67
68 .altinstructions : { *(.altinstructions) } :text
69 .altinstr_replacement : { *(.altinstr_replacement) } :text
70
71 /DISCARD/ : {
72 *(.discard)
73 *(.discard.*)
74 *(__bug_table)
75 }
76 }
77
78
79
80
81 #define PT_GNU_EH_FRAME 0x6474e550
82
83
84
85
86
87 PHDRS
88 {
89 text PT_LOAD FLAGS(5) FILEHDR PHDRS;
90 dynamic PT_DYNAMIC FLAGS(4);
91 note PT_NOTE FLAGS(4);
92 eh_frame_hdr PT_GNU_EH_FRAME;
93 }