util: fixing wrong assumption that PF has to have netdev assigned

libvirt wrongly assumes that VF netdev has to have the
netdev assigned to PF. There is no such requirement in SRIOV standard.
This patch change the virNetDevSwitchdevFeature() function to deal
with SRIOV devices which does not have netdev on PF. Also corrects
one comment about PF netdev assumption.

One example of such devices is ThunderX VNIC.
By applying this change, VF device is used for virNetlinkCommand() as
it is the only netdev assigned to VNIC.

Signed-off-by: Radoslaw Biernacki <radoslaw.biernacki@linaro.org>
Signed-off-by: dann frazier <dann.frazier@canonical.com>
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
Radoslaw Biernacki 2019-01-22 12:26:12 -07:00 committed by Michal Privoznik
parent fb01e1a44d
commit 6452e2f5e1

View File

@ -1355,9 +1355,8 @@ virNetDevGetPhysicalFunction(const char *ifname, char **pfname)
} }
if (!*pfname) { if (!*pfname) {
/* this shouldn't be possible. A VF can't exist unless its /* The SRIOV standard does not require VF netdevs to have
* PF device is bound to a network driver * the netdev assigned to a PF. */
*/
virReportError(VIR_ERR_INTERNAL_ERROR, virReportError(VIR_ERR_INTERNAL_ERROR,
_("The PF device for VF %s has no network device name"), _("The PF device for VF %s has no network device name"),
ifname); ifname);
@ -3178,8 +3177,12 @@ virNetDevSwitchdevFeature(const char *ifname,
if ((is_vf = virNetDevIsVirtualFunction(ifname)) < 0) if ((is_vf = virNetDevIsVirtualFunction(ifname)) < 0)
return ret; return ret;
if (is_vf == 1 && virNetDevGetPhysicalFunction(ifname, &pfname) < 0) if (is_vf == 1) {
goto cleanup; /* Ignore error if PF does not have netdev assigned.
* In that case pfname == NULL. */
if (virNetDevGetPhysicalFunction(ifname, &pfname) < 0)
virResetLastError();
}
pci_device_ptr = pfname ? virNetDevGetPCIDevice(pfname) : pci_device_ptr = pfname ? virNetDevGetPCIDevice(pfname) :
virNetDevGetPCIDevice(ifname); virNetDevGetPCIDevice(ifname);