3

我正在使用自定义链接器脚本将内核映像分成两部分。第一个是正常的代码和数据,第二个是初始化代码和不再需要时丢弃的数据。初始化部分也不像内核本身那样在地址空间之间共享,所以如果它仍然存在(它处于开发的早期阶段),那么任何东西都会被复制到 fork() 上。

我已经分配了一个小的内核堆栈以在启动时使用,但据我所知,我只能将它放在它在地址空间之间共享的 .bss 部分它不能存储为的 init 区域中未初始化的数据。我想将它作为未初始化的数据存储在图像的 init 部分中,以便每个进程都有自己的副本。

我可以想到两种可能的方法来做到这一点,但我无法确定它们是否可能,或者我将如何告诉链接器执行它们。第一种是将未初始化的区域放在非 .bss 部分中,但我不确定这是否可能——我认为您不能像这样混合部分。第二个是创建第二个类似.bss 的部分,它只存储未初始化的数据,我可以将其放入链接描述文件的初始化部分中。

有任何想法吗?为了完整起见,这是我正在使用的链接器脚本:

ENTRY(_start)

_kernel_offset = _start_kernel - _start_kernel_phys;

SECTIONS {
    _start_init = 0x100000;

    .init _start_init : AT(ADDR(.init)) { *(.mboot .init*) }
    .ctors : {
        __CTOR_NUM__ = .; LONG((__CTOR_END__ - __CTOR_LIST__) / 4)
        __CTOR_LIST__ = .; *(.ctors*)
        __CTOR_END__ = .;
    }

    _end_init = .;

    . = ALIGN(4M);
    _start_kernel_phys = .;
    _start_kernel = 0xF0000000;

    .text _start_kernel : AT(ADDR(.text) - _kernel_offset) { *(.text*) }
    .data ALIGN(4K) : AT(ADDR(.data) - _kernel_offset) { *(.rodata* .data*) }
    .bss ALIGN(4K) : AT(ADDR(.bss) - _kernel_offset) { *(.bss) *(COMMON) }

    _end_kernel = .;
    _end_kernel_phys = _end_kernel - _kernel_offset;

    /DISCARD/ : { *(.eh_frame .comment) }
}
4

1 回答 1

3

(呃,再次回答我自己的问题)

创建一个没有 CONTENTS 属性的新部分是可行的;它在程序集中声明如下:

.section .init.bss, "aw", @nobits
于 2010-11-24T23:12:54.097 回答