#endif /* !CONFIG_PM_SLEEP */
 
 #ifdef CONFIG_SUSPEND
+static void pcie_pme_root_status_cleanup(struct pci_dev *pci_dev)
+{
+       /*
+        * Some BIOSes forget to clear Root PME Status bits after system
+        * wakeup, which breaks ACPI-based runtime wakeup on PCI Express.
+        * Clear those bits now just in case (shouldn't hurt).
+        */
+       if (pci_is_pcie(pci_dev) &&
+           pci_pcie_type(pci_dev) == PCI_EXP_TYPE_ROOT_PORT)
+               pcie_clear_root_pme_status(pci_dev);
+}
 
 static int pci_pm_suspend(struct device *dev)
 {
        if (pci_has_legacy_pm_support(pci_dev))
                return pci_legacy_resume_early(dev);
 
+       pcie_pme_root_status_cleanup(pci_dev);
+
        if (drv && drv->pm && drv->pm->resume_noirq)
                error = drv->pm->resume_noirq(dev);
 
 
 }
 
 #ifdef CONFIG_PM
-static int pcie_port_resume_noirq(struct device *dev)
-{
-       struct pci_dev *pdev = to_pci_dev(dev);
-
-       /*
-        * Some BIOSes forget to clear Root PME Status bits after system wakeup
-        * which breaks ACPI-based runtime wakeup on PCI Express, so clear those
-        * bits now just in case (shouldn't hurt).
-        */
-       if (pci_pcie_type(pdev) == PCI_EXP_TYPE_ROOT_PORT)
-               pcie_clear_root_pme_status(pdev);
-       return 0;
-}
-
 static int pcie_port_runtime_suspend(struct device *dev)
 {
        return to_pci_dev(dev)->bridge_d3 ? 0 : -EBUSY;
        .thaw           = pcie_port_device_resume,
        .poweroff       = pcie_port_device_suspend,
        .restore        = pcie_port_device_resume,
-       .resume_noirq   = pcie_port_resume_noirq,
        .runtime_suspend = pcie_port_runtime_suspend,
        .runtime_resume = pcie_port_runtime_resume,
        .runtime_idle   = pcie_port_runtime_idle,