vpp之node节点分析二: qs类型

本文探讨了VPP中QS节点的工作原理及其优化方式。QS节点适用于数据包基本走相同节点的情况,通过一次性获取所有数据包地址并利用vlib_buffer_enqueue_to_next函数统一发送,配合向量指令(如SSE2)实现高效处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

qs类型适用于进入当前node处理的数据包都转发到下一个相同的node,vpp通过向量指令进行优化,提高了处理性能

1.定义该node的下一个node

 可以看出和dual是一样的,一点点区别是模板默认下一个节点是error-drop 也就是丢弃

2.数据包如何转发

 

 

 除了最后一个函数vlib_buffer_enqueue_to_next,其他和dual都是相同的

3.qs和dual的区别

其实区别也能明显看出,qs类型的节点不再是一个一个获取数据包的地址,而是一开始就用vlib_get_buffers函数获取所有数据包的地址,最后通过vlib_buffer_enqueue_to_next函数统一把数据包发走

最大的差别就在vlib_buffer_enqueue_to_next函数

通过源码可以看出

 

 从这些代码可以看出,vpp是通过向量指令对于相同流程的数据包做了指令集优化,现在主要是SSE2指令集优化,如果不了解的可以看看这篇文章C/C++指令集介绍以及优化(主要针对SSE优化)

这样就可以理解了前面说的为什么qs是数据包基本走相同节点的

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值