如何新建VPP插件

简介: 如何新建一个VPP插件

How to create a new plugin

1.使用VPP提供的sample插件作为基础,复制和重命名sample插件文件夹以及am文件
cp -r src/examples/sample-plugin/sample src/plugins/newplugin
cp src/examples/sample-plugin/sample.am src/plugins/newplugin.am
2.修改./src/plugins/newplugin.am文件
这里插件的名字假定为newplugin
需要修改newplugin.am文件中关于目录和文件的信息(sample/ -> newplugin/),使得该am文件指向你的插件,如果不需要二进制api的话,可以把api相关的文件删除
例如:

vppapitestplugins_LTLIBRARIES += newplugin.la
vppplugins_LTLIBRARIES += newplugin_plugin.la

newplugin_plugin_la_SOURCES =        \
    newplugin/sample.c                \
    newplugin/node.c                \
    newplugin/sample_plugin.api.h

API_FILES += newplugin/sample.api

nobase_apiinclude_HEADERS +=            \
  newplugin/sample_all_api_h.h                \
  newplugin/sample_msg_enum.h                \
  newplugin/sample.api.h

newplugin_plugin_la_SOURCES = newplugin/sample_test.c newplugin/sample_plugin.api.h

最简单的一种修改实现:

vppplugins_LTLIBRARIES += newplugin_plugin.la

newplugin_plugin_la_SOURCES = newplugin/main.c newplugin/cmd.c newplugin/node.c
newplugin_plugin_la_LIBADD = -lxxxx  ===> 这里可以添加上你的插件依赖的库,比如-ldpdk

3.修改./src/plugins/Makefile.am文件
在该文件中添加如下判断,这里是为了让编译系统找到插件的makefile

if ENABLE_NEWPLUGIN_PLUGIN
include newplugin.am
endif

4.修改./src/configure.ac文件
为了生成相应的编译规则,还需要对configure.ac文件进行修改,添加如下信息,最后再重新生成一次makefile即可
在324行左右添加如下:

PLUGIN_ENABLED(newplugin)

5.插件须含有的元素

  • 插件声明(必须)
    VLIB_PLUGIN_REGISTER() = {
      .version     = VPP_BUILD_VER,
      .description = "newplugin",
    };
    
  • 插件初始化函数
    VLIB_INIT_FUNCTION(newplugin_init);
    
  • 插件结点相关函数
VLIB_REGISTER_NODE(newplugin_ip4_node) = {
    .function = newplugin_ip4_node_fn,
    .name = "newplugin-ip4",
    .vector_size = sizeof(u32),
    .format_trace = format_newplugin_trace,
    .type = VLIB_NODE_TYPE_INTERNAL,
    .n_next_nodes = 2,
    .next_nodes = {
            [NEWPLUGIN_NEXT_DROP] = "error-drop",
            [NEWPLUGIN_NEXT_IP4_LOOKUP] = "ip4-lookup",
    },
};

VNET_FEATURE_INIT(newplugin_ip4, static) = {
  .arc_name    = "ip4-output",
  .node_name   = "newplugin-ip4",
  .runs_before = VNET_FEATURES("interface-output"),
};

这里newplugin插件的结点名为newplugin-ip4,结点函数为newplugin_ip4_node_fn, 其后两个结点为"error-drop" or "ip4-lookup"
该结点放在ip4-output arc内,在执行interface-output结点之前运行

Reference

  1. [how-to-develop-vpp-plugins]
  2. VPP Infrastructure Libraries
目录
相关文章
OpenWrt Web界面修改及功能实现实例说明
http://www.cnblogs.com/dwayne/archive/2012/04/21/2460830.html 通过上篇文章的介绍,我们应该了解了Lua语言在OpenWrt Web配置页面的基本对应功能设计方法。
2934 0
|
10月前
|
存储
LabVIEW使用VI Package Manager(VIPM)下载和管理附加组件
LabVIEW使用VI Package Manager(VIPM)下载和管理附加组件
365 1
|
10月前
|
NoSQL 安全 芯片
OpenOCD(三):学习OpenJTAG Config文件配置
OpenOCD(三):学习OpenJTAG Config文件配置
521 0
vscode彻底删除安装过的插件和个人配置信息
vscode彻底删除安装过的插件和个人配置信息
1804 0
vscode彻底删除安装过的插件和个人配置信息
UE中创建可脚本化编辑器工具(Scriptable Tools)
UE中创建可脚本化编辑器工具(Scriptable Tools)
295 0
|
IDE Unix 编译器
iOS小技能:Makefile的使用(Makefile的规则、部署脚本、config管理ssh连接)
make是一个命令工具,是一个解释makefile中指令的命令工具。其本质是**文件依赖**,Makefile文件制定编译和链接所涉及的文件、框架、库等信息,将整个过程自动化。
427 0
|
C语言
IAR 安装到创建操作(二)配置
IAR 安装到创建操作(二)配置
462 0
IAR 安装到创建操作(二)配置
|
JavaScript 数据库
egg项目创建之连接配置(三)
默认情况下,egg-sequelize 将使用 sequelize@5,您可以自定义 sequelize 版本使用 config.sequelize.Sequelize 绕过
|
负载均衡 Docker 容器
Universal Link配置,如何使用rancher将文件部署到服务器的根目录
Universal Link配置,如何使用rancher将文件部署到服务器的根目录
312 0
Universal Link配置,如何使用rancher将文件部署到服务器的根目录
|
IDE Unix 编译器
Makefile的使用教程:Makefile的规则、部署脚本、config管理ssh连接
Makefile的使用教程:Makefile的规则、部署脚本、config管理ssh连接
652 0
Makefile的使用教程:Makefile的规则、部署脚本、config管理ssh连接