rust-based-os-comp2022 icon indicating copy to clipboard operation
rust-based-os-comp2022 copied to clipboard

[Question] 内核堆的位置在哪?

Open templklklk opened this issue 2 years ago • 2 comments

heap_allocator.rs的测试代码可以推出内核堆在bss段。


pub fn heap_test() {
    use alloc::boxed::Box;
    use alloc::vec::Vec;
    extern "C" {
        fn sbss();
        fn ebss();
    }
    let bss_range = sbss as usize..ebss as usize;
    let a = Box::new(5);
    assert_eq!(*a, 5);
    assert!(bss_range.contains(&(a.as_ref() as *const _ as usize)));
    drop(a);
    let mut v: Vec<usize> = Vec::new();
    for i in 0..500 {
        v.push(i);
    }
    for (i, vi) in v.iter().enumerate().take(500) {
        assert_eq!(*vi, i);
    }
    assert!(bss_range.contains(&(v.as_ptr() as usize)));
    drop(v);
    info!("heap_test passed!");
}

请问 1.内核堆在bss段的具体位置,从哪开始到哪结束,在哪段代码设置的? 2.为什么内核堆要在bss段?

templklklk avatar Nov 20 '22 11:11 templklklk

我也不是很理解这部分,不过这让我联想到一些东西: 我们之前为操作系统分配了操作系统的运行栈,参考 entry.asm 与 linker.ld 文件:

    . = ALIGN(4K);
    edata = .;
    sbss_with_stack = .;
    .bss : {
        *(.bss.stack)
        sbss = .;
        *(.bss .bss.*)
        *(.sbss .sbss.*)
    }

我们常见的内存布局如下: image

可以看见,堆相关的内存在内存布局中与 .bss 段非常接近,猜测这里是没有刻意在 linker.ld 中指明与 堆相关 的内存布局,而是交给 buddy_system_allocator::LockedHeap 进行处理。

CelestialMelody avatar Nov 22 '22 10:11 CelestialMelody

这里的“内核堆”托管的空间就是一个空白的大数组。“空白的大数组”自然在 .bss 上。

YdrMaster avatar Nov 26 '22 01:11 YdrMaster