Xilinx Dual Quad Flash SPI加载方式下的文件处理

Xilinx Dual Quad Flash对应的加载模式有两种:

(1)Dual parallel Quad SPI

(2)Dual stacked Quad SPI

由于此加载方式为X8位宽,分别对应两片X4的Flash芯片,那么Vivado生成的bin文件是按照什么规律烧写至2片Flash芯片中呢?

笔者此前认为Dual parallel Quad SPI模式下是将原始bin文件中的单个字节进行切割,实际不然。

本篇文章将就此问题进行说明,后续可以自行开发切割工具 or 使用Xilinx提供的xsct/Bootgen 进行bin文件的正确切割和烧写。

1 Xilinx Dual-Stacked Quad SPI模式

1.1 硬件连接

参考Xilinx官方手册,可以找到Dual-Parrallel Quad SPI的硬件连接方法

|--------------------------------------|-------------------------|
| FPGA | Flash |
| QSPI0_CLK QSPI0_IO3:0 QSPI0_CS_b | Quad SPI0 Device(Lower) |
| QSPI0_CLK QSPI0_IO3:0 QSPI1_CS_b | Quad SPI1 Device(Upper) |

1.2 Flash文件映射关系

映射关系如下:

|-------------|---------------|-------------|
| Lower.bin | 原始.bin | Upper.bin |
| Addr0 1Byte | Addr0 1Byte | |
| ... | ... | ... |
| AddrN 1Byte | AddrN 1Byte | |
| | AddrN+1 1Byte | Addr0 1Byte |
| | ... | ... |
| | ... | ... |

这里就最简单的情况进行分析,假设单片Flash的容量为16MB

(1)原始bin文件小于或等于16MB时,那么原始bin文件全部烧写至Lower Flash;

(2)原始bin文件大于16MB时,那么原始bin文件0地址开始的16MB内容写入Lower Flash,原始bin文件16MB之后的内容写入Upper Flash

(3)Flash的容量还可以为16/32/64/128MB

2 Xilinx Dual-Parallel Quad SPI模式

2.1 硬件连接

参考Xilinx官方手册,可以找到Dual-Parrallel Quad SPI的硬件连接方法

|--------------------------------------|-------------------------|
| FPGA | Flash |
| QSPI0_CLK QSPI0_IO3:0 QSPI0_CS_b | Quad SPI0 Device(Lower) |
| QSPI1_CLK QSPI1_IO3:0 QSPI1_CS_b | Quad SPI1 Device(Upper) |

2.2 Flash文件映射关系

映射关系如下:

|-------------|-------------|-------------|
| Lower.bin | 原始.bin | Upper.bin |
| Addr0 1Byte | Addr0 1Byte | |
| | Addr1 1Byte | Addr0 1Byte |
| Addr1 1Byte | Addr2 1Byte | |
| | Addr3 1Byte | Addr1 1Byte |
| Addr2 1Byte | Addr4 1Byte | |
| | Addr5 1Byte | Addr2 1Byte |
| ... | ... | |
| | ... | ... |

基于以上关系,我们可以分别将Lower.bin烧入Lower Flash中,将Upper.bin烧入Upper Flash中,完成Dual-Parallel Quad SPI模式下程序的正常加载。

相关推荐
坏孩子的诺亚方舟7 天前
FPGA系统架构设计实践15_高云Arora V系列时钟体系
fpga开发·系统架构
FPGA小徐7 天前
入门 CNN 结构全解析|从流程图理论到 FPGA Verilog 硬件实现(含习题带讲解)
fpga开发
FPGA小徐7 天前
FPGA 数字信号处理:并行 FIR 与串行滤波器设计原理、对比与完整 Verilog 实现
fpga开发
Saniffer_SH8 天前
【高清视频】Gen6 服务器还没到,Gen6 SSD 怎么测?Emily 现场演示三种测试环境
人工智能·驱动开发·测试工具·缓存·fpga开发·计算机外设·压力测试
zlinear数据采集卡8 天前
双核架构深度解析:ARM+FPGA如何让数据采集卡实现500Ksps高性能?
arm开发·fpga开发·架构
9527华安8 天前
FPGA实现GTH Transceivers Wizard传输2路视频,基于aurora 8b10b编解码架构,提供4套工程源码和技术支持
fpga开发·gth·aurora 8b10b·transceivers
FPGA小徐9 天前
FPGA 数字信号处理(二):并行 FIR 滤波器的 Verilog 全流程设计与实现
fpga开发
国科安芯9 天前
基于AS32S601ZIT2型抗辐照MCU的商业航天卫星姿态确定与控制系统研究
单片机·嵌入式硬件·安全·fpga开发·架构·risc-v
ALINX技术博客9 天前
【黑金云课堂】FPGA技术教程FPGA基础:I2C 总线通信技术
fpga开发·i2c
Hello-FPGA9 天前
Xilinx KU040 FPGA Camera Link 图像采集
c++·fpga开发