首页 > 其他分享 >dpdk 编译

dpdk 编译

时间:2023-10-03 17:12:57浏览次数:54  
标签:VFIO iommu uio 编译 dpdk DPDK

 

引用: https://zhuanlan.zhihu.com/p/566700687

20.11 版本

 

DPDK(Data Plane Development Kit)是数据平面开发工具包,由用于加速在各种CPU架构上运行的数据包处理的库组成。

DPDK需要一定的网卡硬件支持,以Intel为例,支持以下网卡:

 

下面带大家过一遍编译流程,扫清后续应用的第一道障碍!

 

一、源码准备

下载dpdk-20.11.tar.xz源码包

采用如下命令命令进行解压

解压后用ls命令再确认一下

发现多了一个dpdk-20.11文件夹,我们进去瞅瞅他的目录结构,发现该有的都有啦。

稍微展开介绍一下几个重要目录:

  • lib:DPDK库的源代码
  • drivers: DPDK 查询模式驱动源码
  • app: DPDK应用源码(自动化测试)
  • examples: DPDK应用示例程序源码
  • config,buildtools: 框架相关的脚本和配置

 

二、编译安装DPDK

  1. 进入dpdk-20.11目录执行meson -Dexamples=helloworld build命令并回车,如下图红色框所示。如对meson命令不熟悉可以瞅瞅编译工具meson+ninja简介(dpdk编译工具)



稍等片刻出现下图所示内容,我们用ls查看发现多出来一个buid文件夹,没错,接下来的故事在build文件夹内展开。

 

  1. 进入build文件夹ls命令查看一下上一个命令生成的内容,接着依次执行ninja-build命令、ninja-build install命令,如对ninja相关命令比较陌生,可以瞅瞅编译工具meson+ninja简介(dpdk编译工具)。执行以上命令后效果如下图。

 

  1. ninja install命令会拷贝编译后的目标文件到系统范围内可执行的地方,最后执行以下ldconfig命令使ld.so更新它的cache,以便包含刚才生成的目标文件。执行完成以上三步,恭喜你,dpdk就算安装完成了。

三、测试验证

前面执行meson -Dexamples=helloworld build这条命令时不知道大家是否 对-Dexamples=helloworld的用意已理解,这个参数就是告诉meson编译DPDK的同时编译helloworld例程。所以我们可以通过运行这个例程来检验dpdk是否能正常工作。

 

在运行DPDK应用前咱一般还需要干几件事儿:

  1. 设置Hugepages
    Hugepages是DPDK用于提升性能的重要手段。通过使用Hugepages,可以降低内存页数,减少TLB页表数量,增加TLB hit率。在Linux上设置Hugepages有两种方式:
    修改Kernel cmdline(推荐)
    修改sysfs节点
    a、修改Kernel cmdline(推荐)
    通过修改kernel command line可以在kernel初始化时传入Hugepages相关参数并进行配置。具体的操作步骤如下:
    修改grub文件
    修改/etc/default/grub文件,在GRUB_CMDLINE_LINUX中加入如下配置:
    default_hugepagesz=1G hugepagesz=1G hugepages=4

    该配置表示默认的hugepages的大小为1G,设置的hugepages大小为1G,hugepages的页数为4页,即以4个1G页面的形式保留4G的hugepages内存
    修改后的grub文件示例如下:



编译grub配置文件
可以通过命令grub2-mkconfig -o /boot/grub2/grub.cfg


重启
通过reboot命令重启,随后可以通过cat /proc/cmdline查看kernel的command line是否包含之前的配置。


也可以通过cat /proc/meminfo | grep Huge命令查看是否设置成功,若设置成功可以看到如下配置:



DPDK官方建议,64位的应用应配置1GB hugepages。
这种配置方式的优点是可以在系统开机时即配置预留好hugepages,避免系统运行起来后产生内存碎片;另外,对于较大的例如1G pages,是不支持在系统运行起来后配置的,只能通过kernel cmdline的方式进行配置centos7.7,大页为1G 可动态调
注:对于双插槽的NUMA系统(dual-socket NUMA system),预留的hugepages会被均分至两个socket,可以通过lscpu查看CPU信息:



可见测试主机使用的是双socket的NUMA系统。
b、修改sysfs节点
对于2 MB页面,还可以选择在系统启动后进行分配。这是通过修改 /sys/devices/中的nr_hugepages节点来实现的。对于单节点系统,若需要1024个页面,可使用如下命令:



在NUMA机器上,页面的需要明确分配在不同的node上(若只有一个node只需要分配一次):



