介绍下背景吧,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.inc的start里面,该跳转指令是5字节长度,而后面操作数是一个16位的地址,用32位地址表示。
b) reset16.lds里面会定义reset16.inc里面的段被编译到0xfffffff0的位置,并限定_start的位置不能小于0Xffff0000.(末端64kb)的位置。是因为在16为模式下段界限为64kb,在16个字节的最后一个字节处置0值。