ZYNQ - 嵌入式Linux开发 -11- ZYNQ7系列FSBL执行流程分析

简介: ZYNQ - 嵌入式Linux开发 -11- ZYNQ7系列FSBL执行流程分析

写在前面


本文主要是对FSBL工程的main函数进行分析。

FSBL代码启动步骤


在SDK新建一个FSBL工程,然后打开src文件夹中的main.c文件,找到maian函数进行分析,FSBL的启动过程。

1.对 PCW进行初始化


image.png

调用ps7_init函数,主要是对PS端配置信息进行初始化操作,包括MIO,PLL.CLK and DDR。在vivado软件中可以通过图形化的方式对ZYNQ PS端外设进行相关配置,那么这些配置信息会写入到hdf文件,SDK(或petalinux)会对hdf文件进行解析并生成对应的寄存器配置表,然后FSBL工程中会通过ps7_init函数将寄存器配置表写入到对应的寄存器中,完成对MIO/PLL/CLK/DDR等外设的硬件配置。

2.解锁SLCR


image.png

解锁SLCR,用于SLCR寄存器的写入。

3.刷DCache缓存、禁用DCache缓存


image.png

先调用Xil_DCacheFlush,函数完成刷DCache,缓存的操作,然后再调用Xil_DCacheDisable禁用DCache缓存。

4.注册异常处理函数


image.png

调用RegisterHandlers函数,进行异常处理函数的注册。

5.DDR读写测试


调用DDRInitCheck函数,用于DDR读写测试。

image.png

6.PCAP的初始化


image.png

调用InitPcap函数处理器配置访问端口。

7.读取芯片版本


image.png

8.获得PCAP控制器设置检查AES秘钥


image.png

9.存储FSBL复位状态寄存器、读取bootmode寄存器


image.png

10.读取BOOT_MODE寄存器


这个寄存器记录ZYNQ的启动方式(QSPI、SD、NAND、Nor、JTAG),可以通过MIO3、MIO4、MIO5这三个引脚去配置ZYNQ的启动方式

ZYNQ上电复位的时候,会将这三个引脚的电平状态保存在BDOT_MODE寄存器当中,下图为NOR Flash模式下的配置代码。

image.png

这部分代码逐个比较BOOT_MODE寄存器值,确定ZYNQ当前的启动方式每一种启动方式会有不同的处理方式。

  1. 先初始化对应的flash设备
  2. 再将Movelmage.函数指针指向Flash设备的读写函数实体

11.加载启动镜像


image.png

调用LoadBootlmage函数。

FSBL的主要工作是启动U-Boot,也要将bitstream文件加载到PL端。找到U-Boot、bitstream,在读取U-Boot 拷贝 DDR中对应的加载地址,读取bitstream 加载到PL端。然后跳转到U-Boot运行地址启动U-Boot。

12.调用FsblHandoff


image.png

调用FsblHandoff(HandoffAddress),启动完U-Boot之后,FSBL的使命的就完成了。

references


  1. UG585
  2. FSBL代码