这种配置方式的优点是配置简单,无需编译、重启,但是无法配置1GB这样的大hugepages。
DPDK使用Hugepages
预留好Hugepages之后,想要让DPDK使用预留的Hugepages,需要进行下述操作:



可以将这个挂载点添加到/etc/fstab中,这样可以永久生效,即重启后也仍然可以生效:



对于1GB pages,在/etc/fstab中必须指定page size作为mount选项。添加上面这样一行内容至/etc/fstab后并重启,可以通过df -a看到挂载成功:

 

  1. 加载内核驱动
    DPDK的驱动可以选择UIO也可以选择VFIO,VFIO安全性性能都比UIO好,不过要求肯定也比UIO高,所以一般的建议是有条件尽量用VFIO,用不了再用UIO。

    UIO
    UIO(Userspace I/O)是运行在用户空间的I/O技术。Linux系统中一般的驱动设备都是运行在内核空间,而在用户空间用应用程序调用即可。
    而UIO则是将驱动的很少一部分运行在内核空间,而在用户空间实现驱动的绝大多数功能。
    在许多情况下,Linux内核中包含的标准uio_pci_generic模块可以提供uio功能。可以使用以下命令加载此模块:
    sudo modprobe uio_pci_generic

    除了Linux内核中包含的标准uio_pci_generic模块,DPDK也提供了一个可替代的igb_uio模块,可以在kmod路径中找到。可以通过以下方法加载igb_uio模块。
    sudo modprobe uio
    sudo insmod kmod/igb_uio.ko

    如果用于DPDK的设备绑定为uio_pci_generic内核模块,需要确保IOMMU已禁用或passthrough。以intel x86_64系统为例,可以在的GRUB_CMDLINE_LINUX中添加intel_iommu = offintel_iommu = on iommu = pt

    VFIO(推荐)
    VFIO与UIO相比,它更加强大和安全,依赖于IOMMU。要使用VFIO,需要:
    Linix kernel version>=3.6.0
    内核和BIOS必须支持并配置为使用IO virtualization(例如Intel®VT-d)在确认硬件配置支持的情况下,要使用VFIO驱动绑定到NIC必须先使能iommu,否则会导致绑定失败。具体的现象就是查看或修改sysfs节点/sys/bus/pci/drivers/vfio-pci/bind出现io错误,以及dmesg中出现:
    vfio-pci: probe of 0000:05:00.0 failed with error -22

    使能iommu的方法也是修改kernel的command line将iommu=pt intel_iommu=on传入,具体步骤:
    a、修改grub文件
    修改/etc/default/grub文件,在GRUB_CMDLINE_LINUX中加入如下配置:iommu=pt intel_iommu=on




b、编译grub配置文件
可以通过命令grub2-mkconfig -o /boot/grub2/grub.cfg
c、重启
通过reboot命令重启,随后可以通过cat /proc/cmdline查看kernel的command line是否包含之前的配置。



d、iommu配置成功后,dmesg中会有iommu配置group的log,可以通过dmesg | grep iommu查看:


并没有出现类似如下iommu的device加入组的相关信息。
[0.594500] iommu: Adding device 0000:05:00.0 to group 18
[0.594512] iommu: Adding device 0000:06:00.0 to group 19

感觉不太妙,不知vfio能否用的起来。
随后需要调用modprobe来加载VFIO的驱动:
sudo modprobe vfio-pci


lsmod | grep vfio一下,可以看到vfio驱动已经挂载。
为了保险起见,我们把uio的也挂载上吧,如下:


现在uio和vfio的驱动都已成功挂载。

  1. 应用程序使用的端口应绑定到相应的内核驱动程序(可选)
    上面的UIO和VFIO驱动可以加载一项,也可以全都加载。但是在驱动绑定NIC的时候,只能选择一种驱动绑定到NIC,UIO和VFIO该如何选可以回看UIO,IOMMU,VFIO傻傻分不清楚,我们先尝试采用VFIO驱动。可以调用dpdk路径下的usertools/dpdk-devbind.py实用脚本来进行VFIO驱动与NIC绑定,需要注意的是使用这个脚本进行绑定(bind)动作时是需要root权限的。可以调用脚本传入--status查看当前的网络端口的状态:



可以看到,当前NIC的状态都是Network devices using kernel driver。随后可以调用脚本传入--bind将网卡0b:00.0,也就是ens192绑定到VFIO驱动:


结果报错了,看来咱今天演示用的机器是支持不了vfio了,那咱们就只能上uio了,具体如下:



