On Wed, 4 Jan 2006, Pavel Machek wrote: > On Út 27-12-05 20:22:04, Patrick Mochel wrote: > > Heh, not really. You're not really solving any problems, only giving the > > illusion that you've actually fixed something. > > Except perhaps userspace passing invalid values down to drivers in > pm_message_t.event? It is up to the layer parsing the value to filter out bad values. > > As I mentioned in the thread (currently happening, BTW) on the linux-pm > > list, what you want to do is accept a string that reflects an actual state > > that the device supports. For PCI devices that support low-power states, > > this would be "D1", "D2", "D3", etc. For USB devices, which only support > > an "on" and "suspended" state, the values that this patch parses would > > actually work. > > We want _common_ values, anyway. So, we do not want "D0", "D1", "D2", > "D3hot" in PCI cases. We probably want "on", "D1", "D2", "suspend", > and I'm not sure about those "D1" and "D2" parts. Userspace should not > have to know about details, it will mostly use "on"/"suspend" anyway. D0 - D3 are common for all PCI devices. "on" and "suspend" are not device states. They are conceptual representations of device states. I understand where you are coming from. Most users will only care that a particular device is "on" or "off". That is fine. They will click through a gui that turns off a device and never think any more about it. However, we are not developing an interface for end-users. We're developing an interface that the guis may use. And, along with the guis, there are also people that care about everything in between "on" and "suspend". If we export exactly the device states that a device supports, then we can leave it up to the layers taking user input to translate between the real device states and the user conceptions ("on", "suspend", etc), instead of doing the translation ourselves. That way, the kernel PM layers (as part of the bus drivers), can easily and simply support every device that a device may have. What happens when device manufacturers start coming out with D4, D5, etc (like they have with the CPU C? States)? "suspend" takes on a completely different meaning. With a simple (and accurate) kernel interface, this will never be an issue. > > > One day, when we find device that needs it, we may want to add more > > > states. I don't know about such device currently. > > > > There are many devices already do - there are PCI, PCI-X, PCI Express, > > ACPI devices, etc that do. But, you simply cannot create a single > > decent > > I asked for an example. Hey, calm down. See for yourself: for i in `lspci | cut -d ' ' -f 1 ` do pm_str=`sudo lspci -s $i -vv | grep -A 1 "Power Management" | grep Flags | cut -d ' ' -f 4-5`; if [ ! -z "$pm_str" ] then printf "Device: %s ==> Power States: %s\n" $i "$pm_str" fi done I have a firewire controller in a desktop system, and a ATI Radeon in a T42 that support D1 and D2.. Thanks, Patrick