(文章来自作者维护的社区微信公众号【虚拟化云计算】)
DPDK中几种Exception Path方式
在DPDK中经常看到一个词,exception path,它是什么?
DPDK使用环境中,物理网卡收到的报文不再进入内核协议栈,而是直接到达DPDK应用。但是再有些场景中,用户希望把报文(如控制报文)再次发送至内核协议栈进行处理。报文从用户空间再次进入内核的过程在DPDK中称为exception path。
DPDK支持几种方式让用户空间的报文重新进入内核协议栈:

1.TAP/TUN设备
可以使用内核提供的TAP/TUN设备,这种设备的使用需要使用系统调用,并涉及到copy_to_user()和copy_from_user()的开销。
使用virtual TAP设备实现exception path的流向图:
DPDK中几种Exception Path方式
2.DPDK Kernel NIC Interface(KNI)
DPDK提供了KNI接口用于提高用户态和内核态之间报文的处理效率。KNI是通过内核模块构造了一个虚拟网络接口,并且通过FIFO和用户态的DPDK应用交换报文。
正如DPDK官方所讲,使用DPDK KNI的好处是:
  • 比现有的Linux TUN / TAP(通过消除系统调用和copy_to_user()/ copy_from_user()操作)。
  • 允许使用标准Linux网络工具(如ethtool,ifconfig和tcpdump)管理DPDK端口。
  • 允许与内核网络协议栈的交互。
DPDK中几种Exception Path方式

3.virtio-user+vhost-net
DPDK提供了virtio-user虚拟设备,使用它与现有的vhost-kernel方案配合来实现exception path。需要内核中vhost.ko和vhost-net.ko两个模块。
DPDK中几种Exception Path方式
启动virtio-user,会操作/dev/vhost-net创建一个内核态的虚拟设备tap。从DPDK收到的包进入到virtio-user,通过vhost-kthread进入到tap设备,tap设备支持内核协议栈。从而实现了用户态和内核态的数据交互

本文图片全部来自DPDK官方网站www.dpdk.org


============================================================
关注微信公众号【虚拟化云计算】,阅读更多虚拟化云计算知识,纯技术干货更新不停。
DPDK中几种Exception Path方式

相关文章:

  • 2022-12-23
  • 2021-12-19
  • 2021-05-26
  • 2022-12-23
  • 2022-12-23
  • 2022-01-07
  • 2021-07-15
猜你喜欢
  • 2022-01-03
  • 2021-08-10
  • 2021-09-24
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
相关资源
相似解决方案