18、系统固件架构详解

系统固件架构详解

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 加载到内存。

2.3 R

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值