0-ZYNQ折腾记录-启动顺序

0-ZYNQ折腾记录-启动顺序

BootROM——>FSBL——>Uboot

BootROM

  每次一上电, ARM核心就会前往 BootROM完成一些基本的准备工作, 就这样一个最开始的程序,需要完成以下几件事情:

  • 释放PMU,复位CSU。
  • 读取拨码开关,获取启动模式,从相应的内存中获取启动文件。
  • 从Boot image里面获取Boot Header信息。

  通过拨码开关调整ZYNQ用不同的Boot模式进行启动,ARM核心就会去对应的BootROM启动,包括JTAG、Flash、SD、eMMC等等。

image

image

image

FSBL(First Stage Boot Loader)

  FSBL的任务比较重要,它需要完成以下的工作:

  • 初始化PS端。
  • 使用bit文件配置PL端。
  • 加载Uboot到内存中。
  • 移交执行权限给Uboot。

image

  首先会初始化PS端的内存与MIO接口等然后读取 bit文件配置好PL端, 值得注意的是PL端需要在FSBL的阶段配置好,否则是无法直接配置的。接着加载Uboot到内存中,最后ARM会跳转到内存中执行Uboot程序。

Uboot

  Uboot最主要的功能就是将内核写入内存中, 然后将 执行权限移交给内核 ,但是 Uboot需要完成的任务并不仅限于此:
初始化运行环境。

  • 初始化内存。
  • 检查内存映射。
  • 将内核写入内存。
  • 设置启动参数。
  • 调用内核。

  等内核起来后,Uboot就完成了它的工作,紧接着就是内核去完成自己的工作。

posted on   naive156  阅读(48)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· .NET10 - 预览版1新功能体验(一)
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

导航

统计

点击右上角即可分享
微信分享提示