DPDK-Hello-World示例应用程序

文章目录

    • 前言
    • 环境安装
    • 编写hello-world程序

前言

目标: 在linux上安装DPDK的程序编写环境,编写和运行DPDK的hello world程序。

声明:我不清楚DPDK具体是个啥。DPDK的目的大概是:原先的网络数据需要从内核层拷贝到用户层,在IO越来越快的今天,CPU的处理就显得有点慢。DPDK可以跳过内核,实现更快的数据包处理。

环境安装

阅读:DPDK-系统要求、从源代码编译DPDK目标

首先是系统要求,需要在内核中启用 HUGETLBFS 选项。我是在wsl-ubuntu中进行程序开发,没找见内核选项。我以前简单编译过内核,知道些内核选项:内核编译选项简介。(我在网上找了下,暂时没有看见WSL-ubunut控制内核选项的方法。目前跳过。)(virtualbox-ubunut20-desktop中HUGETLBFS选项是默认开启的)

接着是,编译DPDK。emm,我目前不清楚那些编译选项的具体内容。那直接使用包管理器安装吧,当前够用就好。

# almlinux9
# sudo dnf remove dpdk dpdk-devel dpdk-tools # ubuntu22
sudo apt install libhugetlbfs-bin dpdk-dev libdpdk-dev

编写hello-world程序

阅读:Hello World 示例应用程序

这是一个最简单的 DPDK 应用程序示例。该应用程序只是在每个启用的 lcore 上打印一条“helloworld”消息。

lcore是啥?

我们可以看下这个链接: 环境抽象层 (EAL)

环境抽象层 (Environment Abstraction Layer, EAL) 负责访问低级资源,例如硬件和内存空间。它提供了一个通用接口,对应用程序和库隐藏了环境细节。初始化例程负责决定如何分配这些资源(即内存空间、设备、定时器、控制台等)。

术语“lcore”指的是 EAL 线程。DPDK 通常为每个核心固定一个 pthread,以避免任务切换的开销。这可以显着提高性能,但缺乏灵活性并且并不总是高效。当使用多个 pthread 时,EAL pthread 和指定的物理 CPU 之间的绑定不再总是 1:1…

下面是示例代码,修改自:helloworld

#include <rte_eal.h>
#include <rte_lcore.h>
#include <stdio.h>int lcore_hello(__rte_unused void *arg) {unsigned int lcore_id = rte_lcore_id();printf("hello from core %u\n", lcore_id);return 0;
}int main(int argc, char *argv[]) {if (rte_eal_init(argc, argv) < 0) {rte_exit(EXIT_FAILURE, "fail in init");}for (unsigned int lcore_id = rte_get_next_lcore(-1, 1, 0);lcore_id < RTE_MAX_LCORE;lcore_id = rte_get_next_lcore(lcore_id, 1, 0)) {rte_eal_remote_launch(lcore_hello, NULL, lcore_id);}lcore_hello(NULL);rte_eal_mp_wait_lcore(); // Wait until all lcores finish their jobs.rte_eal_cleanup();return 0;
}

下面逐行介绍下上面的API。由于所有的API接口文档,都可以在DPDK-API查看。所以这里仅仅简单介绍下程序中使用的API。

  • rte_eal_init: 初始化EAL, 仅在main lcore上执行。
  • rte_exit:终止程序,打印错误消息,错误码返回到shell。
  • rte_get_next_lcore: 获取下一个启用的lcore ID。
  • rte_eal_remote_launch: 向处于 WAIT 状态的工作线程 lcore发送消息。当远程lcore收到消息时,它切换到RUNNING状态,然后执行函数。执行完成后,远程 lcore 切换到 WAIT 状态,并且函数的返回值存储在本地变量中,以便使用rte_eal_wait_lcore()读取。
  • rte_eal_cleanup: 清理EAL。

下面来编译程序。这里通过cmake来构建。

cmake_minimum_required(VERSION 3.11)project(dpdk_hello_world)find_package(PkgConfig REQUIRED)
pkg_check_modules(LIBDPDK REQUIRED libdpdk)
include_directories(${LIBDPDK_INCLUDE_DIRS})
link_directories(${LIBDPDK_LIBRARY_DIRS})
message(STATUS "LIBDPDK_LIBRARIES: ${LIBDPDK_LIBRARIES}")
message(STATUS "LIBDPDK_INCLUDE_DIRS: ${LIBDPDK_INCLUDE_DIRS}")
message(STATUS "LIBDPDK_LIBRARY_DIRS: ${LIBDPDK_LIBRARY_DIRS}")add_executable(${PROJECT_NAME} main.cpp)
target_link_libraries(${PROJECT_NAME} PRIVATE ${LIBDPDK_LIBRARIES})

