首页
|
新闻
|
新品
|
文库
|
方案
|
视频
|
下载
|
商城
|
开发板
|
数据中心
|
座谈新版
|
培训
|
工具
|
博客
|
论坛
|
百科
|
GEC
|
活动
|
主题月
|
电子展
注册
登录
论坛
博客
搜索
帮助
导航
默认风格
uchome
discuz6
GreenM
»
FPGA/CPLD可编程逻辑
» 基于SPI FLASH的FPGA多重配置(2)
返回列表
回复
发帖
发新话题
发布投票
发布悬赏
发布辩论
发布活动
发布视频
发布商品
基于SPI FLASH的FPGA多重配置(2)
发短消息
加为好友
yuyang911220
当前离线
UID
1029342
帖子
9914
精华
0
积分
4959
阅读权限
90
在线时间
286 小时
注册时间
2014-5-22
最后登录
2017-7-24
论坛元老
UID
1029342
性别
男
1
#
打印
字体大小:
t
T
yuyang911220
发表于 2016-11-23 17:01
|
只看该作者
基于SPI FLASH的FPGA多重配置(2)
FLASH
,
程序
,
而且
,
通信
,
用户
当状态机从用户程序接收到一个触发条件后,会发送一系列如图3所示的IPROG命令。Verilog编码实现状态机的过程中,必须按照图3给出的指令顺序发送这些IPROG命令,否则无法正确的与ICAP核通信。同时这些指令都具有自己特殊的定义而且必须服从Select-MAP数据顺序,否则无法通信。IPROG指令的具体定义及说明如表1所示。
在上述配置指令过程中,第五步Warm Boot StartAddress Register(WBSTAR)指定了满足触发条件的比特流在SPI FLASH中的起始地址,WBSTAR被赋值的地址必须和即将配置的bit流在SPI FLASH中的物理位置相同,否则FPGA就无法从外部读取bit流。WBSTAR被赋值的数值都是提前根据程序的要求计算好的。计算WBSTAR值的时候需要了解WBSTAR寄存器每一位的具体含义,如图5所示。
WBSTAR寄存器共31位,高三位是保留位,RS[1:0]
两位指定了可以多重配置的bit流的个数。RS_TS_B是RS[1:0]的使能信号:0表示Disabled,1表示Enabled.
START_ADDR表示要回读的比特流在外部配置存储器的起始地址。状态机在对WBSTAR进行赋值时,要根据自己选择的bit流个数以及对应各个bit流在外部配置存储器贮存的地址自行计算WBSTAR地址。这里以4个bit流为例说明WBSTAR地址的计算方法,如表2所示。状态机使用的地址是服从SelectMAP数据顺序的地址。FPGA专用配置逻辑在收到IPROG指令后,开始执行内部复位操作(JATG管角和重载控制部分不进行复位操作),擦除板卡上原有的程序,从FLASH芯片中WBSTAR所指向的起始地址开始读取新配置文件完成FPGA的重配置。
2多重配置的实现
Xilinx系列的FPGA需要将后缀名为mcs的内存镜像文件固化到外部配置存储器中,FPGA上电后才能自动加载配置文件。一般的mcs文件只包含一个bit流文件,多重启动的固化文件(。mcs)包含多bit流文件。在将多个bit流整合到mcs文件的过程中,需要指定每个bit流的起始地址,这样FPGA专用配置逻辑才能根据地址找到对应的bit流。首先将用户开发的应用程序和重载控制模块添加到一个工程当中,利用ISE编译软件生成位流文件(。bit)。由于Virtex5系列器件本身的特性,一般情况下生产的bit流文件大约为3 300 KB,而SPIFLASH的容量为32 Mb即4 MB,这个容量无法满足在一个SPI FLASH上贮存多个bit流文件,需要对生成的bit流进行压缩。在用ISE软件生成bit流文件时,当完成了Synthesize-XST以及Implement Design后,执行到最后一步Generate Programming File时,在Process Proper-ties中General Options选项中勾选Enable BitstreamCompression.通过这个压缩设置可以对bit流进行压缩,压缩后的bit流大约在500~600 KB之间,可以满足在一个容量为32 Mb的SPI FLASH上贮存多个bit流文件。其次将需要进行重配置的多个位流文件拷贝至一个工程目录下,有两种方法可以将多个bit流整合为一个mcs文件。第一种方法是通过ISE编译软件的命令行窗口,使用命令行命令将多个位流文件合并为一个FLASH存贮芯片M25P32中烧写的内存镜像文件(。mcs)。第二种方法是用Impact软件创建MultibootSPI FLASH,选择相应的FPGA型号和FLASH的容量以及要包含的bit流的个数(版本的个数)。本文使用第一种方法来将多个bit流文件形成一个内存镜像文件(。mcs)。使用promgen命令的具体格式为:
promgen -spi -pmcs -oMulitBoot.mcs-s4096 -u0rev0.bit -u100000rev1.bit -u200000rev0.bit -u300000rev0.bit命令中各参数的说明如下所述。-spi:表示生成的mcs文件要固化到SPI FLASH中;-p mcs:生成文件的格式是mcs格式;-o ML507.mcs:要生成的文件名,可以根据需要修改;-s 4096:定义了外部存储器的容量,4096表示32 Mb;- u 0rev0.bit:表示名字为rev0的比特流文件在外部存储器的起始地址为0;-u 100000 rev1.bit:表示名字为rev1的比特流文件在外部贮存的起始地址为100000.在生成mcs文件后,通过IM-PACT软件将mcs文件固化到SPI FLASH中。
FPGA上电自动从外部SPI FLASH加载一个初始化的bit流,当需要执行新的程序时,会根据触发条件以及启动地址重新配置。在实验中,通过PC机串口终端发送指令当做触发条件实现多重配置。在实际应用中,还可以根据具体硬件实现,采用其他通信方式传送控制指令来进行触发。
收藏
分享
评分
继承事业,薪火相传
回复
引用
订阅
TOP
返回列表
电商论坛
Pine A64
资料下载
方案分享
FAQ
行业应用
消费电子
便携式设备
医疗电子
汽车电子
工业控制
热门技术
智能可穿戴
3D打印
智能家居
综合设计
示波器技术
存储器
电子制造
计算机和外设
软件开发
分立器件
传感器技术
无源元件
资料共享
PCB综合技术
综合技术交流
EDA
MCU 单片机技术
ST MCU
Freescale MCU
NXP MCU
新唐 MCU
MIPS
X86
ARM
PowerPC
DSP技术
嵌入式技术
FPGA/CPLD可编程逻辑
模拟电路
数字电路
富士通半导体FRAM 铁电存储器“免费样片”使用心得
电源与功率管理
LED技术
测试测量
通信技术
3G
无线技术
微波在线
综合交流区
职场驿站
活动专区
在线座谈交流区
紧缺人才培训课程交流区
意见和建议