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的流向图:

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端口。
  • 允许与内核网络协议栈的交互。


3.virtio-user+vhost-net
DPDK提供了virtio-user虚拟设备,使用它与现有的vhost-kernel方案配合来实现exception path。需要内核中vhost.ko和vhost-net.ko两个模块。

启动virtio-user,会操作/dev/vhost-net创建一个内核态的虚拟设备tap。从DPDK收到的包进入到virtio-user,通过vhost-kthread进入到tap设备,tap设备支持内核协议栈。从而实现了用户态和内核态的数据交互

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


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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值