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

相关文章

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很

java常见报错及解决方案总结

《java常见报错及解决方案总结》:本文主要介绍Java编程中常见错误类型及示例,包括语法错误、空指针异常、数组下标越界、类型转换异常、文件未找到异常、除以零异常、非法线程操作异常、方法未定义异常... 目录1. 语法错误 (Syntax Errors)示例 1:解决方案:2. 空指针异常 (NullPoi

Spring 中 BeanFactoryPostProcessor 的作用和示例源码分析

《Spring中BeanFactoryPostProcessor的作用和示例源码分析》Spring的BeanFactoryPostProcessor是容器初始化的扩展接口,允许在Bean实例化前... 目录一、概览1. 核心定位2. 核心功能详解3. 关键特性二、Spring 内置的 BeanFactory

Java反转字符串的五种方法总结

《Java反转字符串的五种方法总结》:本文主要介绍五种在Java中反转字符串的方法,包括使用StringBuilder的reverse()方法、字符数组、自定义StringBuilder方法、直接... 目录前言方法一:使用StringBuilder的reverse()方法方法二:使用字符数组方法三:使用自

Java进阶学习之如何开启远程调式

《Java进阶学习之如何开启远程调式》Java开发中的远程调试是一项至关重要的技能,特别是在处理生产环境的问题或者协作开发时,:本文主要介绍Java进阶学习之如何开启远程调式的相关资料,需要的朋友... 目录概述Java远程调试的开启与底层原理开启Java远程调试底层原理JVM参数总结&nbsMbKKXJx

Python依赖库的几种离线安装方法总结

《Python依赖库的几种离线安装方法总结》:本文主要介绍如何在Python中使用pip工具进行依赖库的安装和管理,包括如何导出和导入依赖包列表、如何下载和安装单个或多个库包及其依赖,以及如何指定... 目录前言一、如何copy一个python环境二、如何下载一个包及其依赖并安装三、如何导出requirem

Rust格式化输出方式总结

《Rust格式化输出方式总结》Rust提供了强大的格式化输出功能,通过std::fmt模块和相关的宏来实现,主要的输出宏包括println!和format!,它们支持多种格式化占位符,如{}、{:?}... 目录Rust格式化输出方式基本的格式化输出格式化占位符Format 特性总结Rust格式化输出方式

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

Python中连接不同数据库的方法总结

《Python中连接不同数据库的方法总结》在数据驱动的现代应用开发中,Python凭借其丰富的库和强大的生态系统,成为连接各种数据库的理想编程语言,下面我们就来看看如何使用Python实现连接常用的几... 目录一、连接mysql数据库二、连接PostgreSQL数据库三、连接SQLite数据库四、连接Mo

Git提交代码详细流程及问题总结

《Git提交代码详细流程及问题总结》:本文主要介绍Git的三大分区,分别是工作区、暂存区和版本库,并详细描述了提交、推送、拉取代码和合并分支的流程,文中通过代码介绍的非常详解,需要的朋友可以参考下... 目录1.git 三大分区2.Git提交、推送、拉取代码、合并分支详细流程3.问题总结4.git push