System ACE的解决方案需要购买CF存储卡和专用的ACE控制芯片,增加了系统搭建成本和耗费了更多空间,而且该方案只能实现最多8个配置文件的切换,在面对更多个配置文件时,这种方案也无能为力。但若要开发System ACE的替代方案,则需要选择更合适的可反复编程存储器,并且需要选用合适的传输协议接口来下载配置码流。通过串口或并口来下载配置码流速度太慢,不能满足应用中快速下载的需要;通过USB接口来下载配置码流则需要专门的控制芯片,增加了系统设计的成本[23]。
① RS232接口模块接收来自串口工具的配置文件地址及重配置信号,配置文件地址译码后得到对Flash存储器进行各种操作时的起始地址,重配置信号则用来触发FPGA配置文件的切换。
② JTAG模块包括JTAG接口模块、数据缓存模块及烧写控制模块。JTAG接口接收JTAG下载线上的JTAG指令和数据后,若为FERASE或FPGM指令则向烧写控制模块发送擦除或烧写信号,若为FDATA0指令则接收TDI上的串行数据并存入数据缓存模块中。数据缓存模块利用片内BRAM来实现,可存放一帧配置码流。烧写控制模块接收到擦除信号后,产生擦除命令和操作地址并发往状态选择模块;接收到烧写信号后,从数据缓存模块读取配置码流,产生的写命令、操作地址发往状态选择模块,操作数据则直接发往Flash控制器。
③ FPGA配置模块接收到来自RS232接口模块的起始地址和重配置信号后,先向待配FPGA器件发送初始化信号,等待初始化完成后向状态选择模块连续发送读命令和操作地址,并利用从Flash控制器返回的配置码流来配置FPGA器件。