[dpdk][sysfs][pci] 在dpdk程序中操纵PCI设备

 

〇  需求

在DPDK程序运行时,希望能够实时的操纵PCI 网卡设备的驱动绑定与解绑。

本文的目的是为了调查满足以上需求的,kernel提供的,标准的API都有几种,分别是什么。以确定实施方案。

 

一  背景

我们已知有三个方法:

  1. dpdk_devbind.py

  2. driverctl   [administrator][driver] driverctl 是如何在udev上层管理设备驱动的

  3. sysfs

    [knowledge][linux][sysfs] sysfs文件系统

    [dpdk] 读官方文档(2)    这里有个bind/unbind章节。

 

二  分析

分析driverctl的源码

  driverctl 是一个bash脚本,也是用sysfs实现的。原理如下:

# 加载
> echo pci-stub > /sys/bus/pci/devices/0000:03:00.0/driver_override
> echo 0000:03:00.0 > /sys/bus/pci/devices/0000:03:00.0/driver/unbind
> echo 0000:03:00.0 > /sys/bus/pci/drivers_probe
> 
# 卸载
> echo > /sys/bus/pci/devices/0000:03:00.0/preferred_driver
> echo 0000:03:00.0 > /sys/bus/pci/devices/0000:03:00.0/driver/unbind
> echo 0000:03:00.0 > /sys/bus/pci/drivers_probe
> 

 

分析dpdk_devbind.py的源码

  用lspci配合sysfs实现。

  但是在dpdk-devbind中,做个了一个判断,同时支持新旧两种方式。

  新的方式与 driverctl 的实现相同。

  旧的方式与先前我们在sysfs下的做法一样,用new_id来操作, 如下:

[root@T9 usertools]# echo 0000:00:04.0 > /sys/bus/pci/drivers/igb_uio/unbind 
[root@T9 usertools]# echo "1af4 1000" > /sys/bus/pci/drivers/virtio-pci/new_id
或
[root@T9 usertools]# echo "0000:00:04.0" > /sys/bus/pci/drivers/virtio-pci/bind

 

  根据dpdk-devbind中的注释和邮件列表的patch邮件信息: 新的driver_override方式是kernel version >= 3.15才支持。但是实际调试过程中,我当前在redhat kernel version 3.10的环境里,便已经支持了新的方式了。

  patch: https://patches.linaro.org/patch/27588/ 

三 结论

1.    以上三种方式是同一套接口,都是通过文件系统对sysfs进行读写操作来实现的。

2.    具体的sysfs操作方法有前文提到的两种。 推荐较新的一种,即通过driver_override.

  https://www.kernel.org/doc/Documentation/ABI/testing/sysfs-bus-platform

 

posted on 2018-08-28 15:45  toong  阅读(1294)  评论(0编辑  收藏  举报