FPGA的多重加载实际运用详解.doc

上传人:白大夫 文档编号:3251937 上传时间:2019-08-06 格式:DOC 页数:2 大小:14KB
返回 下载 相关 举报
FPGA的多重加载实际运用详解.doc_第1页
第1页 / 共2页
亲,该文档总共2页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《FPGA的多重加载实际运用详解.doc》由会员分享,可在线阅读,更多相关《FPGA的多重加载实际运用详解.doc(2页珍藏版)》请在三一文库上搜索。

1、FPGA的多重加载实际运用详解如今,随着FPGA工艺的进步,性能提升和成本缩减均得到极大的改善,这使得FPGA芯片的使用越来越广泛。因此为了达到降低系统维护和升级的成本,通常我们都会通过网络传送最新的下载文件,让用户在现场直接将文件下载到FPGA中进行远程的升级处理。然而,一旦下载文件是错的,那么系统轻则功能出错,重则直接死机不工作。为了防止这种情况发生给用户带来重大影响或者损失,Xilinx提供了FPGA的多重配置操作功能。1.何为多重配置FPGA多重配置允许动态进行多个下载文件之间的切换,当引导配置过程中检测到出错时,FPGA会触发一个回退标志确保一个已知的好的文件可以被加载进来。具体如下

2、图所示:简而言之,就是你的.mcs文件里包含有两个或更多的下载文件,然后地址0的位置开始存放一个可用的下载文件(多数是升级前那个旧的文件),后面的地址(ADDR_1)存放你将要更新的文件。当下载时,FPGA会先从ADDR_1读取更新的文件,若这个过程发生错误的话就会回到地址0,读取之前的文件,确保设备仍能正常工作。2.多重配置的使用Xilinx的多重配置功能除了更新文件外,也可以进行多任务的切换调度处理。基于这个功能,只要Flash够大,是可以存放好多个下载文件的。当遇到FPGA资源较小,且多个功能之间是独立不干扰的话,有时候可以通过外部控制,在需要不同功能时,进行文件切换下载。比如一个设备需

3、要做到ABCD四个功能,且ABCD各自应用于不同场合,之间没有数据往来,互不干扰。如果这时FPGA的资源只能够实现ABCD中的一种功能或者两种,那么我们就可以做出四个不同的bit文件分别实现ABCD四种功能并合并成一个.mcs文件下载到Flash中。当在需要A功能的场合,我们可以使用按键或者上位机进行配置,让FPGA加载A功能的下载文件,实现A功能。同理,在只需要BCD的场合也是这样,如此可以大大节省FPGA的资源。3.多重配置的流程FPGA内部有一个ICAP核,可对程序加载进行预配置,预配置处理可在.v代码中处理并随之生成.bit文件。如果不在代码处理,则为默认配置。Xilinx FPGA的

4、多重配置流程如下图所示,具体可参考官方文档 xapp1247 。其中可用文件存放在起始地址为0处;更新文件存放在起始地址为A1处。上电后,FPGA会进入Flash的0地址,检测配置寄存器中的WBSTAR和IPROG指令(.v里进行配置)。如果WBSTAR地址指向A1,且IPROG的指令正确,FPGA会跳到A1处读取并加载文件。如果A1处的WBSTAR地址为0,且没有IPROG指令,则加载此处的文件。如果在加载更新文件过程中发生错误,FPGA便会跳到地址0处,重新加载确保可用的那个文件。IPROG的指令表如下所示:对于IPROG的指令配置,必须按照这个顺序进行,一旦数据不对或者顺序不对,FPGA便不会对更新文件进行加载。4.结语在实际使用中FPGA的多重加载是非常有帮助的,灵活的使用能够避免很多现场的尴尬,也节省了很多后期技术支持的成本。下一节将介绍如何进行代码的多重配置处理与使用。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 其他


经营许可证编号:宁ICP备18001539号-1