Blame view

arch/sh/kernel/vsyscall/vsyscall.lds.S 2.08 KB
19f9a34f8   Paul Mundt   sh: Initial vsysc...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
  /*
   * Linker script for vsyscall DSO.  The vsyscall page is an ELF shared
   * object prelinked to its virtual address, and with only one read-only
   * segment (that fits in one page).  This script controls its layout.
   */
  #include <asm/asm-offsets.h>
  
  #ifdef CONFIG_CPU_LITTLE_ENDIAN
  OUTPUT_FORMAT("elf32-sh-linux", "elf32-sh-linux", "elf32-sh-linux")
  #else
  OUTPUT_FORMAT("elf32-shbig-linux", "elf32-shbig-linux", "elf32-shbig-linux")
  #endif
  OUTPUT_ARCH(sh)
  
  /* The ELF entry point can be used to set the AT_SYSINFO value.  */
  ENTRY(__kernel_vsyscall);
  
  SECTIONS
  {
c4eecc995   Roland McGrath   SH vDSO: linker s...
20
  	. = SIZEOF_HEADERS;
19f9a34f8   Paul Mundt   sh: Initial vsysc...
21

c4eecc995   Roland McGrath   SH vDSO: linker s...
22
23
24
25
26
27
28
  	.hash		: { *(.hash) }			:text
  	.gnu.hash	: { *(.gnu.hash) }
  	.dynsym		: { *(.dynsym) }
  	.dynstr		: { *(.dynstr) }
  	.gnu.version	: { *(.gnu.version) }
  	.gnu.version_d	: { *(.gnu.version_d) }
  	.gnu.version_r	: { *(.gnu.version_r) }
19f9a34f8   Paul Mundt   sh: Initial vsysc...
29

c4eecc995   Roland McGrath   SH vDSO: linker s...
30
31
32
33
34
35
36
  	/*
  	 * This linker script is used both with -r and with -shared.
  	 * For the layouts to match, we need to skip more than enough
  	 * space for the dynamic symbol table et al.  If this amount
  	 * is insufficient, ld -shared will barf.  Just increase it here.
  	 */
  	. = 0x400;
19f9a34f8   Paul Mundt   sh: Initial vsysc...
37

c4eecc995   Roland McGrath   SH vDSO: linker s...
38
39
40
  	.text		: { *(.text) } 			:text	=0x90909090
  	.note		: { *(.note.*) }		:text	:note
  	.eh_frame_hdr	: { *(.eh_frame_hdr ) }		:text	:eh_frame_hdr
f38c5a696   Kaz Kojima   sh: Terminate .eh...
41
42
43
44
  	.eh_frame	: {
  		KEEP (*(.eh_frame))
  		LONG (0)
  	}						:text
c4eecc995   Roland McGrath   SH vDSO: linker s...
45
46
47
48
49
50
51
  	.dynamic	: { *(.dynamic) }		:text	:dynamic
  	.useless	: {
  	      *(.got.plt) *(.got)
  	      *(.data .data.* .gnu.linkonce.d.*)
  	      *(.dynbss)
  	      *(.bss .bss.* .gnu.linkonce.b.*)
  	}						:text
19f9a34f8   Paul Mundt   sh: Initial vsysc...
52
53
54
  }
  
  /*
c4eecc995   Roland McGrath   SH vDSO: linker s...
55
56
57
58
59
   * Very old versions of ld do not recognize this name token; use the constant.
   */
  #define PT_GNU_EH_FRAME	0x6474e550
  
  /*
19f9a34f8   Paul Mundt   sh: Initial vsysc...
60
61
62
63
64
   * We must supply the ELF program headers explicitly to get just one
   * PT_LOAD segment, and set the flags explicitly to make segments read-only.
   */
  PHDRS
  {
c4eecc995   Roland McGrath   SH vDSO: linker s...
65
66
67
68
  	text		PT_LOAD FILEHDR PHDRS FLAGS(5);	/* PF_R|PF_X */
  	dynamic		PT_DYNAMIC FLAGS(4);		/* PF_R */
  	note		PT_NOTE FLAGS(4);		/* PF_R */
  	eh_frame_hdr	PT_GNU_EH_FRAME;
19f9a34f8   Paul Mundt   sh: Initial vsysc...
69
70
71
72
73
74
75
  }
  
  /*
   * This controls what symbols we export from the DSO.
   */
  VERSION
  {
c4eecc995   Roland McGrath   SH vDSO: linker s...
76
77
78
79
80
  	LINUX_2.6 {
  	global:
  		__kernel_vsyscall;
  		__kernel_sigreturn;
  		__kernel_rt_sigreturn;
19f9a34f8   Paul Mundt   sh: Initial vsysc...
81

c4eecc995   Roland McGrath   SH vDSO: linker s...
82
83
  	local: *;
  	};
19f9a34f8   Paul Mundt   sh: Initial vsysc...
84
  }