0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

生成zynq裸核启动文件步骤解析

454398 来源:CSDN博主 作者:西邮VDAIL 2020-11-26 15:20 次阅读

话不多说,进入今天的主题:生成zynq裸核启动文件。

1. 首先在vivado SDK中分别建立两个工程

注意:如上图所示,

Core0 工程建立时选择ps7_cortexa9_0,

Core1 工程建立时选择ps7_cortexa9_1

完成后如下图所示:

2. 配置Core1即从核中的BSP文件

在下图中画圈处,配置:-DUSE_AMP=1

3. 配置Core0和Core1的DDR空间分配

通过修改lscript.ld文件中的内容,可以改变在存储器中的执行位置, 因为ELF文件是加载到DDR中执行的,所以两个DDR地址不能重合

Core0的配置 :画圈处栈空间也要分配,防止溢出

Core1配置

4. 建立FSBL文件,并配置main()文件

配置main() 跟第三步中的DDR空间配置有关

在FSBL的src中找到main.c文件打开,在里面添加下面一段代码,用于启动CPU1:

#define sev() __asm__("sev")
#define CPU1STARTADR 0xFFFFFFF0 //Core1 DDR配置中的SIZE大小
#define CPU1STARTMEM 0x10000000 //Core1 DDR配置中的起始地址
void StartCpu1(void)
{
    #if 1
    Xil_Out32(CPU1STARTADR, CPU1STARTMEM);
    dmb(); //waits until write has finished
    sev();
#endif
}

将上面的代码在main()中添加到:Load boot image的位置,将CPU1的启动函数,放置于此位置,改动后的代码段如下:

5. 生成mcs文件和烧写mcs文件到QSPI Flash

单击‘Core1’,选择Xilinx Tools –> Create zynq boot image,选择Add,选择文件…/ Core1/Debug/ Core1.elf,点击打开。然后选择Core1.elf, Core0.elf在Core1.elf上面。然后在Output pach后面把boot.bin修改为Boot.mcs。然后点击 Create Image

选择文件生成存储地址

选择MCS

画圈处是添加的文件

顺序为:FSBL.elf .bit文件 Core0.elf Core1.elf

点击Create Image 生成.mcs文件

6. 完成操作将.MCS文件烧写进板子里

bin文件用来烧写到SD卡,mcs文件用来烧写到QSPI flash中

选择Xilinx Tools –> Program Flash,在Image File后面选择刚才生成的Boot.mcs文件,Offset为0x0,Flash Type为qsip_single。勾选Blank check after erase和Verify after flash。检查开发板上电和连线状况,然后点击Program

编辑:hfy

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 存储器
    +关注

    关注

    38

    文章

    7447

    浏览量

    163587
  • DDR
    DDR
    +关注

    关注

    11

    文章

    711

    浏览量

    65218
  • Vivado
    +关注

    关注

    19

    文章

    808

    浏览量

    66312
收藏 人收藏

    评论

    相关推荐

    ZYNQ开发案例之ZYNQ的UART加载

    加载方法 ZYNQ启动镜像是由FSBL程序(bootloader),PL配置文件(硬件比特流文件),应用层软件三个部分组成,其通过SDK的软件生成
    的头像 发表于 12-05 10:15 5314次阅读
    <b class='flag-5'>ZYNQ</b>开发案例之<b class='flag-5'>ZYNQ</b>的UART加载

    IP生成文件:XilinxAltera

    IP生成文件:XilinxAlteraIP 生成文件:(Xilinx/Altera同) IP 生成
    发表于 08-12 12:21

    关于zynq启动的问题,求达人解答!

    资料显示PL部分也可以单独重启,由PS来完成,但不知道怎么操作,有无现成的函数可用???3)对于QSPI启动模式的镜像的生成,例如不上系统的情况下,把ARM当单片机使用,生成文件只有
    发表于 08-23 10:49

    玩转Zynq连载29——[ex51] 制作跑程序的启动文件BOOT.bin

    `玩转Zynq连载29——[ex51] 制作跑程序的启动文件BOOT.bin 更多资料共享腾讯微云链接:https://share.weiyun.com/5s6bA0s百度网盘链接:
    发表于 09-30 14:11

    Zynq在非JTAG模式下的启动配置流程

    ARM 来实现的。  需要注意的是,与传统的 Xilinx 7 系列 FPGA 芯片不同,Zynq 是不支持从 PL 端进行直接启动配置的,一定要通过 PS 部分来完成。  Zynq
    发表于 01-08 16:33

    Powerpcb生成gerber文件步骤图解

    Powerpcb生成gerber文件步骤图解 第一步:打开powerpcb
    发表于 11-27 20:32 0次下载

    IP生成文件

    IP生成生成ip后有两个文件对我们比较有用,假设生成了一个asyn_fifo的,则asyn
    发表于 07-21 16:42 0次下载

    Allegro生成钻孔文件步骤

    Allegro生成钻孔文件步骤 生成钻孔文件步骤:ALLEGRO TO NC DRILL
    发表于 03-21 18:11 4777次阅读
    Allegro<b class='flag-5'>生成</b>钻孔<b class='flag-5'>文件</b>的<b class='flag-5'>步骤</b>

    ZYNQ-7000如何生成从Flash和SD卡启动的镜像文件

    ZYNQ-7000如何生成从Flash和SD卡启动的镜像文件 将PL与PS部分一起使用,并且通过JTAG下载到板子运行。对于ZYNQ,有多种
    的头像 发表于 05-28 11:42 6341次阅读
    <b class='flag-5'>ZYNQ</b>-7000如何<b class='flag-5'>生成</b>从Flash和SD卡<b class='flag-5'>启动</b>的镜像<b class='flag-5'>文件</b>

    ZYNQ-7000如何生成从Flash和SD卡启动的镜像文件

    ZYNQ-7000如何生成从Flash和SD卡启动的镜像文件 将PL与PS部分一起使用,并且通过JTAG下载到板子运行。对于ZYNQ
    的头像 发表于 12-01 08:38 7586次阅读
    <b class='flag-5'>ZYNQ</b>-7000如何<b class='flag-5'>生成</b>从Flash和SD卡<b class='flag-5'>启动</b>的镜像<b class='flag-5'>文件</b>

    详解zynq启动步骤

    本文主要介绍zynq启动过程,主要包括BootROM和FSBL等的执行过程。
    发表于 10-27 10:47 7431次阅读
    详解<b class='flag-5'>zynq</b>的<b class='flag-5'>启动</b><b class='flag-5'>步骤</b>

    ZYNQ开发双运行原理及过程

    ZYNQ是一个可扩展平台,就是有FPGA作为外设的A9双处理器,它的启动流程与FPGA完全不同,而与传统的ARM处理器类似,ZYNQ启动
    的头像 发表于 12-05 10:48 5851次阅读

    Protel 99SE生成gerber文件的详细步骤

    Protel 99SE生成gerber文件的详细步骤
    发表于 04-13 09:58 0次下载

    ZYNQ启动流程

    ZYNQ7000 SOC 芯片可以从 FLASH 启动,也可以从 SD 卡里启动, 本节介绍程序 FLASH 启动的方法。Zynq7000
    的头像 发表于 05-07 09:41 6307次阅读

    zynq调试更新xsa文件步骤有哪些?

    zynq调试时,经常需要更新xsa文件,更新步骤如下
    的头像 发表于 08-14 09:14 1516次阅读
    在<b class='flag-5'>zynq</b>调试更新xsa<b class='flag-5'>文件</b>的<b class='flag-5'>步骤</b>有哪些?