PCIE BAR空间解读(六)

PCIE BAR空间解读(六)

文章目录


先举个例子:FPGA 负责采集一段数据,这段数据采集好后我们要把他们传到 CPU 内存中的一段地址上,这段地址需要由CPU 动态获取,然后 CPU 写到 BAR0。FPGA 从 BAR0 中读取到传输地址,完成最终的数据传输

PCIE完成流程如下:

这是一个典型的 "BAR寄存器作为控制通道 + DMA引擎完成数据传输" 的应用场景。下面分步骤详细解析:


场景理解:BAR0作为"传输地址指针"

在这个设计里,BAR0并不是直接传输数据的"货车",而是一个存放"送货地址"的告示牌。CPU把目标内存地址写到BAR0,FPGA的DMA引擎读取这个地址后,把采集的数据"快递"过去。


完整工作流程

FPGA采集模块 FPGA DMA引擎 BAR0寄存器 系统内存 主机CPU FPGA采集模块 FPGA DMA引擎 BAR0寄存器 系统内存 主机CPU 1. 初始化阶段 2. 数据采集阶段 3. 地址获取阶段 4. DMA传输阶段 5. 中断通知阶段 分配DMA缓冲区(物理地址:0x2A00_0000) 写地址 0x2A00_0000 (通过PCIe Memory Write TLP) 启动采集传输命令 采集数据就绪(FIFO满) 读地址 0x2A00_0000 (FPGA内部逻辑读取) 发起PCIe写请求,地址=0x2A00_0000 传输完成确认 发送MSI中断 从0x2A00_0000读取处理数据


  • 为什么这样设计?

优点:

  1. 灵活性:CPU可动态分配内存,适应不同大小的采集任务
  2. 标准化:符合PCIe规范,驱动程序通用性强
  3. 性能:DMA直接访问主机内存,无需CPU拷贝数据(零拷贝)
  • ⚠️ 注意事项
    . 原子性问题:如果传输地址在DMA过程中被CPU修改,会导致数据混乱
相关推荐
坏孩子的诺亚方舟5 天前
FPGA系统架构设计实践15_高云Arora V系列时钟体系
fpga开发·系统架构
FPGA小徐6 天前
入门 CNN 结构全解析|从流程图理论到 FPGA Verilog 硬件实现(含习题带讲解)
fpga开发
FPGA小徐6 天前
FPGA 数字信号处理:并行 FIR 与串行滤波器设计原理、对比与完整 Verilog 实现
fpga开发
Saniffer_SH6 天前
【高清视频】Gen6 服务器还没到,Gen6 SSD 怎么测?Emily 现场演示三种测试环境
人工智能·驱动开发·测试工具·缓存·fpga开发·计算机外设·压力测试
zlinear数据采集卡7 天前
双核架构深度解析:ARM+FPGA如何让数据采集卡实现500Ksps高性能?
arm开发·fpga开发·架构
9527华安7 天前
FPGA实现GTH Transceivers Wizard传输2路视频,基于aurora 8b10b编解码架构,提供4套工程源码和技术支持
fpga开发·gth·aurora 8b10b·transceivers
FPGA小徐8 天前
FPGA 数字信号处理(二):并行 FIR 滤波器的 Verilog 全流程设计与实现
fpga开发
国科安芯8 天前
基于AS32S601ZIT2型抗辐照MCU的商业航天卫星姿态确定与控制系统研究
单片机·嵌入式硬件·安全·fpga开发·架构·risc-v
ALINX技术博客8 天前
【黑金云课堂】FPGA技术教程FPGA基础:I2C 总线通信技术
fpga开发·i2c
Hello-FPGA8 天前
Xilinx KU040 FPGA Camera Link 图像采集
c++·fpga开发