【ZYNQ的DMA获取FPGA数据处理,零拷贝,DMA方式】

一、方案:

1、AXI-DMA模式1(直接寄存器模式,UIO + DMA双缓存):

【硬件】:PL侧的FPGA的AXI DMA的S2MM接口直接连接到PS侧的HP接口(FPGA数据直接进出DDR,不经过CPU的cache)或者ACP接口(FPGA数据通过SCU进入CPU的cache,硬件自动处理cache一致性问题,不需要软件处理cache一致性问题)。

【驱动】:直接使用UIO驱动模块(generic_uio),/dev/uio0来控制AXI-DMA开启;

dts中reserved-mem开辟dma的一段缓存dma_buff,用于数据接收;

【应用】:mmap(/dev/mem)映射ddr-dma区域;

中断或轮询方式,判断/dev/uio的数据状态(中断方式唤醒read阻塞)来读取传输数据,以及用户态控制DMA的开启。

【优势】:方便用户态快速开发。

2、AXI-DMA模式2(SG模式,自定义驱动和BD数据):

【硬件】:PL侧的FPGA的AXI DMA的S2MM接口直接连接到PS侧的ACP或者HP接口。

【驱动】:编写独立的驱动模块,实现功能:

1、SG模式(数据包长度不固定,链表方式管理内存块)或者非SG模式的DMA空间;

2、dma_alloc_coherent()分配一致性内存空间;

3、mmap()创建用户空间的内存映射;

4、数据状态的通知机制(poll 或者 FPGA硬件握手)

【应用】:mmap映射fd设备。

【优势】:方便驱动中进行复杂控制。

相关推荐
坏孩子的诺亚方舟1 天前
open_prj22_IIC读写EEPROM、AD/DA、PLSYSMON
fpga开发·mpsoc
cjie2211 天前
仿真xilinx库加glbl()的作用
fpga开发
禾刀围玉1 天前
基于FPGA的卷积神经网络实现-方案构想
人工智能·fpga开发·cnn
Aaron15881 天前
全频段 SDR干扰源模块解决方案(星链干扰、LORA无人机干扰)
人工智能·算法·fpga开发·硬件架构·硬件工程·无人机·信息与通信
Kent Gu1 天前
FPGA JTAG确认
fpga开发
北京青翼科技1 天前
基于VITA57.1的2路125MSPS AD采集、2路250MSPS DA回放FMC子卡丨青翼科技100%国产采集卡
fpga开发·数据采集卡·fmc子卡·ad采集卡
小麦嵌入式2 天前
FPGA入门(四):时序逻辑计数器原理与 LED 闪烁实现
linux·驱动开发·stm32·嵌入式硬件·fpga开发·硬件工程·dsp开发
ALINX技术博客2 天前
【黑金云课堂】FPGA技术教程FPGA基础:呼吸灯实验+RAM/ROM IP设计与验证
网络协议·fpga开发·fpga
ALINX技术博客2 天前
【黑金云课堂】FPGA技术教程Vitis开发:PS端IIC通信
fpga开发·fpga
第二层皮-合肥2 天前
线阵相机坏点校正方案
fpga开发