DPDK文档翻译DPDK学习指南

DPDK编程指南(翻译)( 三十三)

2017-11-20  本文已影响202人  半天妖

33. 扩展 DPDK

本章描述了开发者如何通过扩展DPDK来提供一个新的库、目标文件或者支持新的开发板。

33.1. 示例:添加新的库 libfoo

要添加新的库到DPDK,按照如下操作:

  1. 添加新的配置选项:
for f in config/\*; do \
    echo CONFIG_RTE_LIBFOO=y >> $f; done
  1. 创建新的源码目录:
mkdir ${RTE_SDK}/lib/libfoo
touch ${RTE_SDK}/lib/libfoo/foo.c
touch ${RTE_SDK}/lib/libfoo/foo.h
  1. 源码添加 foo() 函数。
函数定义于 foo.c:

void foo(void)
{
}
函数声明于 foo.h:

extern void foo(void);
  1. 更新文件 lib/Makefile:
vi ${RTE_SDK}/lib/Makefile
# add:
# DIRS-$(CONFIG_RTE_LIBFOO) += libfoo
  1. 为新的库创建新的 Makefile,如派生自 mempool Makefile,进行修改:
cp ${RTE_SDK}/lib/librte_mempool/Makefile ${RTE_SDK}/lib/libfoo/

vi ${RTE_SDK}/lib/libfoo/Makefile
# replace:
# librte_mempool -> libfoo
# rte_mempool -> foo
  1. 更新文件 mk/DPDK.app.mk,添加 -lfoo 选项到 LDLIBS 变量中。 链接DPDK应用程序时会自动添加此标志。

  2. 添加此新库之后,重新构建DPDK (此处仅显示这个特殊的部分):

cd ${RTE_SDK}
make config T=x86_64-native-linuxapp-gcc
make
  1. 检测这个库被正确安装了:
ls build/lib
ls build/include

33.1.1. 示例:在测试用例中使用新库 libfoo

测试应用程序用于验证DPDK的所有功能。 一旦添加了一个库,应该在测试用例程序中添加一个用例。

上一篇 下一篇

猜你喜欢

热点阅读