Commit a70d833e authored by Zhu Lingshan's avatar Zhu Lingshan Committed by Michael S. Tsirkin

vDPA/ifcvf: decouple config/dev IRQ requester and vectors allocator from the adapter

This commit decouples the config irq requester, the device
shared irq requester and the MSI vectors allocator from
the adapter. So they can be safely invoked since probe
before the adapter is allocated.
Signed-off-by: default avatarZhu Lingshan <lingshan.zhu@intel.com>
Cc: stable@vger.kernel.org
Message-Id: <20221125145724.1129962-8-lingshan.zhu@intel.com>
Signed-off-by: default avatarMichael S. Tsirkin <mst@redhat.com>
parent f9a9ffb2
...@@ -132,10 +132,9 @@ static void ifcvf_free_irq(struct ifcvf_hw *vf) ...@@ -132,10 +132,9 @@ static void ifcvf_free_irq(struct ifcvf_hw *vf)
* It returns the number of allocated vectors, negative * It returns the number of allocated vectors, negative
* return value when fails. * return value when fails.
*/ */
static int ifcvf_alloc_vectors(struct ifcvf_adapter *adapter) static int ifcvf_alloc_vectors(struct ifcvf_hw *vf)
{ {
struct pci_dev *pdev = adapter->pdev; struct pci_dev *pdev = vf->pdev;
struct ifcvf_hw *vf = &adapter->vf;
int max_intr, ret; int max_intr, ret;
/* all queues and config interrupt */ /* all queues and config interrupt */
...@@ -222,10 +221,9 @@ static int ifcvf_request_vqs_reused_irq(struct ifcvf_hw *vf) ...@@ -222,10 +221,9 @@ static int ifcvf_request_vqs_reused_irq(struct ifcvf_hw *vf)
return -EFAULT; return -EFAULT;
} }
static int ifcvf_request_dev_irq(struct ifcvf_adapter *adapter) static int ifcvf_request_dev_irq(struct ifcvf_hw *vf)
{ {
struct pci_dev *pdev = adapter->pdev; struct pci_dev *pdev = vf->pdev;
struct ifcvf_hw *vf = &adapter->vf;
int i, vector, ret, irq; int i, vector, ret, irq;
vector = 0; vector = 0;
...@@ -276,10 +274,9 @@ static int ifcvf_request_vq_irq(struct ifcvf_hw *vf) ...@@ -276,10 +274,9 @@ static int ifcvf_request_vq_irq(struct ifcvf_hw *vf)
return ret; return ret;
} }
static int ifcvf_request_config_irq(struct ifcvf_adapter *adapter) static int ifcvf_request_config_irq(struct ifcvf_hw *vf)
{ {
struct pci_dev *pdev = adapter->pdev; struct pci_dev *pdev = vf->pdev;
struct ifcvf_hw *vf = &adapter->vf;
int config_vector, ret; int config_vector, ret;
if (vf->msix_vector_status == MSIX_VECTOR_PER_VQ_AND_CONFIG) if (vf->msix_vector_status == MSIX_VECTOR_PER_VQ_AND_CONFIG)
...@@ -322,7 +319,7 @@ static int ifcvf_request_irq(struct ifcvf_adapter *adapter) ...@@ -322,7 +319,7 @@ static int ifcvf_request_irq(struct ifcvf_adapter *adapter)
struct ifcvf_hw *vf = &adapter->vf; struct ifcvf_hw *vf = &adapter->vf;
int nvectors, ret, max_intr; int nvectors, ret, max_intr;
nvectors = ifcvf_alloc_vectors(adapter); nvectors = ifcvf_alloc_vectors(vf);
if (nvectors <= 0) if (nvectors <= 0)
return -EFAULT; return -EFAULT;
...@@ -333,7 +330,7 @@ static int ifcvf_request_irq(struct ifcvf_adapter *adapter) ...@@ -333,7 +330,7 @@ static int ifcvf_request_irq(struct ifcvf_adapter *adapter)
if (nvectors == 1) { if (nvectors == 1) {
vf->msix_vector_status = MSIX_VECTOR_DEV_SHARED; vf->msix_vector_status = MSIX_VECTOR_DEV_SHARED;
ret = ifcvf_request_dev_irq(adapter); ret = ifcvf_request_dev_irq(vf);
return ret; return ret;
} }
...@@ -342,7 +339,7 @@ static int ifcvf_request_irq(struct ifcvf_adapter *adapter) ...@@ -342,7 +339,7 @@ static int ifcvf_request_irq(struct ifcvf_adapter *adapter)
if (ret) if (ret)
return ret; return ret;
ret = ifcvf_request_config_irq(adapter); ret = ifcvf_request_config_irq(vf);
if (ret) if (ret)
return ret; return ret;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment