diff options
author | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2017-12-15 20:05:48 -0500 |
---|---|---|
committer | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2017-12-15 20:05:48 -0500 |
commit | c51a024e3913e9dbaf4dfcb9aaba825668a89ace (patch) | |
tree | 9772af495ced0bde0d3c58b6e6fb5b395b3afae9 /drivers/pci/pci-driver.c | |
parent | 3487972d7fa6c5143951436ada5933dcf0ec659d (diff) | |
parent | 34fb8f0ba9ceea88e116688f9f53e3802c38aafb (diff) |
Merge back PM core material for v4.16.
Diffstat (limited to 'drivers/pci/pci-driver.c')
-rw-r--r-- | drivers/pci/pci-driver.c | 19 |
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) | |||
838 | Fixup: | 840 | Fixup: |
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" |