编译和运行程序。

mkdir build; cd build; cmake ..; make# 在wsl中运行
# 没有开启大页的内核选项
# https://stackoverflow.com/questions/67996554/eal-initialization-error-on-running-dpdk-sample-program
./dpdk_hello_world 
EAL: Detected CPU lcores: 16
EAL: Detected NUMA nodes: 1
EAL: Detected shared linkage of DPDK
EAL: Multi-process socket /tmp/dpdk/rte/mp_socket
EAL: Selected IOVA mode 'VA'
EAL: No available 2048 kB hugepages reported
EAL: No available 1048576 kB hugepages reported
EAL: FATAL: Cannot get hugepage information.
EAL: Cannot get hugepage information.
EAL: Error - exiting with code: 1#  ./dpdk_hello_world --help
./dpdk_hello_world --no-huge
EAL: Detected CPU lcores: 16
EAL: Detected NUMA nodes: 1
EAL: Static memory layout is selected, amount of reserved memory can be adjusted with -m or --socket-mem
EAL: Detected shared linkage of DPDK
EAL: Multi-process socket /tmp/dpdk/rte/mp_socket
EAL: Selected IOVA mode 'VA'
EAL: VFIO support initialized
TELEMETRY: No legacy callbacks, legacy socket not created
hello from core 1
hello from core 2
hello from core 3
hello from core 4
hello from core 5
hello from core 6
hello from core 7
hello from core 8
hello from core 9
hello from core 10
hello from core 11
hello from core 12
hello from core 13
hello from core 14
hello from core 15
hello from core 0

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/191051.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

检测判断IP合法性API接口

检测判断IP合法性API接口 一、检测判断IP合法性API接口二、使用步骤1、接口2、请求参数3、请求参数示例4、接口 返回示例 三、 如何获取appKey和uid1、申请appKey:2、获取appKey和uid 四、重要说明 一、检测判断IP合法性API接口 一款免费的帮助你检测判断IP合法性API接口 二、…

“于阗佛国、美食和田”——“万人游新疆”推广活动走进企业

11月23日&#xff0c;在安徽省文旅厅、安徽省援疆指挥部、和田地区文旅局的指导和支持下&#xff0c;由安徽环球文旅集团组织的“于阗佛国、美食和田”——“万人游新疆”分享会在安徽合肥市财富广场瑞众保险&#xff08;原华夏保险&#xff09;3楼黄山厅会议室举行&#xff0c…

【Android】布局优化方案

布局优化的核心问题就是要解决因布局渲染性能不佳而导致应用卡顿的问题。 绘制流程 绘制流程&#xff1a;安卓应用的绘制流程是在UI线程上执行的&#xff0c;主要包括以下几个步骤&#xff1a; 测量&#xff08;Measure&#xff09;&#xff1a;从视图树的根节点开始&#x…

【06】ES6:数组的扩展

一、扩展运算符 扩展运算符&#xff08;spread&#xff09;是三个点&#xff08;…&#xff09;。它是 rest 参数的逆运算&#xff0c;将一个数组转为用逗号分隔的参数序列。 1、基本语法 [...array] // array表示要转换的数组console.log(...[1, 2, 3]) // 1 2 3 console.l…

Python操作合并单元格

如何使用python操作Excel实现对合并单元格的一系列操作 01、准备工作&#xff08;使用镜像下载&#xff09; pip install openpyx -i https://pypi.tuna.tsinghua.edu.cn/simple 02、简单示例 简单创建一个工作簿进行示范&#xff1a; from openpyxl import Workbook from o…

波奇学C++:智能指针(二):auto_ptr, unique_ptr, shared_ptr,weak_ptr

C98到C11&#xff1a;智能指针分为auto_ptr, unique_ptr, shared_ptr&#xff0c;weak_ptr,这几种智能都是为了解决指针拷贝构造和赋值的问题 auto_ptr&#xff1a;允许拷贝&#xff0c;但只保留一个指向空间的指针。 管理权转移&#xff0c;把拷贝对象的资源管理权转移给拷贝…

vue v-permission权限指令

