blob: 82803df17977d3656e067b0879f33444830e9f33 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#include <asm-generic/vmlinux.lds.h>
Sam Ravnborgb2b5d372007-10-16 01:26:35 -07002#include <asm/page.h>
Tim Abbottea12c2e2009-09-24 10:36:25 -04003#include <asm/thread_info.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -07004
5OUTPUT_FORMAT("elf64-alpha")
6OUTPUT_ARCH(alpha)
7ENTRY(__start)
Roland McGrathcaf45dd2007-07-19 01:48:37 -07008PHDRS { kernel PT_LOAD; note PT_NOTE; }
Linus Torvalds1da177e2005-04-16 15:20:36 -07009jiffies = jiffies_64;
10SECTIONS
11{
12#ifdef CONFIG_ALPHA_LEGACY_START_ADDRESS
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070013 . = 0xfffffc0000310000;
Linus Torvalds1da177e2005-04-16 15:20:36 -070014#else
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070015 . = 0xfffffc0001010000;
Linus Torvalds1da177e2005-04-16 15:20:36 -070016#endif
17
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070018 _text = .; /* Text and read-only data */
19 .text : {
Tim Abbott92ca5232009-04-25 22:10:58 -040020 HEAD_TEXT
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070021 TEXT_TEXT
22 SCHED_TEXT
23 LOCK_TEXT
24 *(.fixup)
25 *(.gnu.warning)
26 } :kernel
27 _etext = .; /* End of text section */
Linus Torvalds1da177e2005-04-16 15:20:36 -070028
Bastian Blank51597ac2008-07-04 10:00:00 -070029 NOTES :kernel :note
30 .dummy : {
31 *(.dummy)
32 } :kernel
33
34 RODATA
35
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070036 /* Exception table */
37 . = ALIGN(16);
38 __ex_table : {
39 __start___ex_table = .;
40 *(__ex_table)
41 __stop___ex_table = .;
42 }
Linus Torvalds1da177e2005-04-16 15:20:36 -070043
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070044 /* Will be freed after init */
45 . = ALIGN(PAGE_SIZE);
46 /* Init code and data */
47 __init_begin = .;
48 .init.text : {
49 _sinittext = .;
Sam Ravnborg01ba2bd2008-01-20 14:15:03 +010050 INIT_TEXT
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070051 _einittext = .;
52 }
53 .init.data : {
Sam Ravnborg01ba2bd2008-01-20 14:15:03 +010054 INIT_DATA
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070055 }
Linus Torvalds1da177e2005-04-16 15:20:36 -070056
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070057 . = ALIGN(16);
58 .init.setup : {
59 __setup_start = .;
60 *(.init.setup)
61 __setup_end = .;
62 }
Linus Torvalds1da177e2005-04-16 15:20:36 -070063
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070064 . = ALIGN(8);
65 .initcall.init : {
66 __initcall_start = .;
67 INITCALLS
68 __initcall_end = .;
69 }
Linus Torvalds1da177e2005-04-16 15:20:36 -070070
Jean-Paul Saman67d38222007-02-10 01:44:44 -080071#ifdef CONFIG_BLK_DEV_INITRD
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070072 . = ALIGN(PAGE_SIZE);
73 .init.ramfs : {
74 __initramfs_start = .;
75 *(.init.ramfs)
76 __initramfs_end = .;
77 }
Jean-Paul Saman67d38222007-02-10 01:44:44 -080078#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -070079
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070080 . = ALIGN(8);
81 .con_initcall.init : {
82 __con_initcall_start = .;
83 *(.con_initcall.init)
84 __con_initcall_end = .;
85 }
Linus Torvalds1da177e2005-04-16 15:20:36 -070086
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070087 . = ALIGN(8);
88 SECURITY_INIT
Linus Torvalds1da177e2005-04-16 15:20:36 -070089
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070090 PERCPU(PAGE_SIZE)
Linus Torvalds1da177e2005-04-16 15:20:36 -070091
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070092 . = ALIGN(2 * PAGE_SIZE);
93 __init_end = .;
94 /* Freed after init ends here */
Linus Torvalds1da177e2005-04-16 15:20:36 -070095
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070096 . = ALIGN(PAGE_SIZE);
97 .data.page_aligned : {
98 *(.data.page_aligned)
99 }
Linus Torvalds1da177e2005-04-16 15:20:36 -0700100
Sam Ravnborgb2b5d372007-10-16 01:26:35 -0700101 . = ALIGN(64);
102 .data.cacheline_aligned : {
103 *(.data.cacheline_aligned)
104 }
Linus Torvalds1da177e2005-04-16 15:20:36 -0700105
Sam Ravnborgb2b5d372007-10-16 01:26:35 -0700106 _data = .;
107 /* Data */
108 .data : {
Tim Abbottea12c2e2009-09-24 10:36:25 -0400109 INIT_TASK_DATA(THREAD_SIZE)
Sam Ravnborgb2b5d372007-10-16 01:26:35 -0700110 DATA_DATA
111 CONSTRUCTORS
112 }
Linus Torvalds1da177e2005-04-16 15:20:36 -0700113
Sam Ravnborgb2b5d372007-10-16 01:26:35 -0700114 .got : {
115 *(.got)
116 }
117 .sdata : {
118 *(.sdata)
119 }
120 _edata = .; /* End of data section */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700121
Sam Ravnborgb2b5d372007-10-16 01:26:35 -0700122 __bss_start = .;
123 .sbss : {
124 *(.sbss)
125 *(.scommon)
126 }
127 .bss : {
128 *(.bss)
129 *(COMMON)
130 }
131 __bss_stop = .;
132 _end = .;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700133
Sam Ravnborgb2b5d372007-10-16 01:26:35 -0700134 .mdebug 0 : {
135 *(.mdebug)
136 }
137 .note 0 : {
138 *(.note)
139 }
Linus Torvalds1da177e2005-04-16 15:20:36 -0700140
Sam Ravnborgb2b5d372007-10-16 01:26:35 -0700141 STABS_DEBUG
142 DWARF_DEBUG
Tejun Heo023bf6f2009-07-09 11:27:40 +0900143
144 DISCARDS
Linus Torvalds1da177e2005-04-16 15:20:36 -0700145}