原因

Xilinx FPGA固化FPGA程序到FLASH时,可以选择使用MCS或者BIN格式,BIN是纯二进制文件,MCS是ASCII格式的文本文件。
MCS是Intel早期为MCS系列 II ISIS-II 系统 代码固化存储指定的文件格式,成为了普遍遵循的标准,Xilinx 的MCS文件也一样,格式大体如下,文件由行组成,每一行由6部分组成:

  • Start code 起始码
  • Byte count 字节长度
  • Address 起始地址
  • Record type 当前记录数据类型
  • Data 数据
  • Checksum 校验码

从上面的组成可以看出,MCS每一行均有起始地址和数据长度信息,而FLASH内部一些无需更新的区域就可以在BIT转换为MCS文件时选择忽略,那么就不需要向FLASH写入,而BIN文件是二进制文件,无论信息是否冗余均需要刷新到FLASH,这实际上增大了BIN文件的大小,降低了写入数据的速度。

建议

因此,建议在使用JTAG烧录时,选择MCS文件格式。如果是通过其它方式更新FLASH内容,比如ZYNQ的PS、或者PCIe(用于实现不关机、不插JTAG情况下的更新),则可以选择BIN格式,因为BIN文件不需要解析,直接读取后写入即可。