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修改,会导致数据混乱
相关推荐
雨洛lhw12 小时前
24bit AD采样高效数据打包方案解析
fpga开发·数据打包方式·ddr突发读写注意事项
XiaoChaoZhiNeng15 小时前
Xilinx Vivado18.3 Modelsim 库编译与仿真
fpga开发
Flamingˢ18 小时前
FPGA 显示系统学习路线:从 VGA 到 RGB TFT
学习·fpga开发
tiantianuser20 小时前
RDMA设计37:RoCE v2 子系统模型设计
fpga开发·rdma·高速传输·cmac·roce v2
8K超高清20 小时前
博冠8K广播级讯道摄像机获国际设计大奖
网络·算法·fpga开发·接口隔离原则·智能硬件
ooo-p1 天前
FPGA学习篇——Verilog学习之“呼吸灯”
学习·fpga开发
雨洛lhw1 天前
STFT性能测试记录笔记(verilog )
fpga开发
runningshark2 天前
【FPGA】频率计(等精度测量法)
fpga开发
坏孩子的诺亚方舟2 天前
FPGA设计基于团队的最佳实践0
fpga开发·团队设计
FPGA_小田老师2 天前
FPGA例程(7):UART串口接收程序--状态机的编写
fpga开发·uart·状态机·串口接收·uart_rx·串口程序·115200bps