[dpdk-dev] [ovs-discuss] [announce] driverctl: utility for persistent alternative driver binding
Gray, Mark D
mark.d.gray at intel.com
Fri Dec 4 16:44:35 CET 2015
I welcome this initiative, one question below:
> -----Original Message-----
> From: discuss [mailto:discuss-bounces at openvswitch.org] On Behalf Of Panu
> Matilainen
> Sent: Friday, December 4, 2015 10:54 AM
> To: dev at dpdk.org; users at dpdk.org; dev at openvswitch.org;
> discuss at openvswitch.org
> Subject: [ovs-discuss] [announce] driverctl: utility for persistent alternative
> driver binding
>
> Hi all,
>
> While this is not directly related to DPDK or OVS, it is potentially
> useful for users of both, so excuse me for cross-posting.
>
> Quoting from the project README (for the full text see
> http://laiskiainen.org/git/?p=driverctl.git;a=blob_plain;f=README)
>
> > driverctl is a tool for manipulating and inspecting the system
> > device driver choices.
> >
> > Devices are normally assigned to their sole designated kernel driver
> > by default. However in some situations it may be desireable to
> > override that default, for example to try an older driver to
> > work around a regression in a driver or to try an experimental
> > alternative driver. Another common use-case is pass-through
> > drivers and driver stubs to allow userspace to drive the device,
> > such as in case of virtualization.
> >
> > driverctl integrates with udev to support overriding
> > driver selection for both cold- and hotplugged devices from the
> > moment of discovery, but can also change already assigned drivers,
> > assuming they are not in use by the system. The driver overrides
> > created by driverctl are persistent across system reboots
> > by default.
> >
> > Usage
> > -----
> >
> > Find devices currently driven by ixgbe driver:
> >
> > # driverctl -v list-devices | grep ixgbe
> > 0000:01:00.0 ixgbe (Ethernet 10G 4P X520/I350 rNDC)
> > 0000:01:00.1 ixgbe (Ethernet 10G 4P X520/I350 rNDC)
> >
> > Change them to use the vfio-pci driver:
> > # driverctl set-override 0000:01:00.0 vfio-pci
> > # driverctl set-override 0000:01:00.1 vfio-pci
> >
> > Find devices with driver overrides:
> > # driverctl -v list-devices|grep \\*
> > 0000:01:00.0 vfio-pci [*] (Ethernet 10G 4P X520/I350 rNDC)
> > 0000:01:00.1 vfio-pci [*] (Ethernet 10G 4P X520/I350 rNDC)
> >
> > Remove the override from slot 0000:01:00.1:
> > # driverctl unset-override 0000:01:00.1
>
> DPDK of course has its own dpdk_nic_bind(.py) tool for this purpose, the
> main differences to driverctl are:
> - driverctl bindings are persistent across system boots
[Gray, Mark D] This is great!
Will this integrate with, for example in Red Hat-based systems, /etc/sysconfig/network-scripts/ifcfg-X? In DPDK, could we then
potentially reference devices by that (arbitrary) name?
> - driverctl bindings take place immediately on cold- and hotplug
> - driverctl is a generic tool not limited to network adapters
> - dpdk_nic_bind being a special purpose tool has many more
> sanity checks for its supported use-cases
> - dpdk_nic_bind supports binding multiple NICs at once
>
> The project currently lives at
> http://laiskiainen.org/git/?p=driverctl.git
>
> Feedback, patches etc are welcome.
>
> - Panu -
> _______________________________________________
> discuss mailing list
> discuss at openvswitch.org
> http://openvswitch.org/mailman/listinfo/discuss
More information about the dev
mailing list