本文主要是介绍【DPDK学习路径】四、输出hello world!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
在 ./examples/ 目录下可以找到许多的示例程序,将其中的 l3fwd-vf/Makefile 拷贝到自己的工作目录下,新建一个 main.c 文件,编写其内容如下:
#include<stdio.h>int main() {printf("hello world!\n");return 0;
}
这看起来就是个普通的c程序!使用make编译它,并像执行普通的应用程序一样执行它,正常输出就如同一个最普通的c程序!好吧,它实际上也就是个简单的c程序。展示它是为了说明,在引入dpdk库之前,它就是一个普通的c程序,因此调用dpdk库就如同调用stdio库一样便捷。
下面给出一个真正与DPDK相关的hello world程序。
#include<stdio.h>
#include <rte_eal.h>int main(int argc, char *argv[]) {if(rte_eal_init(argc, argv) < 0){rte_exit(EXIT_FAILURE, "Error with eal init\n");}printf("hello world!\n");return 0;
}
它切实地调用了eal库中的 rte_eal_init 函数,完成了对底层的抽象,另外,可以通过函数的入参去控制初始化设备的具体内容,不过,目前为止这些并不重要。
编译并执行上述文件,会输出:
EAL: Detected 4 lcore(s)
EAL: Detected 1 NUMA nodes
EAL: Multi-process socket /var/run/dpdk/rte/mp_socket
EAL: No available hugepages reported in hugepages-1048576kB
EAL: Probing VFIO support...
EAL: VFIO support initialized
EAL: PCI device 0000:02:01.0 on NUMA socket -1
EAL: Invalid NUMA socket, default to 0
EAL: probe driver: 8086:100f net_e1000_em
EAL: PCI device 0000:02:02.0 on NUMA socket -1
EAL: Invalid NUMA socket, default to 0
EAL: probe driver: 8086:100f net_e1000_em
EAL: PCI device 0000:03:00.0 on NUMA socket -1
EAL: Invalid NUMA socket, default to 0
EAL: probe driver: 15ad:7b0 net_vmxnet3
EAL: PCI device 0000:0b:00.0 on NUMA socket -1
EAL: Invalid NUMA socket, default to 0
EAL: probe driver: 15ad:7b0 net_vmxnet3
hello world!
前面的打印展示了一些底层初始化的细节,包括核心数量和NUMA节点数量,数量为1表示我的机器实际不支持NUMA,另外,它还提示我操作系统不支持大页,并且有许多的网卡绑定错误NUMA socket的提示,不过无妨,NUMA及大页的支持并不是DPDK程序运行所必须的,因此rte_eal_init最终没有报错,程序也正常地打印出来了 “hello world!”。
这篇关于【DPDK学习路径】四、输出hello world!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!