Commit 2d925db5 authored by Jacob Keller's avatar Jacob Keller Committed by Tony Nguyen
Browse files

ice: introduce ice_get_vf_by_dev() wrapper



The ice_get_vf_by_id() function is used to obtain a reference to a VF
structure based on its ID. The ice_sriov_set_msix_vec_count() function
needs to get a VF reference starting from the VF PCI device, and uses
pci_iov_vf_id() to get the VF ID. This pattern is currently uncommon in the
ice driver. However, the live migration module will introduce many more
such locations.

Add a helper wrapper ice_get_vf_by_dev() which takes the VF PCI device and
calls ice_get_vf_by_id() using pci_iov_vf_id() to get the VF ID.

Signed-off-by: default avatarJacob Keller <jacob.e.keller@intel.com>
Reviewed-by: default avatarPrzemek Kitszel <przemyslaw.kitszel@intel.com>
Tested-by: default avatarRafal Romanowski <rafal.romanowski@intel.com>
Signed-off-by: default avatarTony Nguyen <anthony.l.nguyen@intel.com>
parent 92268349
Loading
Loading
Loading
Loading
+1 −6
Original line number Diff line number Diff line
@@ -933,7 +933,6 @@ int ice_sriov_set_msix_vec_count(struct pci_dev *vf_dev, int msix_vec_count)
	bool needs_rebuild = false;
	struct ice_vsi *vsi;
	struct ice_vf *vf;
	int id;

	if (!ice_get_num_vfs(pf))
		return -ENOENT;
@@ -952,11 +951,7 @@ int ice_sriov_set_msix_vec_count(struct pci_dev *vf_dev, int msix_vec_count)
	if (msix_vec_count < ICE_MIN_INTR_PER_VF)
		return -EINVAL;

	id = pci_iov_vf_id(vf_dev);
	if (id < 0)
		return id;

	vf = ice_get_vf_by_id(pf, id);
	vf = ice_get_vf_by_dev(pf, vf_dev);
	if (!vf)
		return -ENOENT;

+18 −0
Original line number Diff line number Diff line
@@ -239,6 +239,18 @@ static inline bool ice_vf_is_lldp_ena(struct ice_vf *vf)

#ifdef CONFIG_PCI_IOV
struct ice_vf *ice_get_vf_by_id(struct ice_pf *pf, u16 vf_id);

static inline struct ice_vf *ice_get_vf_by_dev(struct ice_pf *pf,
					       struct pci_dev *vf_dev)
{
	int vf_id = pci_iov_vf_id(vf_dev);

	if (vf_id < 0)
		return NULL;

	return ice_get_vf_by_id(pf, pci_iov_vf_id(vf_dev));
}

void ice_put_vf(struct ice_vf *vf);
bool ice_has_vfs(struct ice_pf *pf);
u16 ice_get_num_vfs(struct ice_pf *pf);
@@ -265,6 +277,12 @@ static inline struct ice_vf *ice_get_vf_by_id(struct ice_pf *pf, u16 vf_id)
	return NULL;
}

static inline struct ice_vf *ice_get_vf_by_dev(struct ice_pf *pf,
					       struct pci_dev *vf_dev)
{
	return NULL;
}

static inline void ice_put_vf(struct ice_vf *vf)
{
}