. = 0x100000;
/* 这里是我们的高半核初始化代码段和数据段 */
- .boot.text BLOCK(4K) : {
+ .boot.text BLOCK(4K) :
+ {
*(.multiboot)
*(.boot.text)
}
- .boot.bss BLOCK(4K) : {
+ .boot.bss BLOCK(4K) :
+ {
*(.boot.bss)
}
- .boot.data BLOCK(4K) : {
+ .boot.data BLOCK(4K) :
+ {
*(.boot.data)
}
- .boot.rodata BLOCK(4K) : {
+ .boot.rodata BLOCK(4K) :
+ {
*(.boot.rodata)
}
- .boot.bss BLOCK(4K) : {
+ .boot.bss BLOCK(4K) :
+ {
*(.boot.rodata)
}
__kexec_boot_end = ALIGN(4K);
. += 0xC0000000;
/* 好了,我们的内核…… */
- .text BLOCK(4K) : AT ( ADDR(.text) - 0xC0000000 ) {
+
+ PROVIDE(__kexec_text_start = ALIGN(4K));
+
+ .text BLOCK(4K) : AT ( ADDR(.text) - 0xC0000000 )
+ {
__kexec_start = .;
- PROVIDE(__kexec_text_start = .);
*(.text)
+ }
+
+ .kf.preempt BLOCK(4K) : AT ( ADDR(.kf.preempt) - 0xC0000000 )
+ {
+ PROVIDE(__kf_preempt_start = .);
+
+ KEEP(*(.kf.preempt));
- PROVIDE(__kexec_text_end = .);
+ PROVIDE(__kf_preempt_end = .);
}
- .data BLOCK(4K) : AT ( ADDR(.data) - 0xC0000000 ) {
+ PROVIDE(__kexec_text_end = .);
+
+ .data BLOCK(4K) : AT ( ADDR(.data) - 0xC0000000 )
+ {
*(.data)
}
- .rodata BLOCK(4K) : AT ( ADDR(.rodata) - 0xC0000000 ) {
+ .rodata BLOCK(4K) : AT ( ADDR(.rodata) - 0xC0000000 )
+ {
*(.rodata)
}
- .kpg BLOCK(4K) : AT ( ADDR(.kpg) - 0xC0000000 ) {
+ .kpg BLOCK(4K) : AT ( ADDR(.kpg) - 0xC0000000 )
+ {
*(.kpg)
}
/* for generated array, we align to address line size */
- .lga BLOCK(4K) : AT ( ADDR(.lga) - 0xC0000000 ) {
+ .lga BLOCK(4K) : AT ( ADDR(.lga) - 0xC0000000 )
+ {
PROVIDE(__lga_twiplugin_inits_start = .);
KEEP(*(.lga.twiplugin_inits));
}
- .bss BLOCK(4K) : AT ( ADDR(.bss) - 0xC0000000 ) {
+ .bss BLOCK(4K) : AT ( ADDR(.bss) - 0xC0000000 )
+ {
*(.bss)
}