当前位置: 首页 > news >正文

vpp怎么写node

VPP(Vector Packet Processing)是一个高性能的数据平面开源项目,用于构建网络功能虚拟化(NFV)和软件定义网络(SDN)解决方案。它由Cisco开发,并在Apache 2.0许可下发布。

在VPP中,节点(Node)是数据包处理的基本单元。每个节点都执行一些特定的功能,并且可以相互组合形成流水线,完成复杂的数据包处理任务。以下是如何编写一个基本节点的步骤:

  1. 包含头文件:首先需要包含VPP相关头文件,例如vlib/vlib.hvnet/vnet.h等。

  2. 定义结构体:定义一个包含节点配置信息和运行时状态的结构体。通常命名为node_main_t。

  3. 注册节点:使用VLIB_REGISTER_NODE宏将节点注册到VPP框架中。该宏需要提供节点名字、输入输出描述符等参数。

  4. 创建节点函数:实现一个create_node函数,其中会初始化节点配置信息和运行时状态。这个函数会被VPP框架调用,创建实际的节点。

  5. 处理数据包:实现一个process_packet函数,用于对输入数据包进行处理,并将结果发送给下一个节点或者输出口。

  6. 清理节点函数:实现一个cleanup_node函数,用于清理节点状态和资源。

以下是一个简单的节点示例,用于向输出口发送ping应答:

#include <vlib/vlib.h>
#include <vnet/vnet.h>typedef struct {u32 sw_if_index;
} node_main_t;static uword process_packet(vlib_main_t *vm, vlib_node_runtime_t *node,vlib_frame_t *frame) {u32 n_left_from, *from;from = vlib_frame_vector_args(frame);n_left_from = frame->n_vectors;while (n_left_from > 0) {u32 n_left_to_next;vlib_get_next_frame(vm, node, VLIB_NODE_FORWARD_NEXT_INDEX, to_next,n_left_to_next);while (n_left_from > 0 && n_left_to_next > 0) {vlib_buffer_t *buf;u32 bi;bi = from[0];from += 1;n_left_from -= 1;to_next[0] = bi;to_next += 1;n_left_to_next -= 1;buf = vlib_get_buffer(vm, bi);u32 sw_if_index = ((node_main_t *)node->runtime_data)->sw_if_index;vnet_buffer(b)->sw_if_index[VLIB_TX] = sw_if_index;vlib_set_next_frame_buffer(vm, node, VLIB_NODE_FORWARD_NEXT_INDEX, bi);}vlib_put_next_frame(vm, node, VLIB_NODE_FORWARD_NEXT_INDEX, n_left_to_next);}return frame->n_vectors;
}static clib_error_t *setup_function(vlib_main_t *vm) {node_main_t *nm;nm = &node_main;nm->sw_if_index = 0;return 0;
}VLIB_REGISTER_NODE(node_ping_reply) = {.function = process_packet,.name = "ping-reply",.type = VLIB_NODE_TYPE_INTERNAL,.vector_size = sizeof(u32),.n_errors = 0,.format_trace = 0,.flags = VLIB_NODE_FLAG_IS_DROP,
};VLIB_INIT_FUNCTION(setup_function);

可以看到,节点的实现主要包含了创建、处理和清理三个函数。其中process_packet是最重要的函数,它通过循环获取所有输入数据包,并对每个数据包进行处理。在这个例子中,只是简单地将输出口设置为节点配置中的sw_if_index。其余部分都是基本的VPP框架代码。

Dpdk/网络协议栈/vpp/OvS/DDos/NFV  视频教程学习地址: https://ke.qq.com/course/5066203?flowToken=1043068
DPDK/网络虚拟化 相关学习资料、视频教程 学习群:739729163 
http://www.lryc.cn/news/62977.html

相关文章:

  • 【4. ROS的主要通讯方式:Topic话题与Message消息】
  • 【react全家桶学习】react中组件定义及state属性(超详/必看)
  • 如何以产品经理思维打造一所高品质学校?
  • 根治Spring中使用Mongo时报错InvalidMongoDbApiUsageException
  • 【计算机组成原理】数据的表示和运算·进位计数制
  • C++ Primer第五版_第十四章习题答案(21~30)
  • 服务器性能调优
  • 带你深入学习k8s--(三) pod 管理
  • 前端系列11集-ES6 知识总结
  • 连接分析工具箱 | 利用CATO进行结构和功能连接重建
  • 【目标检测论文阅读笔记】Detection of plane in remote sensing images using super-resolution
  • 外卖app开发流程全解析
  • BUUCTF jarvisoj_level0
  • 网络安全之入侵检测
  • 元数据管理
  • C# WebService的开发以及客户端调用
  • 有符号数和无符号数左移和右移
  • Netty小白入门教程
  • 【逻辑位移和算数位移】
  • Blender3.5 边的操作
  • Java与Python、Node.js在人工智能和区块链应用程序开发中的比较
  • 【计算机是怎么跑起来的】基础:计算机三大原则
  • NXP公司LPC21XX+PID实现稳定温度控制
  • 【CE实战-生化危机4重置版】实现角色瞬移、飞翔
  • 强烈建议互联网人转战实体和农业,去了就是降维打击!实体太缺人才了,老板也不缺钱!...
  • 如何将 github pages 迁移到 vercel 上托管
  • 2023五一数学建模竞赛(五一赛)选题建议
  • Packet Tracer - 配置 RIPv2
  • Android类似微信聊天页面教程(Kotlin)四——数据本地化
  • C/C++基础知识