0-ZYNQ折腾记录-启动顺序
0-ZYNQ折腾记录-启动顺序
BootROM——>FSBL——>Uboot
BootROM
每次一上电, ARM核心就会前往 BootROM完成一些基本的准备工作, 就这样一个最开始的程序,需要完成以下几件事情:
- 释放PMU,复位CSU。
- 读取拨码开关,获取启动模式,从相应的内存中获取启动文件。
- 从Boot image里面获取Boot Header信息。
通过拨码开关调整ZYNQ用不同的Boot模式进行启动,ARM核心就会去对应的BootROM启动,包括JTAG、Flash、SD、eMMC等等。
FSBL(First Stage Boot Loader)
FSBL的任务比较重要,它需要完成以下的工作:
- 初始化PS端。
- 使用bit文件配置PL端。
- 加载Uboot到内存中。
- 移交执行权限给Uboot。
首先会初始化PS端的内存与MIO接口等然后读取 bit文件配置好PL端, 值得注意的是PL端需要在FSBL的阶段配置好,否则是无法直接配置的。接着加载Uboot到内存中,最后ARM会跳转到内存中执行Uboot程序。
Uboot
Uboot最主要的功能就是将内核写入内存中, 然后将 执行权限移交给内核 ,但是 Uboot需要完成的任务并不仅限于此:
初始化运行环境。
- 初始化内存。
- 检查内存映射。
- 将内核写入内存。
- 设置启动参数。
- 调用内核。
等内核起来后,Uboot就完成了它的工作,紧接着就是内核去完成自己的工作。
分类:
ZYNQ
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· .NET10 - 预览版1新功能体验(一)