控制页面及按钮的显示隐藏 src/directive/permission/index.js import permission from ./permissionconst install function(Vue) {Vue.directive(permission, permission) }if (window.Vue) {window[permission] permissionVue.use(install); // eslint-disable-line }per…

vue中实现纯数字键盘

一、完整 代码展示 <template><div class"login"><div class"login-content"><img class"img" src"../../assets/image/loginPhone.png" /><el-card class"box-card"><div slot"hea…

4.11 计算文件的大小(C语言实现)

【题目描述】编写一个C程序&#xff0c;用来计算指定文件的大小。 【题目分析】计算指定文件大小的方法很多。最直观的方法是通过扫描整个文件计算出文件的字节数。但是这种方法对系统的开销很大&#xff0c;比较浪费时间。可以巧妙地利用I/O库中提供的函数来进行文件大小的判定…

Pytorch中有哪些损失函数?

Pytorch中有哪些损失函数? 一、常见的损失1. **均方误差损失&#xff08;Mean Squared Error Loss&#xff09;&#xff1a;nn.MSELoss**2. **交叉熵损失&#xff08;Cross-Entropy Loss&#xff09;&#xff1a;nn.CrossEntropyLoss**3. **二分类交叉熵损失&#xff08;Binar…

阵列信号处理---频率-波数响应和波束方向图

波束延迟求和器 阵列是由一组全向阵元组成&#xff0c;阵元的位置为 p n p_n pn​&#xff0c;如下图所示&#xff1a; 阵元分别在对应的位置对信号进行空域采样&#xff0c;这样就产生了一组信号信号为 f ( t , p ) f(t,p) f(t,p),具体表示如下&#xff1a; f ( t , p ) [ f…

C++入门篇(零) C++入门篇概述

目录 一、C概述 1. 什么是C 2. C的发展史 3. C的工作领域 4. C关键字(C98) 二、C入门篇导论 一、C概述 1. 什么是C C是基于C语言而产生的计算机程序设计语言&#xff0c;支持多重编程模式&#xff0c;包括过程化程序设计、数据抽象、面向对象程序设计、泛型程序设计和设计模式…

SQL Server 2016(创建数据库)

1、实验环境。 某公司有一台已经安装了SQL Server 2016的服务器&#xff0c;现在需要新建数据库。 2、需求描述。 创建一个名为"db_class"的数据库&#xff0c;数据文件和日志文件初始大小设置为10MB&#xff0c;启用自动增长&#xff0c;数据库文件存放路径为C:\db…

Ubuntu系统CLion安装与Ubuntu下菜单启动图标设置

Ubuntu系统CLion安装 pycharm 同理。 参考官网安装过程&#xff1a;官网安装过程 下载linux tar.gz包 # 解压 sudo tar -xzvf CLion-*.tar.gz -C /opt/ sh /opt/clion-*/bin/clion.sh其中第二个命令是启动CLion命令 clion安装完以后&#xff0c;不会在桌面或者菜单栏建立图…

大学里学编程,为什么这么难?

在大学学习计算机专业&#xff0c;为何很多同学觉得编程学得不顺心呢&#xff1f;许多同学会有这种感觉&#xff0c;在上大学里的计算机专业课程时&#xff0c;听得头都大了&#xff0c;但是真正要写代码&#xff0c;却不知道从哪里开始&#xff0c;或是觉得&#xff0c;大学里…

线性表 力扣67. 二进制求和

题目 67. 二进制求和 翻译 主要思路 核心思路是像竖式计算一样&#xff0c;不过需要将字符串a和b反转后逐位进行二进制计算得到字符串c&#xff0c;最后再将c反转就是答案 逐位计算的时候利用count&#xff0c;在将a和b当前位置数字相加后通过模2来决定字符串c对应位置的数…

05:2440----代码重定义

目录 一&#xff1a;引入 1&#xff1a;基本概念 2&#xff1a;NAND启动 3&#xff1a;NOR启动 4:变量 5&#xff1a;实验证明 A:代码makefile B:NOR启动 C:NAND启动 D:内存空间 二&#xff1a;链接脚本 1:NOR 2:NAND 3:解决方法 A:尝试解决 B:方法一解决 A:简…

【SparkSQL】SparkSQL的运行流程 Spark On Hive 分布式SQL执行引擎

【大家好&#xff0c;我是爱干饭的猿&#xff0c;本文重点介绍、SparkSQL的运行流程、 SparkSQL的自动优化、Catalyst优化器、SparkSQL的执行流程、Spark On Hive原理配置、分布式SQL执行引擎概念、代码JDBC连接。 后续会继续分享其他重要知识点总结&#xff0c;如果喜欢这篇文…

Echarts大屏可视化_05 折线图的定制开发

继续跟着pink老师学习Echarts相关内容&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; 折线图1 1.引入 折线图选取示例地址 标题没有用到就给他删了 直接引入 注意这里是line下面的chart 获取dom元素一定不…

吉他初学者学习网站搭建系列(4)——如何查询和弦图

文章目录 背景实现ChordDbvexchords 背景 作为吉他初学者&#xff0c;如何根据和弦名快速查到和弦图是一个必不可少的功能。以往也许你会去翻和弦的书籍查询&#xff0c;像查新华字典那样&#xff0c;但是有了互联网后我们不必那样&#xff0c;只需要在网页上输入和弦名&#…