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

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

3天内不再提示

Flash外部配置器件在SOPC中的应用

jf_pJlTbmA9 来源:jf_pJlTbmA9 作者:jf_pJlTbmA9 2023-08-03 15:55 次阅读

作者:沈满德 张敏张法全 陈良益

1 Flash在SOPC中的作用

Flash在SOPC中的作用主要表现在两方面:一方面,可用Flash来保存FPGA的配置文件,从而可以省去EPCS芯片或解决EPCS芯片容量不够的问题。当系统上电后,从Flash中读取配置文件,对FPGA进行配置。另一方面,可用Flash来保存用户程序。对于较为复杂的SOPC系统,用户程序一般较大,用EPCS来存储是不现实的。系统完成配置后,将Flash中的用户程序转移到外接RAM或片内配置生成的RAM中,然后系统开始运行。

2 Flash编程的实现

本文以某项目的具体电路为例,阐述在SOPC系统中如何利用Flash来保存用户程序。FPGA为Altera公司的Cyclone EP1C6,Flash为AMD公司的AM29LV160D,外接RAM为Samsung公司的K4S643232H,串行配置器件为EPCS1。开发工具采用Altera公司提供的QuartusII和NioslI软件。

NiosII的开发环境中提供了Flash Programmer工具,对目标板上遵守CFI(Common Flash InteRFace)规范的Flash进行编程。CFI是一种Flash接口规范,只要Flash符合该规范,通过专门的命令就能获得其详细的参数,并根据这些参数访问Flash。利用Altera公司的下载电缆,Flash Programmer工具可以对Flash器件中的任意偏移地址进行任意内容的编程。Flash Programmer工具对Flash编程分为2个步骤:

①根据目标板编程描述对FPGA进行配置;

②Flash Programmer工具将要编程到Flash的文件内容传送到FPGA的数据缓冲区,然后FPGA将收到的数据写入Flash中。

2.1 目标板编程描述的创建

目标板编程描述实际就是一个由SOPC Builder系统生成的最小FPGA设计,其作用是对FPGA进行适当配置以实现对Flash的编程。不同的电路板(目标板)往往使用不同的Flash器件,并且Flash与FPGA的引脚连接以及FPGA的型号也不相同,因此每个目标板编程描述都是与具体的目标板相关联的,不能用于其他目标板。目标板提供了Flash Programmer工具对Flash进行编程的全部信息,包括Flash的容量、Flash的引脚连接等。

一个目标板编程描述包含以下信息:每个接到FPGA上Flash器件的参考元件标号;Flash器件在目标板编程描述中的基地址;用于配置FPGA的SOF文件。

目标板编程描述的创建分2步:

①在Nios SDK Shell中使用mk_target_board命令创建一个工程模板;

②使用SoPC Builder对模板进行编辑,从而形成完整的目标板编程描述。

每个目标板编程描述应包含下列元件:NiosII CPU;JTAG_UART接口;本目标板中采用串行配置器件EPCS存储FPGA的配置文件,因此需要Active Serial MemoryInterface(ASMI);Tri-State Bridge(三态桥);CFI接口的Flash;System ID Peripheral;用于存放程序以及作为数据缓冲的On-chip memory。

下面以本目标板为例,介绍创建目标板编程描述的步骤:

①启动NiosII SDK shell;

②运行mk_target_board命令,创建一个目标板Flash编程描述模板(参数name=flash_board,family=cyclone,clock=80,index=1,epcs=U5,buffer_size=2 048,class=flash_programer);

③启动QuartusII软件并打开刚才创建的目标板编程描述工程flash_programer.qPf;

④在QuartusII软件中选择Assignments→Device打开setting对话框,选取FPGA型号,本例为EP1C6Q240C8;

⑤启动SOPC Builder,在Target选项区的Board下拉列表框中选择Unspecified Board,Clock栏的时钟频率取50 MHz,在模板的基础上添加三态桥Avalon Tri-State Bridge和CFI接口的Flash(Flash的参考标号为U5,地址为20位,数据为16位);

