用户态驱动UIO

加载uio驱动

sudo modprobe uio

simple.c源代码

#include <linux/module.h>
#include <linux/platform_device.h>
#include <linux/uio_driver.h>
#include <linux/slab.h>

struct uio_info kpart_info = {
	.name = "kpart",
	.version = "0.1",
	.irq = UIO_IRQ_NONE,
};

static int drv_kpart_probe(struct device *dev);
static int drv_kpart_remove(struct device *dev);
static struct device_driver uio_dummy_driver={
	.name = "kpart",
	.bus = &platform_bus_type,
	.probe = drv_kpart_probe,
	.remove = drv_kpart_remove,
};

static int drv_kpart_probe(struct device *dev)
{
	printk("drv_kpart_probe(%p)\n", dev);
	kpart_info.mem[0].addr = (unsigned long)kmalloc(1024,GFP_KERNEL);

	if(kpart_info.mem[0].addr==0)
	{
		return -ENOMEM;
	}

	kpart_info.mem[0].memtype = UIO_MEM_LOGICAL;
	kpart_info.mem[0].size = 1024;

	if(uio_register_device(dev,&kpart_info))
		return -ENODEV;

	return 0;
}

static int drv_kpart_remove(struct device *dev)
{
	uio_unregister_device(&kpart_info);
	return 0;
}

static struct platform_device *uio_dummy_device;

static struct platform_device *uio_dummy_device;

static int __init uio_kpart_init(void)
{
	uio_dummy_device = platform_device_register_simple("kpart",-1,NULL,0);
	return driver_register(&uio_dummy_driver);
}

static void __exit uio_kpart_exit(void)
{
	platform_device_unregister(uio_dummy_device);
	driver_unregister(&uio_dummy_driver);
}

module_init(uio_kpart_init);
module_exit(uio_kpart_exit);

MODULE_LICENSE("GPL");
MODULE_AUTHOR("IGB_UIO_TEST");
MODULE_DESCRIPTION("UIO dummy driver");

编译simple.c的Makefile文件

obj-m := simple.o

执行make进行驱动编译

make -C /lib/modules/4.15.0-111-generic/build M=`pwd` modules

生成了simple.ko后加载simple.ko

sudo insmod simple.ko

用户应用程序uio_test.c

#include <stdio.h>
#include <fcntl.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/mman.h>
#include <errno.h>

#define UIO_DEV "/dev/uio0"
#define UIO_ADDR "/sys/class/uio/uio0/maps/map0/addr"
#define UIO_SIZE "/sys/class/uio/uio0/maps/map0/size"

static char uio_addr_buf[16]={0};
static char uio_size_buf[16]={0};

int main(void)
{
	int uio_fd,addr_fd,size_fd;
	int uio_size;
	void *uio_addr,*access_address;
	int n=0;
	char test_buf[20];

	uio_fd = open(UIO_DEV, O_RDWR);
	if(uio_fd<0)
	{
		printf("open uio_dev failed. error number:%s\n",strerror(errno));
		return -1;
	}

	addr_fd = open(UIO_ADDR, O_RDONLY);
	if (addr_fd<0)
	{
		printf("open addr_fd failed.\n");
		return -1;
	}

	size_fd = open(UIO_SIZE, O_RDONLY);
	if(size_fd<0)
	{
		printf("open size_fd failed.\n");
		return -1;
	}

	n = read(addr_fd, uio_addr_buf, sizeof(uio_addr_buf));
	if(n<0)
	{
		printf("read addr_fd failed.\n");
		return -1;
	}

	n = read(size_fd, uio_size_buf, sizeof(uio_size_buf));
	if(n<0)
	{
		printf("read size_fd failed.\n");
		return -1;
	}

	uio_addr = (void*)strtoul(uio_addr_buf,NULL,0);
	uio_size = (int)strtol(uio_size_buf,NULL,0);

	printf("uio_size %d\n", uio_size);
	access_address = mmap(NULL,uio_size,PROT_READ|PROT_WRITE,MAP_SHARED,uio_fd,0);
	if(access_address==(void *)-1)
	{
		printf("mmap failed. error number:%s\n",strerror(errno));
		return -1;
	}

	memcpy(test_buf, access_address, 17);	
	printf("test_buf: %s\n", access_address);

	return 0;
}

编译用户应用测试程序

gcc uio_test.c -o uio_test

执行./uio_test输出