再次调用脚本传入--status,可以从上图看到设备0b:00.0已经配置为drv=uio_pci_generic了。
若想要恢复为kernel默认的vmxnet3驱动,则可以继续调用脚本:
python usertools/dpdk-devbind.py --bind=vmxnet3 0b:00.0


不过为了今后的实验,咱还是把0b:00.0设置为uio_pci_generic吧。接下来咱们用前面编译好的helloworld例程看看效果怎么样,具体如下:
输入红色框命令并回车,接下来例程期望的效果真的出现了,惊不惊喜,意不意外~

原文链接 : https://mp.weixin.qq.com/s/kVUFW3yngpFsY5n-bBhnmA

 

 

 

使用修改sysfs节点方法,修改 hugepage 。第一种方法失败了。

 

 

 

 

 

 

 

 

 

 

参考引用:

https://zhuanlan.zhihu.com/p/566700687

 

标签:VFIO,iommu,uio,编译,dpdk,DPDK
From: https://www.cnblogs.com/rebrobot/p/17741294.html

相关文章

  • CSS预编译:提升样式开发效率与可维护性的关键工具
    ......
  • 【TypeScript学习】—编译选项(三)
    【TypeScript学习】—编译选项(三)一、自动编译文件tscxxx.ts-w二、自动编译整个项目三、编译器选项......
  • Android 编译和使用libpng
    libpnglibpngistheofficialPNGreferencelibrary.ItsupportsalmostallPNGfeatures,isextensible,andhasbeenextensivelytestedforover28years.Thehomesitefordevelopmentversions(i.e.,maybebuggyorsubjecttochangeorincludeexperimen......
  • dpdk lpm
    DPDKLPM(LongestPrefixMatch)是高性能前缀路由匹配库,用于数据包转发过程中快速查找与dstIP地址最长匹配的路由表项。LPM特点高性能:基于前缀树算法实现快速匹配。线程安全:多线程并发安全。灵活配置:支持动态配置路由表,可在运行时添加、删除或修改路由表项。内存管理:使用MemoryPo......
  • dpdk官方转发例子分析
    例子源码http://dpdk.org/browse/dpdk/tree/examples/skeleton/basicfwd.cmain函数主流程1.初始化环境抽象层EALintret=rte_eal_init(argc,argv);if(ret<0)rte_exit(EXIT_FAILURE,"ErrorwithEALinitialization\n");2.分配mempooldpdk使用mbuf保存packet,me......
  • lapce源码学习-编译调试
    master分支调试1、报错:`#![feature]`maynotbeusedonthestablereleasechannel2、Channel切换到nightly,报错:thetraitbound`file_type::FileType:std::sealed::Sealed`isnotsatisfied3、Channel切换到beta,编译ok,但提示不能调试rustupinstallbeta4、编译成功后,......
  • 点播模块编译nginx
    VOD模块NGINX编译部署主要解决我那破电视的观影需求、软件装不了又不想掏钱看线上广告;U盘也没法播、没几个兼容的解码软件,五六年前的电视买的是真坑爹,我又不会刷机,那索性用废笔记本装linux整个nginx-vod模块整个音视频链接,电视上用短小精悍的VLC观影。下包mkdir/usr/local/n......
  • 【rk356x】Linux Cmake如何进行交叉编译
    compiler.arm.cmakeSET(GCC_PATH/work/xxx/buildroot/output/rockchip/host/bin)SET(toolpathprefix${GCC_PATH}/aarch64-buildroot-linux-gnu-)set(libusb_path/work/xxx/libusb/install/lib/pkgconfig/libusb-1.0.pc)SET(CMAKE_C_COMPILER${toolpathprefix}gcc)SET......
  • 【X3m】opencv和opencv_contrib交叉编译
    opencv和contrib版本必须要一直,否则可以编译不匹配opencv4-4.5.4.tar.gzopencv4-contrib-4.5.5.tar.gzopencv交叉编译命令,主要eigen3的地址cmake\-DCMAKE_BUILD_TYPE=Release\-DCMAKE_INSTALL_PREFIX=../install\-DBUILD_PNG=ON\-DBUILD_TIFF=ON\......
  • Go每日一库之136:gopherjs(将Go代码编译成JS)
    简介GopherJS可以将Go代码编译成纯JavaScript代码。其主要目的是为了让你可以使用Go来编写前端代码,这些代码可执行在浏览器上运行。你可以通过这里尝试下GopherJS:GopherJSPlayground.例如JavaScript代码:document.write("Hello world!");用GopherJS来写就变成这......