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: Jacob Keller <[email protected]>
---
 drivers/net/ethernet/intel/ice/ice_vf_lib.h | 26 ++++++++++++++++++++++++++
 drivers/net/ethernet/intel/ice/ice_sriov.c  |  7 +------
 2 files changed, 27 insertions(+), 6 deletions(-)

diff --git a/drivers/net/ethernet/intel/ice/ice_vf_lib.h 
b/drivers/net/ethernet/intel/ice/ice_vf_lib.h
index 
a5ee380f8c9e53d6e5ac029b9942db380829a84f..e538b4ecc6cec7d8bd26b7d198197fd5c3ed2e60
 100644
--- a/drivers/net/ethernet/intel/ice/ice_vf_lib.h
+++ b/drivers/net/ethernet/intel/ice/ice_vf_lib.h
@@ -239,6 +239,26 @@ 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);
+
+/**
+ * ice_get_vf_by_dev - Get pointer to VF by VF PCI device pointer
+ * @pf: the PF private structure
+ * @vf_dev: the VF PCI device pointer
+ *
+ * Convenience wrapper to call ice_get_vf_by_id() using pci_iov_vf_id() to get
+ * the 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 +285,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)
 {
 }
diff --git a/drivers/net/ethernet/intel/ice/ice_sriov.c 
b/drivers/net/ethernet/intel/ice/ice_sriov.c
index 
964c474322196fa8875767ac2667be5d550a6765..9ce4c4db400e1239edf974ae85d27da3abf4c083
 100644
--- a/drivers/net/ethernet/intel/ice/ice_sriov.c
+++ b/drivers/net/ethernet/intel/ice/ice_sriov.c
@@ -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;
 

-- 
2.48.1.397.gec9d649cc640

Reply via email to