如何将软硬件程序固化进串行Flash芯片EPCS
在FPGA芯片的使用中,软硬件程序可通过JTAG口下载进FPGA芯片中,程序可立即执行,并且在掉电后程序丢失。为了避免这种情况的出现,可使用串行FLash芯片EPCS系列,EPCS系列芯片有EPCS1、4、16、128,本人使用的是EPCS16,提供16M的ROM空间。
软硬件程序可通过JTAG口下载进EPCS芯片中。它实际上是执行EPCS控制器的片内ROM的代码(即bootloader),把EPCS中程序的搬到RAM中执行。FPGA的配置数据从EPCS偏移为0的地址开始存放,紧挨着配置数据后面是一个32位的整数,指示程序段的长度,接着是一个32位的地址,指示程序执行时该程序段的地址,我们把这个长度和地址一起称为"程序记录","程序记录"随后就是程序段映象。为了达到上电后程序能立即运行,必须在Qsys系统中,将程序的复位地址设为EPCS的地址,这样上电后才能执行程序。
固化程序有两种方法,一种是使用NIOS II IDE软件中的Flash Programmer,具体步骤如下:
另一种是将软硬件的sof、elf格式的文件先转化为flash格式的文件,再将flash格式的文件转换为Intel的二进制代码hex格式的文件,最后通过Quartus II 软件中的Convert Programming Flies将两个hex合并并转换为jic格式的文件,将jic格式文件下载进EPCS即可。
第一步是先编译生成软硬件的文件hwled.sof和swled.elf,并将两个文件放在一起。因为本人使用的是Quartus II 13.0,硬件编译时生成的hwled.sof,文件是放在outputfile文件夹中的,软件编译是放在自己设置的software文件夹中,并建立了以led为名的软件程序。
第二步找到NIOS II Command Shell命令栏。
第三步执行一些command命令
这两部分可对比着看。还有一些有用的信息
http://www.alteraforum.com.cn/showtopic.aspx?topicid=704&page=end