[linux-pm] ACPI: Make /proc/acpi/wakeup interface handle PCI devices (again)
Rafael J. Wysocki
rjw at sisk.pl
Fri Oct 3 08:10:12 PDT 2008
On Friday, 3 of October 2008, Andrew Morton wrote:
> On Fri, 26 Sep 2008 22:21:47 +0200 "Rafael J. Wysocki" <rjw at sisk.pl> wrote:
>
> > Len,
> >
> > I think we should do this in .27.
>
> Is Len not there? Can some other acpi person please review this for
> 2.6.27 inclusion?
>
>
> > From: Rafael J. Wysocki <rjw at sisk.pl>
> >
> > ACPI: Make /proc/acpi/wakeup interface handle PCI devices (again)
> >
> > Make the ACPI /proc/acpi/wakeup interface set the appropriate
> > wake-up bits of physical devices corresponding to the ACPI
> > devices and make those bits be set initially for devices that are
> > enabled to wake up by default. This is needed to restore the
> > previous behavior for the PCI devices that were previously handled
> > correctly with the help of the /proc/acpi/wakeup interface.
>
> hm, if you say so. It's a bit hard to judge the impact of not fixing this?
There are people for whom /proc/acpi/wakeup worked, but since Tino Keitel
was the only person reporting this problem, I think it's not widespread.
> When is "previous"? Was 2.6.26 similarly busted?
Well, "previous" means "as in 2.6.26 and earlier", so this is a recent
regression.
/proc/acpi/ is going to go away at one point, but I think we shouldn't break
working setups given that the fix is not very intrusive.
> > Signed-off-by: Rafael J. Wysocki <rjw at sisk.pl>
> > ---
> > drivers/acpi/glue.c | 5 ++++-
> > drivers/acpi/sleep/proc.c | 10 ++++++++++
> > 2 files changed, 14 insertions(+), 1 deletion(-)
> >
> > Index: linux-2.6/drivers/acpi/sleep/proc.c
> > ===================================================================
> > --- linux-2.6.orig/drivers/acpi/sleep/proc.c
> > +++ linux-2.6/drivers/acpi/sleep/proc.c
> > @@ -377,6 +377,14 @@ acpi_system_wakeup_device_seq_show(struc
> > return 0;
> > }
> >
> > +static void physical_device_enable_wakeup(struct acpi_device *adev)
> > +{
> > + struct device *dev = acpi_get_physical_device(adev->handle);
> > +
> > + if (dev && device_can_wakeup(dev))
> > + device_set_wakeup_enable(dev, adev->wakeup.state.enabled);
> > +}
> > +
> > static ssize_t
> > acpi_system_write_wakeup_device(struct file *file,
> > const char __user * buffer,
> > @@ -411,6 +419,7 @@ acpi_system_write_wakeup_device(struct f
> > }
> > }
> > if (found_dev) {
> > + physical_device_enable_wakeup(found_dev);
> > list_for_each_safe(node, next, &acpi_wakeup_device_list) {
> > struct acpi_device *dev = container_of(node,
> > struct
> > @@ -428,6 +437,7 @@ acpi_system_write_wakeup_device(struct f
> > dev->pnp.bus_id, found_dev->pnp.bus_id);
> > dev->wakeup.state.enabled =
> > found_dev->wakeup.state.enabled;
> > + physical_device_enable_wakeup(dev);
> > }
> > }
> > }
> > Index: linux-2.6/drivers/acpi/glue.c
> > ===================================================================
> > --- linux-2.6.orig/drivers/acpi/glue.c
> > +++ linux-2.6/drivers/acpi/glue.c
> > @@ -165,8 +165,11 @@ static int acpi_bind_one(struct device *
> > "firmware_node");
> > ret = sysfs_create_link(&acpi_dev->dev.kobj, &dev->kobj,
> > "physical_node");
> > - if (acpi_dev->wakeup.flags.valid)
> > + if (acpi_dev->wakeup.flags.valid) {
> > device_set_wakeup_capable(dev, true);
> > + device_set_wakeup_enable(dev,
> > + acpi_dev->wakeup.state.enabled);
> > + }
> > }
> >
> > return 0;
>
>
>
More information about the linux-pm
mailing list