目录
相关文章
|
12天前
|
Linux 编译器 Android开发
FFmpeg开发笔记(九)Linux交叉编译Android的x265库
在Linux环境下,本文指导如何交叉编译x265的so库以适应Android。首先,需安装cmake和下载android-ndk-r21e。接着,下载x265源码,修改crosscompile.cmake的编译器设置。配置x265源码,使用指定的NDK路径,并在配置界面修改相关选项。随后,修改编译规则,编译并安装x265,调整pc描述文件并更新PKG_CONFIG_PATH。最后,修改FFmpeg配置脚本启用x265支持,编译安装FFmpeg,将生成的so文件导入Android工程,调整gradle配置以确保顺利运行。
37 1
FFmpeg开发笔记(九)Linux交叉编译Android的x265库
|
14天前
|
Unix Linux Shell
FFmpeg开发笔记(八)Linux交叉编译Android的FFmpeg库
在Linux环境下交叉编译Android所需的FFmpeg so库,首先下载`android-ndk-r21e`,然后解压。接着,上传FFmpeg及相关库(如x264、freetype、lame)源码,修改相关sh文件,将`SYSTEM=windows-x86_64`改为`SYSTEM=linux-x86_64`并删除回车符。对x264的configure文件进行修改,然后编译x264。同样编译其他第三方库。设置环境变量`PKG_CONFIG_PATH`,最后在FFmpeg源码目录执行配置、编译和安装命令,生成的so文件复制到App工程指定目录。
43 9
FFmpeg开发笔记(八)Linux交叉编译Android的FFmpeg库
|
3天前
|
Ubuntu 算法 Linux
嵌入式Linux的学习误区
该文指出了学习嵌入式Linux开发的两个常见误区。一是过分专注于学习桌面或服务器版Linux,而非关注嵌入式开发本身,实际上只需熟悉基本操作即可。二是试图在没有基础的情况下直接阅读Linux内核源代码,这是不切实际的,应先建立基础知识再进行源码学习。文章还提到了在嵌入式系统中获取和处理屏幕数据的示例,包括使用gsnap工具将framebuffer数据转为图像,以及涉及的交叉编译过程。
8 0
|
3天前
|
前端开发 Linux iOS开发
【Flutter前端技术开发专栏】Flutter在桌面应用(Windows/macOS/Linux)的开发实践
【4月更文挑战第30天】Flutter扩展至桌面应用开发,允许开发者用同一代码库构建Windows、macOS和Linux应用,提高效率并保持平台一致性。创建桌面应用需指定目标平台,如`flutter create -t windows my_desktop_app`。开发中注意UI适配、性能优化、系统交互及测试部署。UI适配利用布局组件和`MediaQuery`,性能优化借助`PerformanceLogging`、`Isolate`和`compute`。
【Flutter前端技术开发专栏】Flutter在桌面应用(Windows/macOS/Linux)的开发实践
|
7天前
|
编解码 Linux
FFmpeg开发笔记(十二)Linux环境给FFmpeg集成libopus和libvpx
在《FFmpeg开发实战》一书中,介绍了如何在Linux环境下为FFmpeg集成libopus和libvpx,以支持WebM格式的Opus和VP8/VP9编码。首先,下载并安装libopus。接着,下载并安装libvpx。最后,在FFmpeg源码目录下,重新配置FFmpeg,启用libopus和libvpx,编译并安装。通过`ffmpeg -version`检查版本信息,确认libopus和libvpx已启用。
18 1
FFmpeg开发笔记(十二)Linux环境给FFmpeg集成libopus和libvpx
|
7天前
|
编解码 Linux
FFmpeg开发笔记(十)Linux环境给FFmpeg集成vorbis和amr
在Linux环境下,为FFmpeg添加对AAC、MP3、OGG和AMR音频格式的支持,需安装libogg、libvorbis和opencore-amr库。首先,从官方源下载各库的最新源码,如libogg-1.3.5、libvorbis-1.3.7和opencore-amr-0.1.6,然后解压并依次执行`./configure`、`make`和`make install`进行编译安装。接着,在FFmpeg源码目录中,使用`./configure`命令重新配置,并重新编译安装FFmpeg。最后,验证FFmpeg版本信息确认已启用ogg和amr支持。
18 0
FFmpeg开发笔记(十)Linux环境给FFmpeg集成vorbis和amr
|
18天前
|
Linux 编译器 测试技术
嵌入式 Linux 下的 LVGL 移植
嵌入式 Linux 下的 LVGL 移植
|
18天前
|
Linux 内存技术 Perl
【ZYNQ】制作从 QSPI Flash 启动 Linux 的启动文件
【ZYNQ】制作从 QSPI Flash 启动 Linux 的启动文件
|
3天前
|
SQL 缓存 监控