blob: 647b84c15382347ec25efae55067e77fff26693e [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#include <asm-generic/vmlinux.lds.h>
Sam Ravnborgde078ef2009-09-25 19:53:43 +02002#include <asm/thread_info.h>
Tejun Heo0f06c062011-01-25 14:27:38 +01003#include <asm/cache.h>
Sam Ravnborgb2b5d372007-10-16 01:26:35 -07004#include <asm/page.h>
David Howellsec221202012-03-28 18:11:12 +01005#include <asm/setup.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -07006
7OUTPUT_FORMAT("elf64-alpha")
8OUTPUT_ARCH(alpha)
9ENTRY(__start)
Roland McGrathcaf45dd2007-07-19 01:48:37 -070010PHDRS { kernel PT_LOAD; note PT_NOTE; }
Linus Torvalds1da177e2005-04-16 15:20:36 -070011jiffies = jiffies_64;
12SECTIONS
13{
14#ifdef CONFIG_ALPHA_LEGACY_START_ADDRESS
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070015 . = 0xfffffc0000310000;
Linus Torvalds1da177e2005-04-16 15:20:36 -070016#else
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070017 . = 0xfffffc0001010000;
Linus Torvalds1da177e2005-04-16 15:20:36 -070018#endif
19
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070020 _text = .; /* Text and read-only data */
21 .text : {
Tim Abbott92ca5232009-04-25 22:10:58 -040022 HEAD_TEXT
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070023 TEXT_TEXT
24 SCHED_TEXT
25 LOCK_TEXT
26 *(.fixup)
27 *(.gnu.warning)
28 } :kernel
David Howellsec221202012-03-28 18:11:12 +010029 swapper_pg_dir = SWAPPER_PGD;
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070030 _etext = .; /* End of text section */
Linus Torvalds1da177e2005-04-16 15:20:36 -070031
Bastian Blank51597ac2008-07-04 10:00:00 -070032 NOTES :kernel :note
33 .dummy : {
34 *(.dummy)
35 } :kernel
36
37 RODATA
Geoffrey Thomas9d93f002009-09-24 10:36:26 -040038 EXCEPTION_TABLE(16)
Linus Torvalds1da177e2005-04-16 15:20:36 -070039
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070040 /* Will be freed after init */
Geoffrey Thomas9d93f002009-09-24 10:36:26 -040041 __init_begin = ALIGN(PAGE_SIZE);
42 INIT_TEXT_SECTION(PAGE_SIZE)
43 INIT_DATA_SECTION(16)
Tejun Heo0415b002011-03-24 18:50:09 +010044 PERCPU_SECTION(L1_CACHE_BYTES)
Geoffrey Thomas9d93f002009-09-24 10:36:26 -040045 /* Align to THREAD_SIZE rather than PAGE_SIZE here so any padding page
46 needed for the THREAD_SIZE aligned init_task gets freed after init */
47 . = ALIGN(THREAD_SIZE);
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070048 __init_end = .;
49 /* Freed after init ends here */
Linus Torvalds1da177e2005-04-16 15:20:36 -070050
Steven Rostedta2d063a2011-05-19 21:34:58 -040051 _sdata = .; /* Start of rw data section */
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070052 _data = .;
Tejun Heo0f06c062011-01-25 14:27:38 +010053 RW_DATA_SECTION(L1_CACHE_BYTES, PAGE_SIZE, THREAD_SIZE)
Linus Torvalds1da177e2005-04-16 15:20:36 -070054
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070055 .got : {
56 *(.got)
57 }
58 .sdata : {
59 *(.sdata)
60 }
61 _edata = .; /* End of data section */
Linus Torvalds1da177e2005-04-16 15:20:36 -070062
Geoffrey Thomas9d93f002009-09-24 10:36:26 -040063 BSS_SECTION(0, 0, 0)
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070064 _end = .;
Linus Torvalds1da177e2005-04-16 15:20:36 -070065
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070066 .mdebug 0 : {
67 *(.mdebug)
68 }
69 .note 0 : {
70 *(.note)
71 }
Linus Torvalds1da177e2005-04-16 15:20:36 -070072
Sam Ravnborgb2b5d372007-10-16 01:26:35 -070073 STABS_DEBUG
74 DWARF_DEBUG
Tejun Heo023bf6f2009-07-09 11:27:40 +090075
76 DISCARDS
Linus Torvalds1da177e2005-04-16 15:20:36 -070077}