123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- #include <asm-generic/vmlinux.lds.h>
- #include <asm/thread_info.h>
- #include <asm/cache.h>
- #include <asm/page.h>
- #include <asm/setup.h>
- OUTPUT_FORMAT("elf64-alpha")
- OUTPUT_ARCH(alpha)
- ENTRY(__start)
- PHDRS { kernel PT_LOAD; note PT_NOTE; }
- jiffies = jiffies_64;
- SECTIONS
- {
- #ifdef CONFIG_ALPHA_LEGACY_START_ADDRESS
- . = 0xfffffc0000310000;
- #else
- . = 0xfffffc0001010000;
- #endif
- _text = .; /* Text and read-only data */
- .text : {
- HEAD_TEXT
- TEXT_TEXT
- SCHED_TEXT
- LOCK_TEXT
- *(.fixup)
- *(.gnu.warning)
- } :kernel
- swapper_pg_dir = SWAPPER_PGD;
- _etext = .; /* End of text section */
- NOTES :kernel :note
- .dummy : {
- *(.dummy)
- } :kernel
- RODATA
- EXCEPTION_TABLE(16)
- /* Will be freed after init */
- __init_begin = ALIGN(PAGE_SIZE);
- INIT_TEXT_SECTION(PAGE_SIZE)
- INIT_DATA_SECTION(16)
- PERCPU_SECTION(L1_CACHE_BYTES)
- /* Align to THREAD_SIZE rather than PAGE_SIZE here so any padding page
- needed for the THREAD_SIZE aligned init_task gets freed after init */
- . = ALIGN(THREAD_SIZE);
- __init_end = .;
- /* Freed after init ends here */
- _sdata = .; /* Start of rw data section */
- _data = .;
- RW_DATA_SECTION(L1_CACHE_BYTES, PAGE_SIZE, THREAD_SIZE)
- .got : {
- *(.got)
- }
- .sdata : {
- *(.sdata)
- }
- _edata = .; /* End of data section */
- BSS_SECTION(0, 0, 0)
- _end = .;
- .mdebug 0 : {
- *(.mdebug)
- }
- .note 0 : {
- *(.note)
- }
- STABS_DEBUG
- DWARF_DEBUG
- DISCARDS
- }
|