[linux-pm] [PATCH 0/6] [-mm]: ACPI: duplicate ACPI procfs functions in sysfs

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Saturday 06 January 2007 9:54 pm, Matthew Garrett wrote:
> On Sat, Jan 06, 2007 at 02:21:41PM -0800, David Brownell wrote:
> 
> > Please tell me you mean "devices with a /sys/devices/.../power/wakeup"
> > attribute.  And that ACPI is finally going to start working with those
> > attributes ...
> 
> It's not necessarily possible to map from an ACPI object with a wakeup 
> capability to a Linux device, 

That seems singularly useless then.  If there's no such mapping, there's
really no point to the /proc/acpi/wakeup table... why not just always
enable every possible device as a wakeup source, since that information
is evidently not designed to be usable for anything?

Or are you saying that some of the entries there aren't for "devices"
per se, but for busses, bridges, and so on?  If so, that's not an issue.
At least, not until Linux has drivers for those things.


> so there's going to have to be some degree  
> of interface nastiness.

Interface, or implementation?  One expects that the interface would
be the same regardless of whether or not ACPI gets involved.


> However, some devices can be sensibly mapped,  
> and ideally those should be integrated into 
> /sys/devices/.../power/wakeup.

Yes...


> However, I'm not entirely sure /how/ that integration should happen. If 
> both the Linux driver and ACPI know how to enable wakeup for a device,
> what should writing to power/wakeup do?

Writing to power/wakeup sets the policy for that device:  should it
issue wakeup events, or not?  The answer is "yes" by default, but when
the hardware is broken, or the user doesn't want that, the policy can
be changed without a kernel recompile.

The driver stack needs to know that policy in order to act properly.

For example, USB devices should only be told to use remote wakeup if
their ancestral USB host controller is wakeup-enabled.  And when that
controller isn't wakeup-enabled, it can often enter states which save
more power.  (E.g. turn off oscillators and switch off VBUS power.)

You will notice, by the way, that the USB peripherals will never be
showing up in those ACPI tables... which is a trivial demostration
of the fact that the ACPI wakeup infrastructure is insufficient to
manage system wakeup on Linux.  That USB keyboard, or mouse, that
wakes the system does not appear in those ACPI tables.

Also, a network driver needs to know that it should configure WOL, and
in this mode not that one, etc.

I'd expect drivers and ACPI to cooperate more or less by having the
driver do the standard stuff (like enabling PCI PME#, and enabling
wakeup irqs)), and ACPI not being driver-visible while it does
whatever it must to make those driver directions actually work.


> > > 	So /proc/acpi/wakeup is deprecated by
> > > 	/sys/devices/acpi_system/.../xxx/sleep_state && wakeup. 
> > 
> > Why is ACPI still not coupling such information to the REAL device
> > nodes?  On my laptop, right now without any wakeup-capable USB
> > devices attached, the appended script produces:
> 
> So for example, the PCI0 device on my Thinkpad is an ACPI wakeup device. 
> Investigating the DSDT suggests that this is just a wrapper around a 
> bunch of platform devices, including the ISA bridge. In this case, what 
> real device should we be associating it with?

I'd guess the root bridge... I have a desktop that seems to have the
same structure.  The PS2K and PS2M devices have separate entries in
/proc/acpi/wakeup but the DSDT for PCI0 also talks about them.  A
quick look suggests to me that /proc/acpi/wakeup is discarding the
device tree internal to ACPI ... _SB_.PCI0.SBRG.PS2K._PRW gets
morphed to "PS2K" and discards the PCI0 parentage.

On the other hand, I think that particular ACPI table must have a
habit of being flakey.  I have one machine that claims to have four
different USB host adapters, where the silicon only has three; and
what I'm assuming is a firewire device (S139), where the silicon
most certainly does not have one of those.  And another machine
lists an MMCI (MMC/SD?) that certainly does not exist ...

So it may well be that doing the work to connect those ACPI tables
to the system hardware will let Linux discard all the bogus data,
so it can work better.  :)

- Dave



[Index of Archives]     [Linux ACPI]     [Netdev]     [Ethernet Bridging]     [Linux Wireless]     [CPU Freq]     [Kernel Newbies]     [Fedora Kernel]     [Security]     [Linux for Hams]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux RAID]     [Linux Admin]     [Samba]

  Powered by Linux