基于pcie链路,实现虚拟网卡,从而使用socket进行通信。
以下是四种实现方案
1. 方案1
发送数据
在 X86 端用户空间通过使用各种各样的网络工具,将数据通过 Socket 接口传递给 Linux 的网络协议层,网络协议层再将 socket 传递的数据进行封包,然后传递给 TUN/TAP 驱动。TUN/TAP 驱动在获得网络层传递下来的数据之后,将数据通过 字符设备,以字节流的方式传递给 TUN/TAP 在用户空间的接口,此时 VnetCard 使 用 VFS 为 TUN/TAP 提供的 open/read 接口从 TUN/TAP 中获得数据流, 获得数据流之后,将多个数据拼在一起放置在 RingBuf 中,当符合某个条件之后, VnetCard 使用 DMA 将 RingBuffer 中准备好的数据经 PCIe 拷贝到 FPGA/ARM 物理内存的指定位置,在拷贝完毕后,VnetCard 通过 queue 告诉 FPGA/ARM 有 新的网络数据已经准备好。至此 X86 端 VnetCard 发送数据过程完毕。
接收数据
VnetCard 通过轮询的方式读取 queue 中的信息,以确定是否有新的数据到达。如果 queue 中有新数据的信息,VnetCard 就从 queue 中读取新数据在 FPGA/ARM 中的 信息,然后调用 DMA 从 FPGA/ARM 物理内存的指定位置上读取数据到