系统固件架构详解
1. 内存相关组件
1.1 内存范围与e820表
特定的内存范围在整个启动阶段都可访问,并且作为e820表的保留部分提供给操作系统。
1.2 内存数据库(IMD)
IMD 位于 cbmem 区域,用于创建动态的 cbmem 基础设施,使 cbmem 能随内容添加而动态增长。IMD 数据结构有两个区域:作为 IMD 根指针大区域的 IMDR 和小区域。这些区域根据 imd.h 进行静态大小分配,从提供的上限和根大小开始在内存中向下增长,新的分配区域总是位于最后一个分配区域下方。区域可以移除,但只能移除最后添加的区域。
1.3 可重定位模块(rmodules)
引入此概念是为了支持启动阶段的重定位。对于 coreboot 项目中的 .elf 文件,那些在物理内存初始化后执行且不使用 SPI 映射内存的文件,使用 rmodtool 生成位置无关代码和数据块。cbfstool 用于解析并将 ELF 类型文件转换为 rmodules。
2. 启动阶段
2.1 Romstage
Romstage 负责加载下一个阶段(如果有 postcar)到 DRAM 并开始执行。
2.2 Postcar
Postcar 阶段是 x86 平台上物理内存可用后,第一个从 DRAM 运行的阶段,是所有启动阶段中体积最小的。其职责如下:
- 拆除 CAR 设置。
- 在拆除 CAR 后从常规 DRAM 运行代码。
- 将 ramstage 加载到内存。
超级会员免费看
订阅专栏 解锁全文
2519

被折叠的 条评论
为什么被折叠?



