【coreboot】coreboot编译和运行

准备工作

本文使用的系统是64位Ubuntu16.04系统。

coreboot版本下载日期为2016年8月10日。

安装git。(root模式下运行apt install git)

通过git下载coreboot源代码。(git clone http://review.coreboot.org/coreboot.git)

安装qemu。(root模式下运行apt install qemu)

使用命令安装以下内容:

apt install build-essential flex bison libncurses5-dev wget zlib1g-dev

后续编译时需要使用到它们。

编译

进入coreboot根目录:

 上图用来展示coreboot目录结构,注意实际的编译是在linux下进行的。

编译过程如下(本文以x86平台为例):

1. make crossgcc-i386

使用这个命令后,会下载很多的辅助工具,一部分通过git clone完成,另一部分通过下载完成。不过无论哪种方式都不是很顺利,因此这边自己根据提示信息自行下载了需要的内容。

下面是需要下载内容的地址:

http://ftpmirror.gnu.org/gmp/gmp-6.1.0.tar.xz

http://ftpmirror.gnu.org/mpfr/mpfr-3.1.4.tar.xz

http://ftpmirror.gnu.org/mpc/mpc-1.0.3.tar.gz

http://www.mr511.de/software/libelf-0.8.13.tar.gz

http://ftpmirror.gnu.org/binutils/binutils-2.26.1.tar.bz2

http://ftpmirror.gnu.org/gcc/gcc-5.3.0/gcc-5.3.0.tar.bz2

(git clone部分还算顺利,因此没有列举)

随着coreboot版本的更新,上述的下载地址可能也会更新,这里不做保证。

上面的内容下载完成之后,需要把它们放到coreboot/util/crossgcc/tarballs目录下。

这样,make crossgcc-i386就可以顺利执行了。

这个命令是用来生成tool chain的,这里只生成了用于x86平台编译的部分。

2. make

第一次使用make的时候会提示设置各种配置,根据实际情况设置就可以。

或者直接所有设置都按回车也可以。

然后可以通过make menuconfig后出现的配置界面中进行设置:

关于所有配置的作用,可以在https://www.coreboot.org/Coreboot_Options中找到。生成的配置文件是coreboot/.config。

3. 因为本文使用x86平台,所以上面的配置中需要修改Mainboard选项中的一部分,改成x86就可以了。

4. 另外一个需要修改的地方是Playload选项。默认情况下,coreboot不带Payload,但是为了后续的运行,需要在这里加上Payload,本文使用seabios作为Payload。

最新的coreboot版本中没有自带的seabios了,因此需要自己下载源代码来编译生成seabios二进制。

不过好的是在coreboot/payload/externals下有Seabios目录,理论上在这个目录下运行make,就可以下载和编译seabios了,但是实际使用的时候会发现下载没有问题,但是编译失败:

不过即使自动编译失败了,还是可以手动配置和编译的。

首先是配置,进入seabios目录下,运行make menuconfig,配置Build Target为coreboot:

然后运行make,会在seabios/out目录下生成bios.bin.elf文件,这个是coreboot编译时候需要的seabios(可以在coreboot/.config文件中的Payload项中找到对应)。

5. 之后返回coreboot目录,执行make命令。完成后可以在coreboot/build目录下找到coreboot.rom文件,这个就是生成的二进制文件。

注意:在配置coreboot和seabios时出现了用户模式下配置文件不能保存的问题,改成root模式下就可以了。

运行

这里使用qemu来运行生成的coreboot。

1. 创建qemu需要使用的硬盘:

qemu-img create -f raw disk.img 200M

2. 将编译得到的coreboot.rom放在同一级目录,如下所示:

3. 执行如下的命令:

qemu-system-x86_64 -bios coreboot.rom -hda disk.img

就可以执行coreboot了,下面是结果:

目前的效果是coreboot已经执行到了seabios中的启动项加载部分,但是因为disk.img本身没有任何东西,所以加载失败,并跳转到了iPXE。

不过总的来说,coreboot的运行本身已经工作起来了。

参考

本文根据以下网站为参考写成,网站中的部分内容已经比较旧了,不能再作为参考,因此与本文可能有冲突。

Build HOWTO - coreboot

QEMU - coreboot

QEMU Build Tutorial - coreboot

SeaBIOS - coreboot

SeaBIOS

  • 3
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
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开发流程和相关技术后进行修改。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值