### 回答1: DPDK (Data Plane Development Kit) 是一个开源的数据平面开发工具包。它可以提供高性能的网络 I/O 接口,允许开发人员在用户空间中运行网络应用程序。 igb_uio 是 DPDK 提供的一种用于 Intel 82580/I350 以太网控制器的用户空间驱动程序。要使用 igb_uio 驱动,需要进行以下步骤: 1. 下载 DPDK 并解压缩。 2. 运行 "make config T=x86_64-native-linuxapp-gcc" 来配置 DPDK。 3. 在 .config 文件中找到并启用 "CONFIG_RTE_LIBRTE_IGB_UIO=y" 选项。 4. 运行 "make" 来编译 DPDK。 5. 运行 "make install" 来安装 DPDK。 6. 加载 igb_uio 驱动,运行 "modprobe uio" 和 "insmod build/kmod/igb_uio.ko"。 7. 将网卡绑定到 igb_uio 驱动上,运行 "./usertools/dpdk-devbind.py --bind=igb_uio 网卡名" 在完成这些步骤后,就可以在 DPDK 中使用 igb_uio 驱动了。 注意: - 上面的步骤基于linux系统,在其他系统上安装配置步骤可能有所不同 - 具体操作请参考DPDK官网,这里给出大致流程,需要结合具体DPDK版本参考 ### 回答2: 在DPDK中使用igb_uio驱动需要进行以下步骤: 1. 下载DPDK源代码:首先需要到DPDK官网(https://www.dpdk.org/)下载最新的DPDK源代码。 2. 解压源代码:将下载好的源代码文件解压到一个合适的目录下。 3. 配置编译环境:进入解压后的DPDK源代码目录,在终端中执行命令“make config T=x86_64-native-linuxapp-gcc”配置编译环境。其中,T参数根据自己的处理器架构进行选择,x86_64代表64位。 4. 编译DPDK:继续在终端中执行命令“make”编译DPDK。这一步需要耐心等待编译完成。 5. 设置环境变量:在终端中执行命令“export RTE_SDK=/path/to/dpdk”和“export RTE_TARGET=x86_64-native-linuxapp-gcc”分别设置DPDK的根目录和目标平台。 6. 下载igb_uio驱动:在终端中执行命令“make install T=x86_64-native-linuxapp-gcc”下载igb_uio驱动。这一步会自动从DPDK的软件仓库中下载igb_uio驱动,并将其安装到系统中。 7. 配置驱动:在终端中执行命令“modprobe uio”加载uio驱动,然后执行命令“insmod /path/to/dpdk/x86_64-native-linuxapp-gcc/kmod/igb_uio.ko”加载igb_uio驱动。 8. 绑定网卡:执行命令“dpdk-devbind --bind=igb_uio ethX”将指定的网卡绑定到igb_uio驱动。 至此,igb_uio驱动就成功下载、编译、配置完毕。现在可以在DPDK中使用igb_uio驱动来进行高性能网络应用开发了。 ### 回答3: DPDK(Data Plane Development Kit)是一种用于快速数据包处理的开源工具集。在DPDK中,igb_uio是一种用户态UIO(Userspace Input/Output)驱动,用于将网卡设备映射到用户态进程,实现零拷贝和更高的性能。 要下载、编译和配置igb_uio驱动,可以按照以下步骤进行: 1. 首先,确保系统安装了必要的构建工具和依赖项。例如,gcc、make、kernel-headers等。如果缺少相关软件包,可以使用包管理器进行安装。 2. 接下来,下载DPDK源代码。可以从DPDK官方网站(https://www.dpdk.org/)或者DPDK的GitHub仓库中获取最新的源代码。 3. 解压源代码包,并进入解压后的目录。 4. 在终端中,执行以下命令编译DPDK和igb_uio驱动: ``` make config T=x86_64-native-linuxapp-gcc make ``` 这将根据系统架构编译DPDK和igb_uio驱动的二进制文件。 5. 编译完成后,可以使用以下命令将igb_uio驱动安装到系统中: ``` sudo make install T=x86_64-native-linuxapp-gcc ``` 此命令将igb_uio.ko模块复制到适当的系统目录中。 6. 配置igb_uio驱动,使其可以加载并与网卡设备关联。需要编辑DPDK的配置文件(config文件),将CONFIG_RTE_EAL_IGB_UIO=y设置为解除注释,并保存更改。 7. 加载igb_uio驱动模块,可以使用以下命令: ``` sudo modprobe igb_uio ``` 如果成功加载,可以通过执行以下命令检查igb_uio模块是否成功绑定到网卡设备: ``` sudo ./dpdk-devbind.py --status ``` 此命令将显示网卡设备及其绑定状态。 通过按照以上步骤进行,可以成功下载、编译和配置DPDK下的igb_uio驱动。完成后,可以在DPDK应用程序中使用igb_uio驱动来进行高性能的数据包处理。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值