ZYNQ实验--裸机程序固化

news2025/1/12 20:09:26

参考资料

正点原子《领航者 ZYNQ 之嵌入式 SDK 开发指南》详细的配置资料中都有介绍,本文只针对个人实验需求进行简要说明

固化流程

  调试阶段是通过 JTAG 接口将 FPGA 配置文件和应用程序下载到 ZYNQ 器件中。但在实际应用中需要程序在上电或者复位时让程序自动运行,这个过程需要启动引导程序(Boot Loader)的参与。Boot Loader 会加载 FPGA 配置文件,以及运行在 ARM 中的软件应用。

1、基本的硬件配置

  在进行固化前请确保使能 QSPI 以及 SD 控制器外设,并分别设置 Bank0 和 Bank1 的电平标准。建议把串口和一些必要的配置都勾选上以免以后加功能还重新设置。
在这里插入图片描述

2、FSBL(First-Stage Boot Loader)工程和启动镜像创建

2.1 在工程目录中修改bsp设置

  在弹出的 BSP 设置界面中,勾选“xilffs”,以使用 FAT 文件系统。工程需要的包要保留
在这里插入图片描述
在这里插入图片描述

2.2 创建FSBL 工程

  在菜单栏中选择“File->New->Application Project”,然后在弹出的新建工程界面中设置工程名,并选择工程中的 BSP,如下图所示,接下来点击 Next,并在示例工程中选择“Zynq FSBL”,最后点击“Finish”,如下图所示。FSBL 工程创建完成之后,SDK 软件会自动执行编译过程,生成 FSBL.elf 文件。
在这里插入图片描述

2.3 创建启动镜像

  在 SDK 菜单栏中选择“Xilinx -> Create Boot Image”
在这里插入图片描述

  在弹出的创建 Boot Image 对话框中,设置输出文件的路径(可以自己指定),然后在add处添加配置文件
在这里插入图片描述
  首先添加的是 FSBL,在 Partion type 一栏默认的文件类型为 bootloader,然后指定 FSBL.elf 所在的文件路径。点击“OK”后返回到上图所示的界面,再次点击“Add”按钮,添加 FPGA 配置文件,注意添加顺序,bit在FSBL之后
在这里插入图片描述
  ELF 文件添加完成后,创建 Boot Image 界面如下图所示。点击“Create Image”,完成 BIN 文件的创建。
在这里插入图片描述
在这里插入图片描述

3、SD卡启动

  将 Micro SD 卡插入读卡器,然后在电脑上将其格式化为 FAT32 格式。将生成的 BOOT.bin 文件拷贝到 SD 卡根目录下,注意SD卡名字也要改成BOOT,启动时将选择到SD启动即可。

4、QSPI Flash 启动

  将程序固化到 QSPI Flash 需要使用 JTAG 下载器,下载到QSPI Flash时保证当前是在JTAG启动模式。在 SDK 软件的菜单栏中点击“Xilinx->Program Flash”。
在这里插入图片描述
  在弹出的对话框中指定前面所生成的镜像文件 BOOT.bin 以及 FSBL.elf 文件
在这里插入图片描述
  FLASH 编程结束后,控制台提示信息如下图所示。接下来关闭开发板电源开关,切换到QSPI Flash启动即可。
在这里插入图片描述

遇到的问题

  1. 上点后串口打印错误信息: FSBL Warning !!!Bitstream not loaded into PL Partition order invalid
    出现该问题是因为创建镜像文件时bit文件位置不对。bit一定要在FSBL之后
    在这里插入图片描述
  2. 网络连接无效
    PS工程可能会用到很多其他的库,bsp设置里一定要保留需要的库选项,确定没有问题再生成FSBL工程。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1656308.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

利用Python简单操作MySQL数据库,轻松实现数据读写

PyMySQL是Python编程语言中的一个第三方模块,它可以让Python程序连接到MySQL数据库并进行数据操作。它的使用非常简单,只需要安装PyMySQL模块,然后按照一定的步骤连接到MySQL数据库即 可。本文将介绍PyMySQL的安装、连接MySQL数据库、创建表、…

【Linux】18. 进程间通信 --- System V IPC(选学)

System V IPC System V 消息队列System V 共享内存System V 信号量 system V 共享内存 共享内存区是最快的IPC形式。一旦这样的内存映射到共享它的进程的地址空间,这些进程间数据传递不再涉及到内核。 换句话说是进程不再通过执行进入内核的系统调用来传递彼此的数据…

Python图形界面(GUI)Tkinter笔记(一):根窗口的创建

