VPP 源码学习总结

2024-04-25 23:04
文章标签 源码 学习 总结 vpp

本文主要是介绍VPP 源码学习总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

当我们在VPP/plugins目录下注册了自己的node后, 肯定有一个node.func(), 那这个函数是如何执行到的呢:

1. 首先我们要看一下这个插件注册的时候做了什么, 假设node 如下:

编译成功后, 我们可以从函数vlib_plugin_early_init() 中分析, 初始化时,怎么把这个node加到全局链表中的。

TODO: 大概就是, 在so 目录下去遍历所有so文件,根据注册的名字用头插法把相关node 加入链表中, 并为其分配相关的维护逻辑。

2. vpp初始化的前两步把插件,加载完了(维护起来了), 那下边我们看下VPP是怎么在后台一直去轮询的呢? 

由于亿图脑图目前不能保存,节点限制, 先把已经总结放这里(新标签中打开图片可以放大)。

下图主要以vpp的main()为入口,学习vpp如果调用我注册的node的处理函数的。

前边马上就要找到调用我们注册的node了, 下边我们看一下dispatch_node()函数。

在调用的地方我们要注意框起来的这两个参数:

因为我们注册的NODE是VLIB_NODE_TYPE_INTERNAL类型的, 这里就是了, 我们看下dispatch_node()源码:

static_always_inline u64
dispatch_node (vlib_main_t * vm,vlib_node_runtime_t * node,vlib_node_type_t type,     // internal 类型的vlib_node_state_t dispatch_state,   // polling 状态 的。vlib_frame_t * frame, u64 last_time_stamp)
{uword n, v;u64 t;vlib_node_main_t *nm = &vm->node_main;vlib_next_frame_t *nf;if (CLIB_DEBUG > 0){vlib_node_t *n = vlib_get_node (vm, node->node_index);ASSERT (n->type == type);}/* Only non-internal nodes may be disabled. */if (type != VLIB_NODE_TYPE_INTERNAL && node->state != dispatch_state){ASSERT (type != VLIB_NODE_TYPE_INTERNAL);return last_time_stamp;}if ((type == VLIB_NODE_TYPE_PRE_INPUT || type == VLIB_NODE_TYPE_INPUT) // 这里些时进不来&& dispatch_state != VLIB_NODE_STATE_INTERRUPT){u32 c = node->input_main_loops_per_call;/* Only call node when count reaches zero. */if (c){node->input_main_loops_per_call = c - 1;return last_time_stamp;}}/* Speculatively prefetch next frames. */if (node->n_next_nodes > 0) // 这里是预取, 先不用管{nf = vec_elt_at_index (nm->next_frames, node->next_frame_index);CLIB_PREFETCH (nf, 4 * sizeof (nf[0]), WRITE);}vm->cpu_time_last_node_dispatch = last_time_stamp;if (1 /* || vm->thread_index == node->thread_index */ ) // 这里一定能进来。{vlib_main_t *stat_vm;stat_vm = /* vlib_mains ? vlib_mains[0] : */ vm;vlib_elog_main_loop_event (vm, node->node_index, last_time_stamp,frame ? frame->n_vectors : 0,/* is_after */ 0);/** Turn this on if you run into* "bad monkey" contexts, and you want to know exactly* which nodes they've visited... See ixge.c...*/if (VLIB_BUFFER_TRACE_TRAJECTORY && frame) // 这里前宏没有定义 , 进不来{int i;u32 *from;from = vlib_frame_vector_args (frame);for (i = 0; i < frame->n_vectors; i++){vlib_buffer_t *b = vlib_get_buffer (vm, from[i]);add_trajectory_trace (b, node->node_index);}n = node->function (vm, node, frame); }else // 最后走到了这里。n = node->function (vm, node, frame);  // 这里调用的我们加的internal node的执行函数。/* 因为上层调用的时候 , 是处理所有的internal类型的node, 这里的node 就包含了我们注册的
Node.  node->function () 就是调用的我们注册的函数 yb_sample_node_fn() , 上层调用是一个
while() 循环, 所以这些node会一直在后台循环处理, 这样只要有包到我们这个node,就会添加进调度链表,并进行处理。*/

从这个流程上, 就大概知道我们注册的node是如何被调用起来的了。 以后有更多的细节要学习, 可以根据这个流程去找具体的实现逻辑。

这篇关于VPP 源码学习总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/936035

相关文章

Nginx屏蔽服务器名称与版本信息方式(源码级修改)

《Nginx屏蔽服务器名称与版本信息方式(源码级修改)》本文详解如何通过源码修改Nginx1.25.4,移除Server响应头中的服务类型和版本信息,以增强安全性,需重新配置、编译、安装,升级时需重复... 目录一、背景与目的二、适用版本三、操作步骤修改源码文件四、后续操作提示五、注意事项六、总结一、背景与

Android实现图片浏览功能的示例详解(附带源码)

《Android实现图片浏览功能的示例详解(附带源码)》在许多应用中,都需要展示图片并支持用户进行浏览,本文主要为大家介绍了如何通过Android实现图片浏览功能,感兴趣的小伙伴可以跟随小编一起学习一... 目录一、项目背景详细介绍二、项目需求详细介绍三、相关技术详细介绍四、实现思路详细介绍五、完整实现代码

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

Spring 依赖注入与循环依赖总结

《Spring依赖注入与循环依赖总结》这篇文章给大家介绍Spring依赖注入与循环依赖总结篇,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Spring 三级缓存解决循环依赖1. 创建UserService原始对象2. 将原始对象包装成工

MySQL中查询和展示LONGBLOB类型数据的技巧总结

《MySQL中查询和展示LONGBLOB类型数据的技巧总结》在MySQL中LONGBLOB是一种二进制大对象(BLOB)数据类型,用于存储大量的二进制数据,:本文主要介绍MySQL中查询和展示LO... 目录前言1. 查询 LONGBLOB 数据的大小2. 查询并展示 LONGBLOB 数据2.1 转换为十

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.

在Java中实现线程之间的数据共享的几种方式总结

《在Java中实现线程之间的数据共享的几种方式总结》在Java中实现线程间数据共享是并发编程的核心需求,但需要谨慎处理同步问题以避免竞态条件,本文通过代码示例给大家介绍了几种主要实现方式及其最佳实践,... 目录1. 共享变量与同步机制2. 轻量级通信机制3. 线程安全容器4. 线程局部变量(ThreadL

Spring Boot 与微服务入门实战详细总结

《SpringBoot与微服务入门实战详细总结》本文讲解SpringBoot框架的核心特性如快速构建、自动配置、零XML与微服务架构的定义、演进及优缺点,涵盖开发环境准备和HelloWorld实战... 目录一、Spring Boot 核心概述二、微服务架构详解1. 微服务的定义与演进2. 微服务的优缺点三

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys