]> bbs.cooldavid.org Git - net-next-2.6.git/blobdiff - drivers/ata/ahci.c
ahci: Factor out PCI specifics from ahci_reset_controller()
[net-next-2.6.git] / drivers / ata / ahci.c
index e49c32d51fdade4c49e921bec5e6643162540750..189b97c9f0ece2ddffc275865b5dff7454b3f3e9 100644 (file)
@@ -1359,7 +1359,6 @@ static int ahci_deinit_port(struct ata_port *ap, const char **emsg)
 
 static int ahci_reset_controller(struct ata_host *host)
 {
-       struct pci_dev *pdev = to_pci_dev(host->dev);
        struct ahci_host_priv *hpriv = host->private_data;
        void __iomem *mmio = hpriv->mmio;
        u32 tmp;
@@ -1403,7 +1402,17 @@ static int ahci_reset_controller(struct ata_host *host)
                dev_printk(KERN_INFO, host->dev,
                           "skipping global host reset\n");
 
+       return 0;
+}
+
+static int ahci_pci_reset_controller(struct ata_host *host)
+{
+       struct pci_dev *pdev = to_pci_dev(host->dev);
+
+       ahci_reset_controller(host);
+
        if (pdev->vendor == PCI_VENDOR_ID_INTEL) {
+               struct ahci_host_priv *hpriv = host->private_data;
                u16 tmp16;
 
                /* configure PCS */
@@ -2697,7 +2706,7 @@ static int ahci_pci_device_resume(struct pci_dev *pdev)
                return rc;
 
        if (pdev->dev.power.power_state.event == PM_EVENT_SUSPEND) {
-               rc = ahci_reset_controller(host);
+               rc = ahci_pci_reset_controller(host);
                if (rc)
                        return rc;
 
@@ -3437,7 +3446,7 @@ static int ahci_init_one(struct pci_dev *pdev, const struct pci_device_id *ent)
        if (rc)
                return rc;
 
-       rc = ahci_reset_controller(host);
+       rc = ahci_pci_reset_controller(host);
        if (rc)
                return rc;