diff options
Diffstat (limited to 'drivers/pci/pci-driver.c')
| -rw-r--r-- | drivers/pci/pci-driver.c | 12 | 
1 files changed, 2 insertions, 10 deletions
diff --git a/drivers/pci/pci-driver.c b/drivers/pci/pci-driver.c index 94c6e2aa03d..6c94fc9489e 100644 --- a/drivers/pci/pci-driver.c +++ b/drivers/pci/pci-driver.c @@ -398,6 +398,8 @@ static void pci_device_shutdown(struct device *dev)  	struct pci_dev *pci_dev = to_pci_dev(dev);  	struct pci_driver *drv = pci_dev->driver; +	pm_runtime_resume(dev); +  	if (drv && drv->shutdown)  		drv->shutdown(pci_dev);  	pci_msi_shutdown(pci_dev); @@ -408,16 +410,6 @@ static void pci_device_shutdown(struct device *dev)  	 * continue to do DMA  	 */  	pci_disable_device(pci_dev); - -	/* -	 * Devices may be enabled to wake up by runtime PM, but they need not -	 * be supposed to wake up the system from its "power off" state (e.g. -	 * ACPI S5).  Therefore disable wakeup for all devices that aren't -	 * supposed to wake up the system at this point.  The state argument -	 * will be ignored by pci_enable_wake(). -	 */ -	if (!device_may_wakeup(dev)) -		pci_enable_wake(pci_dev, PCI_UNKNOWN, false);  }  #ifdef CONFIG_PM  |