Tkinter库是Python的内置关于图形界面编程(GUI全称为Graphical User Interface,中文意思为“图形用户界面”)的一个库。直接导入Tkinter使用即可。 其余笔记:【Python图形界面(GUI)Tkinter笔记(…

ES6语法教程

简介: ECMA European Computer Manufactures Association 欧洲计算机制造商协会,该组织的目标是评估、开发、和认可电信和计算机标准,94年后该组织改名为Ecma国标。 ECMAScript是由Ecma国际通过ECMA-262标准化的脚本程序设计语言 Ecma国…

【设计模式】JAVA Design Patterns——Abstract-document

🔍 目的 使用动态属性,并在保持类型安全的同时实现非类型化语言的灵活性。 🔍 解释 抽象文档模式使您能够处理其他非静态属性。 此模式使用特征的概念来实现类型安全,并将不同类的属性分离为一组接口 真实世界例子 考虑由多个部…

九州金榜|如果孩子胆小懦弱,如何家庭教育?

在孩子成长的过程中,孩子可能会出现胆小懦弱的表现,当孩子出现这个问题是,势必会对孩子成长造成影响,可能会影响孩子的社交,学习以及日常生活等。对此很多家长不明白哪地方出现了问题,就会着急。面对这种情…

速度背!24上软考信管“经典100道母题来了”!

距离软考考试的时间越来越近了,趁着这两周赶紧准备起来 今天给大家整理了——信息系统管理工程师经典100道母题(含解析),有PDF版,可打印,每天刷一点。 1、微机系统中,( &#xff09…

一键自动化博客发布工具,用过的人都说好(cnblogs篇)

cnblogs和其他的博客平台相比会比较复杂,需要设置的项目也比较多一些,弄懂了cnblogs的实现方式,那么你应该对selenium的整个框架使用已经烂熟于心了。 除了正常的标题,内容,摘要之外,cnblogs还需要设置个人…

操作系统原理与实验——实验十三多道批处理作业调度(作业不可移动)

关键代码 #include<stdio.h> #include<stdlib.h> #include<string.h> typedef struct data{int hour;//当前小时int min;//当前分钟 }time; struct node{char name[20];//进程名time arrive;//到达就绪队列时间int zx;//执行时间(预期时间)int size;int ta…

用栈实现队列——leetcode刷题

题目要求我们只用栈的基本操作 push to top 入栈&#xff0c;peek from top 返回栈顶元素&#xff0c;pop from top 移除并返回栈顶元素&#xff0c;size 栈的大小&#xff0c;is_empty 判断栈是否为空&#xff0c;这几个函数来实现队列&#xff0c;也就是说&#xff0c;我们在…

建议收藏!如何选择高低温冲击试验箱厂家?

高低温冲击试验箱是实验室中不可或缺的重要设备之一&#xff0c;它在许多领域都发挥着关键作用。因此选择合适的高低温冲击试验箱厂家是非常关键的&#xff0c;因为正规厂家的正规产品能直接影响到产品实验的准确性和效率。下面我们一起来了解一下关于选择高低温冲击试验箱厂家…

从源头把控风险:集团多主体合规管理实战技巧分享

官.网地址&#xff1a;合合TextIn - 合合信息旗下OCR云服务产品 集团合规管理中&#xff0c;为了规避内外部利益冲突&#xff0c;需要对员工、供应商、经销商、客户、黑名单企业等多主体及其关联主体之间&#xff0c;进行多维度、多层级的关系挖掘与排查&#xff0c;避免利益…

OpenHarmony 实战开发(南向)-Docker编译环境搭建

Docker环境介绍 OpenHarmony为开发者提供了两种Docker环境&#xff0c;以帮助开发者快速完成复杂的开发环境准备工作。两种Docker环境及适用场景如下&#xff1a; 独立Docker环境&#xff1a;适用于直接基于Ubuntu、Windows操作系统平台进行版本编译的场景。 基于HPM的Docker…

react、vue 把要渲染的元素挂到指定节点。

react、vue 把要渲染的元素挂到指定节点。 文章目录 vue3 的 Teleportreact 的 createPortal 在日常工作中&#xff0c;需要封装一些定制的浮动模态框&#xff0c;但是每个弹框在不同的父级元素中&#xff0c;那弹框的层级我们是没有办法控制到的&#xff0c;所有有必要把它统一…

2024年钉钉直播回放怎么永久保存

钉钉群直播回放下载工具我已经打包好了&#xff0c; 钉钉群直播回放下载链接&#xff1a;百度网盘 请输入提取码 提取码&#xff1a;1234 --来自百度网盘超级会员V10的分享 1.首先解压好我给大家准备好的压缩包 2.再继续解压M3U8逍遥一仙下载器 3.进入M3U8逍遥一仙下载器文…

Pytorch快速上手

Pytorch快速上手 一、加载数据集 &#xff08;Dataset&#xff09; 加载数据集需要继承Dataset&#xff0c;通常情况下需要实现__init__方法、__getitem__方法以及__len__方法。 案例一&#xff1a; import osimport torch from torch.utils.data import Dataset from PIL …

SqlDeveloper字体大小设置

菜单栏字体&#xff1a; C:\Users\xxx\AppData\Roaming\SQL Developer\system19.2.1.247.2212\o.sqldeveloper 下的ide.properties 修改 Ide.FontSize.Aqua30 编辑器字体&#xff1a;

特定消谐技术:SHEPWM调制方法

简介 特定消谐技术是通过计算PWM波的开关时刻&#xff0c;消除特定的低阶谐波。其基本理论是恰当地控制逆变器脉宽调制电压的波形&#xff0c;通过脉宽平均法把逆变器输出的方波电压转换成等效的正弦波&#xff0c;以消除某些特定的谐波。本文对特定谐波消除方法的基本原理进行…

SpringBoot启动流程源码解析

目录 一、SpringApplication构造方法解析 1. web应用类型 2. BootstrapRegistryInitializer 3. ApplicationContextInitializer 4. ApplicationListener 5. 推断Main方法所在类 二、SpringApplication.run(String... args)方法解析 1.创建DefaultBootstrapContext 2.获…

算法day02

1、202. 快乐数 如上题所述&#xff1a; 在该题意规则下&#xff0c;所有的数字变化会有两种情况&#xff0c;其一最后是有的会变化成恒为1的数&#xff1b;其二是有的数会变化会呈现成有规律的环&#xff0c;分别如下图所示&#xff1a; 可以近似的理解为图一就是一个环&#…