dpdk20.11.1学习-2.skeleton

本文介绍了DPDK 20.11.1版本中skeleton应用的功能,它是一个简单的二层转发工具,将偶数端口接收到的数据包转发到配对的奇数端口,反之亦然。通过端口初始化、内存缓冲池mbuf_pool和mbuf的使用,实现数据包的接收与转发。编译和运行后,可以观察到端口间的双向转发效果。源码分析包括头文件引用、宏定义、端口初始化、lcore_main线程函数以及main函数的详细内容。
摘要由CSDN通过智能技术生成

一.skeleton功能

基础的二层转发工具。将偶数个网口进行配对,从0接收到的包转发到1口中,从1接收到的包转发到0口中,以此类推。所以端口数需要是偶数个!,仅仅从一个网口抓取数据包转发到另外一个网口,这样做双向转发,相当于桥的功能。其他基础业务都不做。
该例程用到了内存缓冲池mbuf_pool以及mbuf进行接包转包。

二.编译及运行结果

cd examples/skeleton
make
cd build
sudo ./basicfwd

结果

EAL: Detected 1 lcore(s)
EAL: Detected 1 NUMA nodes
EAL: Detected shared linkage of DPDK
EAL: Multi-process socket /var/run/dpdk/rte/mp_socket
EAL: Selected IOVA mode 'PA'
EAL: No available hugepages reported in hugepages-1048576kB
EAL: Probing VFIO support...
EAL:   Invalid NUMA socket, default to 0
EAL:   Invalid NUMA socket, default to 0
EAL: Probe PCI driver: net_e1000_em (8086:100f) device: 0000:02:06.0 (socket 0)
EAL: Error reading from file descriptor 10: Input/output error
EAL:   Invalid NUMA socket, default to 0
EAL: Probe PCI driver: net_e1000_em (8086:100f) device: 0000:02:07.0 (socket 0)
EAL: Error reading from file descriptor 18: Input/output error
EAL: No legacy callbacks, legacy socket not created
EAL: Error enabling interrupts for fd 10 (Input/output error)
Port 0 MAC: 00 0c 29 9b cf 5b
EAL: Error enabling interrupts for fd 18 (Input/output error)
Port 1 MAC: 00 0c 29 9b cf 65

Core 0 forwarding packets. [Ctrl+C to quit]

三.源码分析

1.头文件引用及宏定义

#include <stdint.h>
#include <inttypes.h>
#include <rte_eal.h>
#include <rte_ethdev.h>
#include <rte_cycles.h>
#include <rte_lcore.h>
#include <rte_mbuf.h>

#define RX_RING_SIZE 1024   //接收环的大小
#define TX_RING_SIZE 1024   //发送环的大小

#define NUM_MBUFS 8191//每个网口可以挂最多NUM_MBUFS个包(rx+tx)
#define MBUF_CACHE_SIZE 250//与内存以及高速缓存起有关
#define BURST_SIZE 32  //调用一次函数,从物理层获取的最大包数量


//网口默认配置,RX接收的数据包大小默认为ETHER链路帧包的最大值(MTU)
//以太网端口使用rte_eth_dev_configure()函数和port_conf_default结构以默认设置进行配置 :
static const struct rte_eth_conf port_conf_default = {
   
	.rxmode = {
   
		.max_rx_pkt_len = RTE_ETHER_MAX_LEN,
	},
};

2.端口初始化port_init

/* basicfwd.c: Basic DPDK skeleton forwarding example. */

/*
 * Initializes a given port using global settings and with the RX buffers
 * coming from the mbuf_pool passed as a parameter.
 */
 //基本转发应用程序中使用的端口初始化的主要功能部分
 //1.获取可用 eth 的个数
//2.配置网卡设备
//3.每个 port
DPDK-20.11.1是一个开源的数据平面开发工具包,用于提高网络包处理性能。它是在Intel公司的推动下发起的,旨在提供一个高效灵活的解决方案,帮助开发人员利用现代多核处理器的强大计算能力,处理网络流量。 DPDK-20.11.1具有以下几个主要特点: 1. 高性能:DPDK-20.11.1能够充分利用现代多核处理器的并行计算能力,通过绕过操作系统内核的网络协议栈,直接访问网络包,实现高吞吐量的数据平面处理。 2. 低延迟:DPDK-20.11.1通过优化数据包处理的方式,减少了处理网络包的延迟。它采用零拷贝技术,避免了数据复制带来的额外延迟,并提供了高效的队列管理和调度算法。 3. 硬件加速:DPDK-20.11.1支持基于硬件的加速技术,如Intel的快速数据平面技术(Intel Quick Data Plane)和英特尔架构内置的虚拟化扩展(Intel Virtualization Technology)等,进一步提高了网络包处理性能。 4. 灵活性:DPDK-20.11.1提供了丰富的API和开发工具,使开发人员能够自定义网络包处理规则和算法,以满足不同应用场景的需求。它支持各种网络协议栈,如TCP/IP、UDP等,并提供了可扩展的软件定义网络(SDN)功能。 通过使用DPDK-20.11.1,开发人员可以实现高性能、低延迟的网络包处理,加速网络应用程序的性能,并提高网络服务的质量和可靠性。它被广泛应用于云计算、网络安全、电信和数据中心等领域,成为了加速网络包处理的重要工具。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值