summaryrefslogtreecommitdiffstats
path: root/drivers/pci/pci-driver.c
diff options
context:
space:
mode:
authorRafael J. Wysocki <rafael.j.wysocki@intel.com>2017-12-15 20:05:48 -0500
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>2017-12-15 20:05:48 -0500
commitc51a024e3913e9dbaf4dfcb9aaba825668a89ace (patch)
tree9772af495ced0bde0d3c58b6e6fb5b395b3afae9 /drivers/pci/pci-driver.c
parent3487972d7fa6c5143951436ada5933dcf0ec659d (diff)
parent34fb8f0ba9ceea88e116688f9f53e3802c38aafb (diff)
Merge back PM core material for v4.16.
Diffstat (limited to 'drivers/pci/pci-driver.c')
-rw-r--r--drivers/pci/pci-driver.c19
1 files changed, 17 insertions, 2 deletions
diff --git a/drivers/pci/pci-driver.c b/drivers/pci/pci-driver.c
index 945099d49f8f..9e53e51b91f3 100644
--- a/drivers/pci/pci-driver.c
+++ b/drivers/pci/pci-driver.c
@@ -699,7 +699,7 @@ static void pci_pm_complete(struct device *dev)
699 pm_generic_complete(dev); 699 pm_generic_complete(dev);
700 700
701 /* Resume device if platform firmware has put it in reset-power-on */ 701 /* Resume device if platform firmware has put it in reset-power-on */
702 if (dev->power.direct_complete && pm_resume_via_firmware()) { 702 if (pm_runtime_suspended(dev) && pm_resume_via_firmware()) {
703 pci_power_t pre_sleep_state = pci_dev->current_state; 703 pci_power_t pre_sleep_state = pci_dev->current_state;
704 704
705 pci_update_current_state(pci_dev, pci_dev->current_state); 705 pci_update_current_state(pci_dev, pci_dev->current_state);
@@ -783,8 +783,10 @@ static int pci_pm_suspend_noirq(struct device *dev)
783 struct pci_dev *pci_dev = to_pci_dev(dev); 783 struct pci_dev *pci_dev = to_pci_dev(dev);
784 const struct dev_pm_ops *pm = dev->driver ? dev->driver->pm : NULL; 784 const struct dev_pm_ops *pm = dev->driver ? dev->driver->pm : NULL;
785 785
786 if (dev_pm_smart_suspend_and_suspended(dev)) 786 if (dev_pm_smart_suspend_and_suspended(dev)) {
787 dev->power.may_skip_resume = true;
787 return 0; 788 return 0;
789 }
788 790
789 if (pci_has_legacy_pm_support(pci_dev)) 791 if (pci_has_legacy_pm_support(pci_dev))
790 return pci_legacy_suspend_late(dev, PMSG_SUSPEND); 792 return pci_legacy_suspend_late(dev, PMSG_SUSPEND);
@@ -838,6 +840,16 @@ static int pci_pm_suspend_noirq(struct device *dev)
838Fixup: 840Fixup:
839 pci_fixup_device(pci_fixup_suspend_late, pci_dev); 841 pci_fixup_device(pci_fixup_suspend_late, pci_dev);
840 842
843 /*
844 * If the target system sleep state is suspend-to-idle, it is sufficient
845 * to check whether or not the device's wakeup settings are good for
846 * runtime PM. Otherwise, the pm_resume_via_firmware() check will cause
847 * pci_pm_complete() to take care of fixing up the device's state
848 * anyway, if need be.
849 */
850 dev->power.may_skip_resume = device_may_wakeup(dev) ||
851 !device_can_wakeup(dev);
852
841 return 0; 853 return 0;
842} 854}
843 855
@@ -847,6 +859,9 @@ static int pci_pm_resume_noirq(struct device *dev)
847 struct device_driver *drv = dev->driver; 859 struct device_driver *drv = dev->driver;
848 int error = 0; 860 int error = 0;
849 861
862 if (dev_pm_may_skip_resume(dev))
863 return 0;
864
850 /* 865 /*
851 * Devices with DPM_FLAG_SMART_SUSPEND may be left in runtime suspend 866 * Devices with DPM_FLAG_SMART_SUSPEND may be left in runtime suspend
852 * during system suspend, so update their runtime PM status to "active" 867 * during system suspend, so update their runtime PM status to "active"