diff options
| author | Rafael J. Wysocki <rjw@sisk.pl> | 2008-07-06 21:34:48 -0400 |
|---|---|---|
| committer | Jesse Barnes <jbarnes@virtuousgeek.org> | 2008-07-07 19:26:28 -0400 |
| commit | eb9d0fe40e313c0a74115ef456a2e43a6c8da72f (patch) | |
| tree | 7a90a68b8dc152d49a38469fd6a6a7840954bac2 /include | |
| parent | 0af4b8c4fb31193dc666f4893107a18fef82baab (diff) | |
PCI ACPI: Rework PCI handling of wake-up
* Introduce function acpi_pm_device_sleep_wake() for enabling and
disabling the system wake-up capability of devices that are power
manageable by ACPI.
* Introduce function acpi_bus_can_wakeup() allowing other (dependent)
subsystems to check if ACPI is able to enable the system wake-up
capability of given device.
* Introduce callback .sleep_wake() in struct pci_platform_pm_ops and
for the ACPI PCI 'driver' make it use acpi_pm_device_sleep_wake().
* Introduce callback .can_wakeup() in struct pci_platform_pm_ops and
for the ACPI 'driver' make it use acpi_bus_can_wakeup().
* Move the PME# handlig code out of pci_enable_wake() and split it
into two functions, pci_pme_capable() and pci_pme_active(),
allowing the caller to check if given device is capable of
generating PME# from given power state and to enable/disable the
device's PME# functionality, respectively.
* Modify pci_enable_wake() to use the new ACPI callbacks and the new
PME#-related functions.
* Drop the generic .platform_enable_wakeup() callback that is not
used any more.
* Introduce device_set_wakeup_capable() that will set the
power.can_wakeup flag of given device.
* Rework PCI device PM initialization so that, if given device is
capable of generating wake-up events, either natively through the
PME# mechanism, or with the help of the platform, its
power.can_wakeup flag is set and its power.should_wakeup flag is
unset as appropriate.
* Make ACPI set the power.can_wakeup flag for devices found to be
wake-up capable by it.
* Make the ACPI wake-up code enable/disable GPEs for devices that
have the wakeup.flags.prepared flag set (which means that their
wake-up power has been enabled).
Signed-off-by: Rafael J. Wysocki <rjw@sisk.pl>
Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
Diffstat (limited to 'include')
| -rw-r--r-- | include/acpi/acpi_bus.h | 2 | ||||
| -rw-r--r-- | include/linux/pm_wakeup.h | 26 |
2 files changed, 8 insertions, 20 deletions
diff --git a/include/acpi/acpi_bus.h b/include/acpi/acpi_bus.h index 071daf8db600..7ab5a611e43f 100644 --- a/include/acpi/acpi_bus.h +++ b/include/acpi/acpi_bus.h | |||
| @@ -337,6 +337,7 @@ int acpi_bus_get_status(struct acpi_device *device); | |||
| 337 | int acpi_bus_get_power(acpi_handle handle, int *state); | 337 | int acpi_bus_get_power(acpi_handle handle, int *state); |
| 338 | int acpi_bus_set_power(acpi_handle handle, int state); | 338 | int acpi_bus_set_power(acpi_handle handle, int state); |
| 339 | bool acpi_bus_power_manageable(acpi_handle handle); | 339 | bool acpi_bus_power_manageable(acpi_handle handle); |
| 340 | bool acpi_bus_can_wakeup(acpi_handle handle); | ||
| 340 | #ifdef CONFIG_ACPI_PROC_EVENT | 341 | #ifdef CONFIG_ACPI_PROC_EVENT |
| 341 | int acpi_bus_generate_proc_event(struct acpi_device *device, u8 type, int data); | 342 | int acpi_bus_generate_proc_event(struct acpi_device *device, u8 type, int data); |
| 342 | int acpi_bus_generate_proc_event4(const char *class, const char *bid, u8 type, int data); | 343 | int acpi_bus_generate_proc_event4(const char *class, const char *bid, u8 type, int data); |
| @@ -379,6 +380,7 @@ acpi_handle acpi_get_pci_rootbridge_handle(unsigned int, unsigned int); | |||
| 379 | 380 | ||
| 380 | #ifdef CONFIG_PM_SLEEP | 381 | #ifdef CONFIG_PM_SLEEP |
| 381 | int acpi_pm_device_sleep_state(struct device *, int *); | 382 | int acpi_pm_device_sleep_state(struct device *, int *); |
| 383 | int acpi_pm_device_sleep_wake(struct device *, bool); | ||
| 382 | #else /* !CONFIG_PM_SLEEP */ | 384 | #else /* !CONFIG_PM_SLEEP */ |
| 383 | static inline int acpi_pm_device_sleep_state(struct device *d, int *p) | 385 | static inline int acpi_pm_device_sleep_state(struct device *d, int *p) |
| 384 | { | 386 | { |
diff --git a/include/linux/pm_wakeup.h b/include/linux/pm_wakeup.h index f0d0b2cb8d20..3af0c8d05cdc 100644 --- a/include/linux/pm_wakeup.h +++ b/include/linux/pm_wakeup.h | |||
| @@ -35,6 +35,11 @@ static inline void device_init_wakeup(struct device *dev, int val) | |||
| 35 | dev->power.can_wakeup = dev->power.should_wakeup = !!val; | 35 | dev->power.can_wakeup = dev->power.should_wakeup = !!val; |
| 36 | } | 36 | } |
| 37 | 37 | ||
| 38 | static inline void device_set_wakeup_capable(struct device *dev, int val) | ||
| 39 | { | ||
| 40 | dev->power.can_wakeup = !!val; | ||
| 41 | } | ||
| 42 | |||
| 38 | static inline int device_can_wakeup(struct device *dev) | 43 | static inline int device_can_wakeup(struct device *dev) |
| 39 | { | 44 | { |
| 40 | return dev->power.can_wakeup; | 45 | return dev->power.can_wakeup; |
| @@ -47,21 +52,7 @@ static inline void device_set_wakeup_enable(struct device *dev, int val) | |||
| 47 | 52 | ||
| 48 | static inline int device_may_wakeup(struct device *dev) | 53 | static inline int device_may_wakeup(struct device *dev) |
| 49 | { | 54 | { |
| 50 | return dev->power.can_wakeup & dev->power.should_wakeup; | 55 | return dev->power.can_wakeup && dev->power.should_wakeup; |
| 51 | } | ||
| 52 | |||
| 53 | /* | ||
| 54 | * Platform hook to activate device wakeup capability, if that's not already | ||
| 55 | * handled by enable_irq_wake() etc. | ||
| 56 | * Returns zero on success, else negative errno | ||
| 57 | */ | ||
| 58 | extern int (*platform_enable_wakeup)(struct device *dev, int is_on); | ||
| 59 | |||
| 60 | static inline int call_platform_enable_wakeup(struct device *dev, int is_on) | ||
| 61 | { | ||
| 62 | if (platform_enable_wakeup) | ||
| 63 | return (*platform_enable_wakeup)(dev, is_on); | ||
| 64 | return 0; | ||
| 65 | } | 56 | } |
| 66 | 57 | ||
| 67 | #else /* !CONFIG_PM */ | 58 | #else /* !CONFIG_PM */ |
| @@ -80,11 +71,6 @@ static inline int device_can_wakeup(struct device *dev) | |||
| 80 | #define device_set_wakeup_enable(dev, val) do {} while (0) | 71 | #define device_set_wakeup_enable(dev, val) do {} while (0) |
| 81 | #define device_may_wakeup(dev) 0 | 72 | #define device_may_wakeup(dev) 0 |
| 82 | 73 | ||
| 83 | static inline int call_platform_enable_wakeup(struct device *dev, int is_on) | ||
| 84 | { | ||
| 85 | return 0; | ||
| 86 | } | ||
| 87 | |||
| 88 | #endif /* !CONFIG_PM */ | 74 | #endif /* !CONFIG_PM */ |
| 89 | 75 | ||
| 90 | #endif /* _LINUX_PM_WAKEUP_H */ | 76 | #endif /* _LINUX_PM_WAKEUP_H */ |
