[linux-pm] RE: on-ness

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

 



On Mon, Apr 24, 2006 at 04:32:54PM -0500, Woodruff, Richard wrote:
> > Are they?  Does "off" imply the device will have been reset the next
> > time it goes to "on"?  If not, there would seem to be two "off"
> states.
> > Or maybe more ... PCI_D0 is probably "on", but all of the other PCI
> > device states seem to be variants of "off", not of "on".
> 
> That would seem device specific.  It would seem that applying a reset
> when moving from "off" (especially that mapped to PCI_D3) would seem
> reasonable.  As I was told, the rest of the PCI defined states D1-D3 are
> non-functional.  So they are all OFF states.

Yes, they are all off in the sense that they are not operable. However, 
there are definitely different levels of off-ness. When a device is in D3
then it transitions to D0, it is assumed to perform an internal device
reset.

Well, up until the PCI PM Spec 1.2, which adds a field to the PCI PM 
config space called "NoSoftReset". If a device has that set, then it is
an indication that the device does not perform a soft reset (and there-
fore may not lose any state).

In D1 and D2, the devices will not lose as much state (though the amount
is device-specific), but more importantly, the device will not perform a
reset on the transition back to D0, meaning that we don't have to do a
full reinitialization. 

[ The memory savings may be insignificant, but saving ourselves from the
process of reinitialziation is a big plus. For video devices, it's even
more compelling - the framebuffer may be large, a reinit may take a very
long time, and we may not even know how to do a full reinit. ]

> If just happens that in D3 you can safely physically remove the device.

That's not necessarily true, but it's moot for this thread anyway. 

> The current pseudo export
> of these non-functional states doesn't seem so useful.  Having some
> fuzzy level of idleness seems much better.

Maybe. What's more important is getting rid of the pseudo states. The
drivers should export exactly the states that they support, in whatever
fashion makes the most sense to them. For PCI devices that support basic
PM, this will be "D0" and "D3". PCI devices that support D1 and D2 will
export "D1" and "D2" as well. Devices that support other, device-
specific states will export meaningful names for them. 

Different concepts of on-ness should be handled in a similar fashion. It
doesn't really matter if they are sensical strings or if they are digits,
it's all ASCII as it goes through sysfs, and it all has to get parsed,
mapped, and verified at some level. 

> In my current hack attempts I am trying to associate a 'device' D2 state
> with a local device sleep with an async wake up enabled.  In this state
> a devices accesses are locked out until the device wake up event
> happens.  This async wake can be from a device specific wake up or from
> an associated timer resource.  Current DPM enabled OMAP sprinkles
> suspend lock outs inside of drivers which re-suspend queued waiters and
> suspends new requests if the device is in a locked out state.  From many
> devices this creates a device which just reacts with a higher latency.

That sounds promising. Got any patches that you care to post? 

Thanks,


	Patrick

[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