diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-10-02 21:32:35 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-10-02 21:32:35 -0400 |
commit | 16642a2e7be23bbda013fc32d8f6c68982eab603 (patch) | |
tree | 346ae485f485f6901e5d8150f0d34d178a7dd448 /drivers/pci/pci-driver.c | |
parent | 51562cba98939da0a1d10fe7c25359b77a069033 (diff) | |
parent | b9142167a2bb979b58b98ffcd928a311b55cbd9f (diff) |
Merge tag 'pm-for-3.7-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm
Pull power management updates from Rafael J Wysocki:
- Improved system suspend/resume and runtime PM handling for the SH
TMU, CMT and MTU2 clock event devices (also used by ARM/shmobile).
- Generic PM domains framework extensions related to cpuidle support
and domain objects lookup using names.
- ARM/shmobile power management updates including improved support for
the SH7372's A4S power domain containing the CPU core.
- cpufreq changes related to AMD CPUs support from Matthew Garrett,
Andre Przywara and Borislav Petkov.
- cpu0 cpufreq driver from Shawn Guo.
- cpufreq governor fixes related to the relaxing of limit from Michal
Pecio.
- OMAP cpufreq updates from Axel Lin and Richard Zhao.
- cpuidle ladder governor fixes related to the disabling of states from
Carsten Emde and me.
- Runtime PM core updates related to the interactions with the system
suspend core from Alan Stern and Kevin Hilman.
- Wakeup sources modification allowing more helper functions to be
called from interrupt context from John Stultz and additional
diagnostic code from Todd Poynor.
- System suspend error code path fix from Feng Hong.
Fixed up conflicts in cpufreq/powernow-k8 that stemmed from the
workqueue fixes conflicting fairly badly with the removal of support for
hardware P-state chips. The changes were independent but somewhat
intertwined.
* tag 'pm-for-3.7-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm: (76 commits)
Revert "PM QoS: Use spinlock in the per-device PM QoS constraints code"
PM / Runtime: let rpm_resume() succeed if RPM_ACTIVE, even when disabled, v2
cpuidle: rename function name "__cpuidle_register_driver", v2
cpufreq: OMAP: Check IS_ERR() instead of NULL for omap_device_get_by_hwmod_name
cpuidle: remove some empty lines
PM: Prevent runtime suspend during system resume
PM QoS: Use spinlock in the per-device PM QoS constraints code
PM / Sleep: use resume event when call dpm_resume_early
cpuidle / ACPI : move cpuidle_device field out of the acpi_processor_power structure
ACPI / processor: remove pointless variable initialization
ACPI / processor: remove unused function parameter
cpufreq: OMAP: remove loops_per_jiffy recalculate for smp
sections: fix section conflicts in drivers/cpufreq
cpufreq: conservative: update frequency when limits are relaxed
cpufreq / ondemand: update frequency when limits are relaxed
properly __init-annotate pm_sysrq_init()
cpufreq: Add a generic cpufreq-cpu0 driver
PM / OPP: Initialize OPP table from device tree
ARM: add cpufreq transiton notifier to adjust loops_per_jiffy for smp
cpufreq: Remove support for hardware P-state chips from powernow-k8
...
Diffstat (limited to 'drivers/pci/pci-driver.c')
-rw-r--r-- | drivers/pci/pci-driver.c | 17 |
1 files changed, 0 insertions, 17 deletions
diff --git a/drivers/pci/pci-driver.c b/drivers/pci/pci-driver.c index 9e1d2959e226..94c6e2aa03d6 100644 --- a/drivers/pci/pci-driver.c +++ b/drivers/pci/pci-driver.c | |||
@@ -607,21 +607,6 @@ static int pci_pm_prepare(struct device *dev) | |||
607 | int error = 0; | 607 | int error = 0; |
608 | 608 | ||
609 | /* | 609 | /* |
610 | * If a PCI device configured to wake up the system from sleep states | ||
611 | * has been suspended at run time and there's a resume request pending | ||
612 | * for it, this is equivalent to the device signaling wakeup, so the | ||
613 | * system suspend operation should be aborted. | ||
614 | */ | ||
615 | pm_runtime_get_noresume(dev); | ||
616 | if (pm_runtime_barrier(dev) && device_may_wakeup(dev)) | ||
617 | pm_wakeup_event(dev, 0); | ||
618 | |||
619 | if (pm_wakeup_pending()) { | ||
620 | pm_runtime_put_sync(dev); | ||
621 | return -EBUSY; | ||
622 | } | ||
623 | |||
624 | /* | ||
625 | * PCI devices suspended at run time need to be resumed at this | 610 | * PCI devices suspended at run time need to be resumed at this |
626 | * point, because in general it is necessary to reconfigure them for | 611 | * point, because in general it is necessary to reconfigure them for |
627 | * system suspend. Namely, if the device is supposed to wake up the | 612 | * system suspend. Namely, if the device is supposed to wake up the |
@@ -644,8 +629,6 @@ static void pci_pm_complete(struct device *dev) | |||
644 | 629 | ||
645 | if (drv && drv->pm && drv->pm->complete) | 630 | if (drv && drv->pm && drv->pm->complete) |
646 | drv->pm->complete(dev); | 631 | drv->pm->complete(dev); |
647 | |||
648 | pm_runtime_put_sync(dev); | ||
649 | } | 632 | } |
650 | 633 | ||
651 | #else /* !CONFIG_PM_SLEEP */ | 634 | #else /* !CONFIG_PM_SLEEP */ |