【PCIe】P2P DMA

PCIe P2P (peer-to-peer communication)是PCIe的一种特性,它使两个PCIe设备之间可以直接传输数据,而不需要使用主机RAM作为临时存储。如下图3的走向

比如EP1要发送和数据给EP2,操作流程如下:

  1. 打开EP1的dma控制器;--client侧

2.src=EP1的内存地址,dst=EP2的BAR地址空间(provider),EP2的BAR地址一般会与自己的某段内存空间有一个映射关系,也就是将EP2的bar暴漏给了EP1去操作。

3.开启dma传输,将EP1的ddr数据搬运到EP2 bar空间

思考:

Why would you want peer to peer DMA?

没有CPU开销或同步的处理管道;

节省数据流行程

附:

Providers -- Expose P2P resources to other drivers

◢ Clients -- Make use of P2P resources via DMA

◢ Orchestrators -- Enables data flow between clients and providers

◢ Memory is allocated on the client side

接口参考:

PCI Peer-to-Peer DMA Support --- The Linux Kernel documentation

相关推荐
东成20222 天前
ch340驱动的串口可以寻址DMA吗
串口·dma·ch340
酿情师3 天前
区块链原理与技术03:P2P 网络概述与区块链中的 P2P 网络(区块链网络与跨链操作01)
网络·区块链·p2p
SoStraw10 天前
基于P2P开发一个聊天桌面软件
p2p·quic·文件共享·打洞·通信·文件传输·聊天软件
SoStraw11 天前
基于p2p通信开发一个聊天通信软件
p2p·加密·quic·打洞·穿透·传输·聊天
9527华安17 天前
FPGA实现PCIe数据通信培训课程,提供工程源码+视频教程+FPGA开发板
fpga开发·pcie·视频教程·培训
CinzWS20 天前
DMA控制器 - 沉默的加速器:驾驭通道仲裁、传输握手与内存一致性的双刃剑
arm开发·dma·嵌入式
linkedbyte22 天前
P2P直播系统
音视频·p2p·obs·obs直播·pcdn
爱吃芹菜炒肉23 天前
Chapter 16: Power Management
服务器·c语言·网络·tcp/ip·pcie
NQBJT24 天前
DMA —— 让 CPU “偷懒”的数据搬运工
stm32·单片机·dma·嵌入式