近些年来,由于其灵活可配置性及成本的降低,现场可编程门阵列(Field Programmable Gate Array,FPGA)在嵌入式系统中应用越来越广泛,不论产品的初期研发或是后期维护都不可避免地需要频繁更新FPGA程序。传统的JTAG方式更新FPGA程序的方式是通过开发软件将需固化的文件写入Nor Flash器件。当系统很复杂且需要更新的FPGA数量较多时,JTAG方式更新FPGA程序则费时费力且还需拆结构。若在FPGA内部通过逻辑代码搭建一Flash控制器实现对Flash器件的读写操作,即可并行实现系统内每片FPGA对配置文件的在线更新,大大缩短程序固化时间。本文依托于Xilinx公司的FPGA和Spasion公司的Nor Flash,详细介绍了Flash控制器设计和在线加载功能的实现方法。
1 FPGA配置方式
以Xilinx Virtex6 系列FPGA为例,对配置文件的加载方式有串行Flash、并行Flash、JTAG方式等,其中最常用的是并行Flash方式(Byte Peripheral Interface Parallel Flash Mode,BPI),其配置模式如图1所示。
![07a4a8dce2e55f47d5d0481a574b7fce.gif](https://i-blog.csdnimg.cn/blog_migrate/a30d8f8e3f958970147446c826c7b5c1.gif)
一种实际的FPGA与Nor Flash硬线连接方式如图2所示。
![47e3bb2f5fd5ab8b9232cf922018c2bb.gif](https://i-blog.csdnimg.cn/blog_migrate/58d3cde612d93c26716112dd389e293e.gif)
无论是通过JTAG方式还是通过软件操作