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 2024-10-27 19:24  naive156  阅读(3)  评论(0编辑  收藏  举报

导航