⑥选择System Generation选项卡,关闭Simulation选项,然后单击Generate按钮;

⑦当生成完成后,退出SOPC Builder,并返回到QuartuslI;

⑧在QuartuslI中更新原理图,然后添加、链接并命名引脚;

⑨进行引脚分配,确保与FPGA各引脚的连接一致;

⑩编译并保存工程。

编译成功后,目标板编程描述即成功创建。打开SOPC Builder即可在Target选项区的Board下拉列表框中找到该目标板编程描述,本例为flash_board。(该目标板编程描述的顶层图略――编者注)

创建好的目标板编程描述在任何设计的SOPC Builder中都能使用。如果想让该目标板编程描述在其他PC机上使用,将整个设计文件夹拷贝到NiosII安装路径\altera\kits\nios2\components目录下即可。 function ImgZoom(Id)//重新设置图片大小 防止撑破表格 { var w = $(Id).width; var m = 650; if(w

2.2 使用Flash Programmer工具编程Flash

目标板编程描述创建后会在SOPC Builder中的Target选项区的Board下拉列表框中显示出来。本例中所创建的目标板编程描述为flash_board。目标板编程描述创建后就可以在目标板上进行用户SOPC系统的开发了,并能将用户程序编程到Flash存储器件中。采用EPCS器件存储配置文件、Flash器件存储用户程序的SOPC系统的开发流程如图1所示。

wKgaomTLXVmAQNJiAABuUkGKqwA408.jpg

用Flash Programmer工具对Flash编程的步骤如下:

①创建项目,构建SOPC硬件系统。

②启动NiosII,建立SOPC系统的软件然后进行编译、链接。

③在NiosII中选中要进行编程的工程,然后选择Tools→Flash Programmer,打开Flash Programmer窗口。

④在Main选项中,选中Program software project in-to flash memory project,表示要将工程的flash_progra-mer.elf文件写入Flash。对flash_programer.elf文件的编程,在Flash Programmer窗口中并没有存储器和偏移地址的设置。存储器和偏移地址由SOPC Builder中的Reset Address指向的存储器和设置的偏移地址决定。如果将Reset Address指向Flash、偏移地址从0x00开始,那么Flash Programmer就会从Flash的“基地址+0x00”开始烧写数据。如果将Reset Address指向EPCS Controller、偏移地址从0x00开始,那么Flash Programmer就会从EPCS的“基地址+配置数据空间+0x00”开始烧写数据。

⑤选择Target Connection选项卡,在JTAG cable和JTAG device栏中选中当前所用的下载电缆和JTAG器件。

⑥单击Apply按钮,然后单击Program Flash按钮,开始对指定的Flash存储器编程。

当完成Flash编程后,由于当前的EPCS中的配置文件是目标板编程描述的配置文件,所以写入Flash的用户程序并不会马上运行。用户需要给系统重新上电,使FPGA使用EPCS中的配置文件重新配置FPGA,此时用户程序就能正常运行。

结 语

本文针对SOPC系统开发所面临的问题,提出采用外接Flash存储器件是最直接、最有效的解决方法。将FPGA的配置文件存入EPCS、用户程序存人Flash器件,SOPC系统上电后首先进行配置,然后将Flash中的用户程序载入系统RAM,这样不仅解决了存储容量的问题,也解决了Flash存取速度较慢的问题。本文对外接Flash的SOPC系统开发有一定的参考价值。

审核编辑:汤梓红

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

    关注

    1626

    文章

    21665

    浏览量

    601793
  • 芯片
    +关注

    关注

    453

    文章

    50387

    浏览量

    421777
  • sopc
    +关注

    关注

    2

    文章

    247

    浏览量

    62012
  • FlaSh
    +关注

    关注

    10

    文章

    1621

    浏览量

    147744
