{}
  #endif
  
- static int ahci_init_interrupts(struct pci_dev *pdev, struct ahci_host_priv *hpriv)
 -int ahci_init_interrupts(struct pci_dev *pdev, unsigned int n_ports,
++static int ahci_init_interrupts(struct pci_dev *pdev, unsigned int n_ports,
+                        struct ahci_host_priv *hpriv)
  {
-       int rc;
-       unsigned int maxvec;
+       int rc, nvec;
  
-       if (!(hpriv->flags & AHCI_HFLAG_NO_MSI)) {
-               rc = pci_enable_msi_block_auto(pdev, &maxvec);
-               if (rc > 0) {
-                       if ((rc == maxvec) || (rc == 1))
-                               return rc;
-                       /*
-                        * Assume that advantage of multipe MSIs is negated,
-                        * so fallback to single MSI mode to save resources
-                        */
-                       pci_disable_msi(pdev);
-                       if (!pci_enable_msi(pdev))
-                               return 1;
-               }
-       }
+       if (hpriv->flags & AHCI_HFLAG_NO_MSI)
+               goto intx;
+ 
+       rc = pci_msi_vec_count(pdev);
+       if (rc < 0)
+               goto intx;
+ 
+       /*
+        * If number of MSIs is less than number of ports then Sharing Last
+        * Message mode could be enforced. In this case assume that advantage
+        * of multipe MSIs is negated and use single MSI mode instead.
+        */
+       if (rc < n_ports)
+               goto single_msi;
+ 
+       nvec = rc;
+       rc = pci_enable_msi_block(pdev, nvec);
+       if (rc)
+               goto intx;
  
+       return nvec;
+ 
+ single_msi:
+       rc = pci_enable_msi(pdev);
+       if (rc)
+               goto intx;
+       return 1;
+ 
+ intx:
        pci_intx(pdev, 1);
        return 0;
  }