Make vmlinux.lds almost readable.
When going through the file fixed the following:
- Use PAGE_SIZE as replacement for hardcoded 4096
- Moves label definitions inside {} to avoid ld alignment
  that may be added between label and section

Signed-off-by: Sam Ravnborg <sam@ravnborg.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Sam Ravnborg 2007-09-17 19:02:30 -07:00 коммит произвёл David S. Miller
Родитель 9bb3c227c4
Коммит bcbe40ebdd
1 изменённых файлов: 93 добавлений и 72 удалений

Просмотреть файл

@ -1,6 +1,7 @@
/* ld script to make SparcLinux kernel */ /* ld script to make SparcLinux kernel */
#include <asm-generic/vmlinux.lds.h> #include <asm-generic/vmlinux.lds.h>
#include <asm/page.h>
OUTPUT_FORMAT("elf32-sparc", "elf32-sparc", "elf32-sparc") OUTPUT_FORMAT("elf32-sparc", "elf32-sparc", "elf32-sparc")
OUTPUT_ARCH(sparc) OUTPUT_ARCH(sparc)
@ -20,72 +21,92 @@ SECTIONS
_etext = .; _etext = .;
PROVIDE (etext = .); PROVIDE (etext = .);
RODATA RODATA
.data : .data : {
{
DATA_DATA DATA_DATA
CONSTRUCTORS CONSTRUCTORS
} }
.data1 : { *(.data1) } .data1 : {
*(.data1)
}
_edata = .; _edata = .;
PROVIDE (edata = .); PROVIDE (edata = .);
.fixup : {
__start___fixup = .; __start___fixup = .;
.fixup : { *(.fixup) } *(.fixup)
__stop___fixup = .; __stop___fixup = .;
}
__ex_table : {
__start___ex_table = .; __start___ex_table = .;
__ex_table : { *(__ex_table) } *(__ex_table)
__stop___ex_table = .; __stop___ex_table = .;
}
NOTES NOTES
. = ALIGN(4096); . = ALIGN(PAGE_SIZE);
__init_begin = .; __init_begin = .;
_sinittext = .;
.init.text : { .init.text : {
_sinittext = .;
*(.init.text) *(.init.text)
}
_einittext = .; _einittext = .;
__init_text_end = .;
.init.data : { *(.init.data) }
. = ALIGN(16);
__setup_start = .;
.init.setup : { *(.init.setup) }
__setup_end = .;
__initcall_start = .;
.initcall.init : {
INITCALLS
} }
__init_text_end = .;
.init.data : {
*(.init.data)
}
. = ALIGN(16);
.init.setup : {
__setup_start = .;
*(.init.setup)
__setup_end = .;
}
.initcall.init : {
__initcall_start = .;
INITCALLS
__initcall_end = .; __initcall_end = .;
}
.con_initcall.init : {
__con_initcall_start = .; __con_initcall_start = .;
.con_initcall.init : { *(.con_initcall.init) } *(.con_initcall.init)
__con_initcall_end = .; __con_initcall_end = .;
}
SECURITY_INIT SECURITY_INIT
#ifdef CONFIG_BLK_DEV_INITRD #ifdef CONFIG_BLK_DEV_INITRD
. = ALIGN(4096); . = ALIGN(PAGE_SIZE);
.init.ramfs : {
__initramfs_start = .; __initramfs_start = .;
.init.ramfs : { *(.init.ramfs) } *(.init.ramfs)
__initramfs_end = .; __initramfs_end = .;
}
#endif #endif
PERCPU(4096) PERCPU(PAGE_SIZE)
. = ALIGN(4096); . = ALIGN(PAGE_SIZE);
__init_end = .; __init_end = .;
. = ALIGN(32); . = ALIGN(32);
.data.cacheline_aligned : { *(.data.cacheline_aligned) } .data.cacheline_aligned : {
*(.data.cacheline_aligned)
}
__bss_start = .; __bss_start = .;
.sbss : { *(.sbss) *(.scommon) } .sbss : {
.bss : *(.sbss)
{ *(.scommon) }
.bss : {
*(.dynbss) *(.dynbss)
*(.bss) *(.bss)
*(COMMON) *(COMMON)
} }
_end = . ; _end = . ;
PROVIDE (end = .); PROVIDE (end = .);
/DISCARD/ : { *(.exit.text) *(.exit.data) *(.exitcall.exit) } /DISCARD/ : {
*(.exit.text)
*(.exit.data)
*(.exitcall.exit)
}
STABS_DEBUG STABS_DEBUG
DWARF_DEBUG DWARF_DEBUG
} }