FPGA固件如何进行在线升级?
扫描二维码
随时随地手机看文章
. FPGA也能在线升级?
以最常用的Xilinx和Altera公司的FPGA为例,这两家公司的FPGA固件通常保存在外部的一片SPI Flash芯片中,常规的下载方式是使用专用的下载器,如Xilinx的Platfom Cable USB或者USB Blaster,通过JTAG将程序文件下载到外部的Flash芯片中,程序固化的过程本质上是对片外的Flash芯片进行固件更新。由此我们可以知道,当FPGA产品量产,需要大批量进行程序烧写时,只需要使用SPI Flash烧写器通过烧录座对Flash芯片进行烧写,烧写完成之后再焊接到板子上。本文介绍如何不通过JTAG口,不使用专用下载器,仅仅通过普通管脚来进行固件更新,分享实现思路和设计方法,暂时还没有示例工程。以Xilinx FPGA通过串口进行固件升级为例,所需要的软硬件为:- FPGA板卡(含外部SPI Flash),如Spartan-6系列XC6SLX9 FPGA M25P16 SPI Flash
- 专用的PC串口上位机,也可以使用通用的串口助手,自定义的串口助手会增强通讯的稳定性和可靠性
- USB-TTL串口模块,用于FPGA和PC进行通讯
- 专用的FPGA固件代码
. FPGA程序文件结构
在进行设计之前,我们需要先了解一下FPGA的程序文件格式,以Xilinx FPGA程序文件为例,主要有两种文件格式:Bit文件和Mcs文件。前者Bit文件通常用于调试,Bit文件会下载到FPGA芯片内部RAM空间,掉电程序会丢失,因为FPGA开发阶段需要频繁的进行程序的擦除烧写操作,这样的好处是程序下载速度非常快,不会消耗Flash芯片的寿命。后者Mcs文件通常用于最后的程序发布,产品量产时使用,它可以由Bit文件文件生成,在生成过程中需要指定外部SPI Flash的存储大小。关于这两种文件格式的介绍可以查看以下文章:- Xilinx Bit文件格式详解
- Xilinx MCS(HEX)文件格式详解
. 通讯协议设计
为了保证升级的稳定性,我们不使用通用的串口调试助手,通过自定义通讯协议和串口上位机,可以提高升级的可靠性。串口通讯波特率通常为几百KBps,而SPI控制器读写频率通常为几十MHz,为了能将数据完整有序的接收、保存、写入,我们需要先将串口接收的数据存储到FPGA内部的FIFO中,作为缓存和跨时钟域处理。串口上位机解析出Mcs文件中的数据部分,启动传输前,先发启动命令,然后发送数据帧,最后发送结束命令。数据帧包括:帧头 256字节数据 CRC校验值。FPGA接收到数据之后,对数据进行校验,校验正确回复给上位机一个正确响应信号,校验错误回复错误响应信号,串口上位机接收到正确的响应信号后,继续发下一个数据帧,接收到错误的响应信号后,重复发上一帧数据,直到所有的数据发送完成,最后发送一个结束命令。这样就简单定义了一个发送-响应机制的通讯协议。. SPI芯片数据写入
SPI数据的写入有两种方式:- 每接收到一帧数据之后,对SPI执行一次写256字节操作
- 所有的数据接收完成后,一次性将数据写入外部的SPI Flash芯片。
. SPI芯片擦除和校验
同理,为了保证程序能正常运行,在数据接收完成后,数据写入前,我们需要对SPI芯片执行全片擦除指令,这个擦除时间一般会比较长,通常和存储大小相关,擦除完成之后,再执行写入,写入完成之后,如果有必要,可以对指定存储区间进行数据回读,和接收到的数据进行比较,从而达到校验的目的。. 总结
升级模块可以独立于应用逻辑,作为一个单独的功能,不会影响正常的代码逻辑。本文只是提供一个大致实现思路,如果要是做得非常完美,工作量还是很大的。当然串口只是一种升级方式,还可以通过SD卡升级,网口升级,USB升级,WiFi升级,外部控制器(如STM32)对FPGA进行程序更新等等。. 更多
- 如何写出易于维护的Verilog代码
- FPGA能进行断点调试吗?
- 基于STM32的USB BlasterFPGA下载器
- 低成本、开源的Xilinx HS-2下载器
- 一文看懂I2C协议
- 一文看懂SPI协议
- 一文看懂Modbus协议
- 串口通讯协议及其FPGA实现
- 单工、半双工、全双工、异步和同步的区别