收藏 人收藏

    评论

    相关推荐

    采用外接Flash存储器件SOPC系统开发的实现

    1 FlashSOPC的作用 FlashSOPC
    发表于 07-01 09:07 883次阅读
    采用外接<b class='flag-5'>Flash</b>存储<b class='flag-5'>器件</b>对<b class='flag-5'>SOPC</b>系统开发的实现

    CPLD控制读取外部配置flash的问题

    本人新手,设计一个cpld的控制电路,需要从flash读取数据传送给其他模块。由于数据量比较大,cpld内部的flash容量不够,需要在外部
    发表于 07-31 11:23

    【AC620 FPGA试用体验】SOPC开发

    的基于Nios II的SOPC系统是一个软硬件复合的系统。开发时,可分为硬件和软件两个部分,但在实际设计过程,有时候所需要的功能既可以用软件也可以用硬件来实现。具体采用什么方式,要根据系统设计要求来权衡
    发表于 08-26 12:48

    基于μClinux的SoPC应用系统设计

    。 1 基于SoPC的嵌入式硬件平台构建 不同于基于处理器或控制器及SoC的嵌入式系统,基于SoPC的嵌入式系统具有可配置的特点,不会包括任何专用外设,而是可根据需要灵活地一片FP
    发表于 12-04 10:44

    SoPC目标板Flash编程设计的创建及应用介绍

    使用Flash来保存在NiosII运行的程序代码、非易失性数据和FPGA的配置数据。因此Flash编程便成为调试完
    发表于 07-29 06:58

    Flash外部配置器件SOPC中有哪些应用?

    FlashSOPC的作用主要表现在两方面:一方面,可用Flash来保存FPGA的配置文件,从
    发表于 08-14 06:46

    并行NOR FlashSOPC开发的4种不同应用,不看肯定后悔

    (简称“1600E”)为背景,结合项目开发经验和参阅相关文献的基础上,介绍了并行NOR FlashSOPC开发的4种不同应用。
    发表于 04-13 06:02

    并行NOR FlashSOPC开发中有哪些应用?

    并行NOR FlashSOPC开发中有哪几种应用?
    发表于 04-27 06:58

    如何使用Flash Programmer工具编程Flash

    FlashSOPC的作用是什么SOPC系统
    发表于 04-30 06:57

    怎么实现SoPC目标板Flash编程设计的创建?

    怎么实现SoPC目标板Flash编程设计的创建?目标板Flash编程设计实际Flash编程
    发表于 04-30 07:06

    并行NOR FlashSOPC开发的应用

    摘要 讨论Intel StrataFlash 3V Memory系列的JS28F128J3D75并行NOR Flash基于Xilinx MicroBlaze的SOPC开发的4种不同
    发表于 03-29 15:09 1850次阅读
    并行NOR <b class='flag-5'>Flash</b><b class='flag-5'>在</b><b class='flag-5'>SOPC</b>开发<b class='flag-5'>中</b>的应用

    局部动态重构SOPC的应用

    提出一种Xilinx平台上基于模块的局部重构设计方法,并将其应用在片上可编程系统SOPC现有Xilinx软硬件平台上,以XC2VP40内嵌的PowerPC处理器内核为基础,通过
    发表于 05-13 18:55 22次下载
    局部动态重构<b class='flag-5'>在</b><b class='flag-5'>SOPC</b><b class='flag-5'>中</b>的应用

    LPC2200_flash内部Flash外部Flash分散加载

    LPC2200_flash内部Flash外部Flash分散加载示例。
    发表于 05-20 16:08 16次下载

    FPGA芯片配置分类及配置方式

    广义的来说,FPGA的配置包括直接使用下载电缆对FPGA器件进行编程、对外部EEPROM和FLASH进行编程、使用MPU对FPGA器件进行编
    的头像 发表于 09-06 09:41 6626次阅读

    TMS320C672x器件配置外部中断

    电子发烧友网站提供《TMS320C672x器件配置外部中断.pdf》资料免费下载
    发表于 10-15 09:58 0次下载
    <b class='flag-5'>在</b>TMS320C672x<b class='flag-5'>器件</b>上<b class='flag-5'>配置</b><b class='flag-5'>外部</b>中断