coreboot(linuxBIOS)中bootblock源码分析

本文深入分析了coreboot(原linuxBIOS)的bootblock源码,从BIOS入口地址开始,详细阐述了16位代码段的转换到保护模式的过程,包括GDT的设置、内存管理、SSE指令的初始化以及主板特定信息的加载。最后介绍了如何查找并跳转到romstage的入口。
摘要由CSDN通过智能技术生成

介绍下背景吧,coreboot原名linuxBIOS,是一款开源的BIOS,代码可以从www.coreboot.org获得,有兴趣的一起研究吧,本人小菜,第一次发原创,大家多多指教。

bootblock的流程分析参照

 

整个bootblock编译时都被include到一个文件里面然后编译,所以我们可以直接查看/build/mainboard/amd/mahogany_fam10/bootblock.s文件,这样不但不用去翻查,还能理清执行顺序。

 

1.      整个BIOS入口地址src/cpu/x86/16bit/reset16.inc

a)       定义了一个跳转指令,跳转到entry16.incstart里面,该跳转指令是5字节长度,而后面操作数是一个16位的地址,用32位地址表示。

b)      reset16.lds里面会定义reset16.inc里面的段被编译到0xfffffff0的位置,并限定_start的位置不能小于0Xffff0000.(末端64kb)的位置。是因为在16为模式下段界限为64kb,在16个字节的最后一个字节处置0值。

coreboot设置屏幕的timing参数通常需要修改相关的设备树文件和源代码。具体步骤如下: 1. 打开设备树文件,通常在`src/mainboard/<vendor>/<board>/devicetree.cb`,可以使用文本编辑器打开该文件。 2. 找到相关的设备节点,例如`lcd`、`display`等,根据屏幕的型号和接口类型进行修改,以设置正确的timing参数。例如: ``` device pci 1.0 on end # assume the device is connected to PCI1 chip drivers/pci/onboard device pci104c,8039.0 on # assume this is the LCD controller chip drivers/generic/lcd device panel chip drivers/generic/lcd_panel # set timing parameters here config gfx_display_width = 800 config gfx_display_height = 600 config gfx_display_depth = 24 config gfx_display_refresh = 60 config gfx_display_bpp = 32 config gfx_payload_x = 0 config gfx_payload_y = 0 config gfx_payload_offset = 0 config gfx_payload_lfb_base = 0x000a0000 ``` 3. 修改相关的源代码,以支持新的timing参数。例如,在`src/drivers/generic/lcd_panel.c`,可以添加新的timing参数并修改初始化函数,以正确设置屏幕的timing参数。 4. 编译和测试代码,确保屏幕的timing参数被正确设置。 需要注意的是,不同的屏幕型号和接口类型可能有不同的timing参数,需要根据具体情况进行修改。同时,修改设备树文件和源代码需要具备一定的编程经验和技能,建议在熟悉coreboot开发流程和相关技术后进行修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值