积分规则 网站地图 帮助中心    
嵌入式软件 单 片 机 DSP 存储器 传感控制 光电显示
嵌入式硬件 CPLD/FPGA SOPC AD/DA 接口电路 模拟设计
I C设计 通信产品 汽车电子 电源产品 消费电子 数控系统
工业控制 军工/航天 安防产品 医疗电子 计算机外设 测试测量
供应 I C
求购 公司库

  IC 求购 销售 公司 论文 DATASHEET 参考设计 论坛
当前位置: 电子技术 >> SOPC >> 应用论文
  相关分类: 相关文章 | 应用论文 | 新产品 | 下载 |
Flash外部配置器件在SOPC中的应用
 
作者:中国科学院西安光学精密机械研究所 沈满德 张敏 张法全 陈良益   来源:《单片机与嵌入式系统应用》    点击数:135   更新时间:2008-7-15
您可以添加到网摘 让更多人关注此文章:

    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目录下即可。


2.2 使用Flash Programmer工具编程Flash


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







用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系统开发有一定的参考价值。

[1]



相关文章
· flash接口电路的实现[218]
· DSP和Flash接口技术的实现[244]
· NAND Flash控制芯片低头[183]
· 基于嵌入式多核SoPC平台的说话人识别系统应用研究[139]
· 基于Linux的SoPC应用系统设计[130]
热门评论排行
·VHDL设计中电路简化问题的
·江苏嵌入式Linux教育培训
·锐极LINUX驱动培训班定于
·基于实时操作系统μC/OS-
·ARM嵌入式系统基础教程(N

文章评论
    没有任何评论
*只显示最新10条评论。评论内容只代表网友观点,与本站立场无关。更多评论
发表评论
  * 请先[登陆]再进行评论,谢谢。
评分: 1分 2分 3分 4分 5分
内容: *
发帖须知:
一.所发文章必须遵守《互联网电子公告服务管理规定》;
二.严禁发布供求代理信息,公司介绍,产品信息等广告宣传信息;
三.严禁恶意重复发帖;
四.严禁对个人,实体,民族,国家等进行漫骂,污蔑,诽谤。
 
热点新闻 [更多]
 
赛普拉斯为用于机器视觉与运动分析应用
赛普拉斯针对机器视觉与全息数据存储应
金融危机来袭 台湾LED产
半导体市场环境恶化 安森美
Vishay 的新型&nb
Intersil推出采用小尺寸QFN
富士通微电子携手西安电子科技大学成立
纤巧和高压的 LDO&nb
华为计划收购北电业务 华为
华为计划收购北电业务 华为
 
热门下载 [更多]
 
[ PCB设计] Protel99教程下载
[ ] 手把手学单片机20个例
[ ] 单片机做的智能台灯
[ ] 单片机入门书
[ ] linux系统移植开发文档
[ ] IC卡的读写程序
[ ] 8051单片机C语言彻底应用
[ 常用软件] 555定时器电路设计软件V1.2
[ 常用软件] 51定时器计算软件
[ ] ARM处理器应用开发4步骤
 
论坛新帖 [更多]
 
四折批发各种数码相机,摄相机等...
最低价销售各种品牌手机...
震撼出售各种品牌笔记本电脑等!...
IC design 的流程...
电子工程师,别拿一分钱不当回事...
新款安全多用途非接触式芯片(T...
关于ARM启动的一篇文章!...
Linux网络设备驱动编程...
linux文件系统基础知识...
求奇想达QXD-DM642开发...

 
赞助商 [更多]
 

ICP许可证号:[粤 05056597]
联系电话:010-82517432 82517615 传真: 010-82517615

版权所有 Copyright © 2006 嵌入式技术网