1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- /* ld script to make M32R Linux kernel
- */
- #include <asm-generic/vmlinux.lds.h>
- #include <asm/addrspace.h>
- #include <asm/page.h>
- #include <asm/thread_info.h>
- OUTPUT_ARCH(m32r)
- #if defined(__LITTLE_ENDIAN__)
- jiffies = jiffies_64;
- #else
- jiffies = jiffies_64 + 4;
- #endif
- kernel_entry = boot - 0x80000000;
- ENTRY(kernel_entry)
- SECTIONS
- {
- . = CONFIG_MEMORY_START + __PAGE_OFFSET;
- eit_vector = .;
- . = . + 0x1000;
- .empty_zero_page : { *(.empty_zero_page) } = 0
- /* read-only */
- _text = .; /* Text and read-only data */
- .boot : { *(.boot) } = 0
- .text : {
- HEAD_TEXT
- TEXT_TEXT
- SCHED_TEXT
- LOCK_TEXT
- *(.fixup)
- *(.gnu.warning)
- } = 0x9090
- #ifdef CONFIG_SMP
- . = ALIGN(65536);
- .eit_vector4 : { *(.eit_vector4) }
- #endif
- _etext = .; /* End of text section */
- EXCEPTION_TABLE(16)
- NOTES
- _sdata = .; /* Start of data section */
- RODATA
- RW_DATA_SECTION(32, PAGE_SIZE, THREAD_SIZE)
- _edata = .; /* End of data section */
- /* will be freed after init */
- . = ALIGN(PAGE_SIZE); /* Init code and data */
- __init_begin = .;
- INIT_TEXT_SECTION(PAGE_SIZE)
- INIT_DATA_SECTION(16)
- PERCPU_SECTION(32)
- . = ALIGN(PAGE_SIZE);
- __init_end = .;
- /* freed after init ends here */
- BSS_SECTION(0, 0, 4)
- _end = . ;
- /* Stabs debugging sections. */
- .stab 0 : { *(.stab) }
- .stabstr 0 : { *(.stabstr) }
- .stab.excl 0 : { *(.stab.excl) }
- .stab.exclstr 0 : { *(.stab.exclstr) }
- .stab.index 0 : { *(.stab.index) }
- .stab.indexstr 0 : { *(.stab.indexstr) }
- .comment 0 : { *(.comment) }
- /* Sections to be discarded */
- DISCARDS
- }
|