Commit a1c82311 authored by Robert Richter's avatar Robert Richter Committed by Tejun Heo

ahci: Move interrupt enablement code to a separate function

This patch refactors ahci_init_interrupts() and moves msi code to a
separate function. Need the split since we add msix initialization in
a later patch. The initialization for msix will be done after msi but
before intx.
Signed-off-by: default avatarRobert Richter <rrichter@cavium.com>
Signed-off-by: default avatarTejun Heo <tj@kernel.org>
parent 8485187b
...@@ -1201,17 +1201,17 @@ static inline void ahci_gtf_filter_workaround(struct ata_host *host) ...@@ -1201,17 +1201,17 @@ static inline void ahci_gtf_filter_workaround(struct ata_host *host)
{} {}
#endif #endif
static int ahci_init_interrupts(struct pci_dev *pdev, unsigned int n_ports, static int ahci_init_msi(struct pci_dev *pdev, unsigned int n_ports,
struct ahci_host_priv *hpriv) struct ahci_host_priv *hpriv)
{ {
int rc, nvec; int rc, nvec;
if (hpriv->flags & AHCI_HFLAG_NO_MSI) if (hpriv->flags & AHCI_HFLAG_NO_MSI)
goto intx; return -ENODEV;
nvec = pci_msi_vec_count(pdev); nvec = pci_msi_vec_count(pdev);
if (nvec < 0) if (nvec < 0)
goto intx; return nvec;
/* /*
* If number of MSIs is less than number of ports then Sharing Last * If number of MSIs is less than number of ports then Sharing Last
...@@ -1224,8 +1224,8 @@ static int ahci_init_interrupts(struct pci_dev *pdev, unsigned int n_ports, ...@@ -1224,8 +1224,8 @@ static int ahci_init_interrupts(struct pci_dev *pdev, unsigned int n_ports,
rc = pci_enable_msi_exact(pdev, nvec); rc = pci_enable_msi_exact(pdev, nvec);
if (rc == -ENOSPC) if (rc == -ENOSPC)
goto single_msi; goto single_msi;
else if (rc < 0) if (rc < 0)
goto intx; return rc;
/* fallback to single MSI mode if the controller enforced MRSM mode */ /* fallback to single MSI mode if the controller enforced MRSM mode */
if (readl(hpriv->mmio + HOST_CTL) & HOST_MRSM) { if (readl(hpriv->mmio + HOST_CTL) & HOST_MRSM) {
...@@ -1240,12 +1240,25 @@ static int ahci_init_interrupts(struct pci_dev *pdev, unsigned int n_ports, ...@@ -1240,12 +1240,25 @@ static int ahci_init_interrupts(struct pci_dev *pdev, unsigned int n_ports,
return nvec; return nvec;
single_msi: single_msi:
if (pci_enable_msi(pdev)) rc = pci_enable_msi(pdev);
goto intx; if (rc < 0)
return rc;
return 1; return 1;
}
intx: static int ahci_init_interrupts(struct pci_dev *pdev, unsigned int n_ports,
struct ahci_host_priv *hpriv)
{
int nvec;
nvec = ahci_init_msi(pdev, n_ports, hpriv);
if (nvec >= 0)
return nvec;
/* lagacy intx interrupts */
pci_intx(pdev, 1); pci_intx(pdev, 1);
return 0; return 0;
} }
......
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