1. 从零开始:为什么u-boot是ZYNQ7000启动Linux的“第一把钥匙”
如果你刚拿到一块像AX7020这样的ZYNQ7000开发板,想让它跑起一个完整的Linux系统,比如Ubuntu,你可能会有点懵。硬件设计好了,Vivado工程也生成了比特流,操作系统镜像也准备好了,但怎么让板子“听话”地从SD卡里找到并启动这一切呢?这里面的关键角色,就是u-boot。你可以把它想象成电脑主板上的BIOS,但更强大、更灵活,是嵌入式世界里的“超级引导程序”。
我刚开始玩ZYNQ的时候,也以为把系统文件往SD卡里一扔就行了,结果板子上电后串口一片寂静,啥也没有。后来才明白,在处理器(PS端)真正执行我们的应用程序或Linux内核之前,需要一段“开道”的代码。这段代码要初始化最基础的硬件(比如DDR内存、时钟、串口),然后把更复杂的“大程序”(比如Linux内核)从存储设备(如SD卡、QSPI Flash)搬运到内存里,最后把控制权交出去。这个“开道者”就是u-boot。对于ZYNQ7000这个包含ARM Cortex-A9双核处理器和FPGA的混合架构芯片来说,u-boot的职责尤其重要,它不仅要引导ARM侧的Linux,整个启动链条的衔接也离不开它。
所以,这篇内容我就以手头的AX7020开发板为例,带你完整走一遍u-boot的编译、配置,直到生成最终可启动的BOOT.BIN文件,并上板测试。整个过程我会尽量还原我踩过的坑和总结的技巧,目标是让你看完就能自己动手做出来,看到串口里u-boot那熟悉的启动日志。我们不会深究u-boot每一行源代码,而是聚焦在“怎么做”和“为什么这么做”上,保证实用、可操作。
2. 动手之前:理清u-boot的来龙去脉与源码骨架
在开始敲命令之前,我们花点时间搞清楚u-boot到底是什么,以及它的源码是怎么组织的。这能帮你后面遇到编译错误或者配置问题时,知道该去哪里找答案,而不是盲目试错。
u-boot,全称Universal Boot Loader,最早是德国DENX小组开发的。它的“Universal”名副其实,支持ARM、MIPS、PowerPC、x86等几乎所有主流嵌入式CPU架构,也能引导Linux、VxWorks、QNX等多种操作系统。在ZYNQ7000平台上,我们主要用它来引导Linux。它本身也是一个功能丰富的微型系统,提供了命令行界面,可以读写内存、擦写Flash、配置网络、甚至通过TFTP下载文件,这些功能在开发和调试阶段极其有用。
当你从Xilinx的Git仓库或者某个稳定版本下载好u-boot源码包(比如我常用的xilinx-v2016.07这个版本,比较稳定,与SDK 2015.4配合良好)并解压后,面对一堆文件夹可能会眼花。别慌,它的结构非常清晰,每个目录各司其职:
arch/:这是架构目录,所有CPU架构相关的代码都在这里。对于我们ZYNQ7000的ARM Cortex-A9,核心代码就在arch/arm/下面。这里的文件负责最底层的CPU初始化、汇编启动代码等。board/:开发板目录。Xilinx官方支持的开发板(包括我们的AX7020所使用的通用Zynq配置)定义都在这里,比如board/xilinx/zynq/。这个目录下的文件决定了这块板子上的DDR型号、串口是哪个、网络PHY怎么连接等硬件差异。configs/:配置文件目录。注意,这个目录在include/下面。里面存放着各种开发板的默认配置文件,文件名通常以_defconfig结尾。例如,zynq_ax7020_defconfig就是为我们这块板子预置的配置模板。编译前执行make xxx_defconfig,其实就是把这个模板复制为当前编译的配置。include/configs/:头文件配置目录。这里面的头文件(如zynq_common.h)包含了更详细的宏定义,比如内存大小、环境变量存储地址、启动命令等。defconfig文件里的选项最终会映射到这里生成autoconf.h。drivers/:驱动目录。串口、网卡(AX7020用的Realtek PHY)、SD/MMC控制器、USB等所有外设的驱动都在这里。u-boot能识别你的SD卡、能通过网线传输文件,全靠这里的驱动。common/:通用命令目录。u-boot命令行里那些好用的命令,比如printenv(打印环境变量)、setenv(设置环境变量)、tftp(网络下载)、bootm(启动内核)的实现代码,都在这个目录下以单个文件形式存在。scripts/、tools/:工具脚本目录。编译过程中用到的各种工具,比如将内核镜像打包成u-boot可识别的uImage格式的

893

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



