Re: [linux-pm] suspend blockers & Android integration

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

 



On Sun, 6 Jun 2010 04:14:09 -0700 (PDT)
david@xxxxxxx wrote:

> On Sun, 6 Jun 2010, Florian Mickler wrote:
> 
> > On Sun, 6 Jun 2010 12:19:08 +0200
> > Vitaly Wool <vitalywool@xxxxxxxxx> wrote:
> >
> >> 2010/6/6  <david@xxxxxxx>:
> >>
> >>> as an example (taken from this thread).
> >>>
> >>> system A needs to wake up to get a battery reading, store it and go back to
> >>> sleep, It does so every 10 seconds. But when it does so it only runs the one
> >>> process and then goes back to sleep.
> >>>
> >>> system B has the same need, but wakes up every 10 minutes. but when it does
> >>> so it fully wakes up and this allows the mail app to power up the radio,
> >>> connect to the Internet and start checking for new mail before oppurtunistic
> >>> sleep shuts things down (causing the mail check to fail)
> >>>
> >>> System A will last considerably longer on a battery than System B.
> >>
> >> Exactly, thanks for pointing out the specific example :)
> >>
> >> ~Vitaly
> >
> > This does not affect suspend_blockers nor does suspend_blockers
> > interfere with that.
> >
> > Suspend_blockers allow the system to suspend ("mem">/sys/power/state
> > suspend), when the userspace decides that the device is not in use.
> >
> > So implementing suspend_blockers support does not impact any
> > optimizations done to either system A nor system B.
> 
> Actually, it does.
> 
> system A is what's being proposed by kernel developers, where the 
> untrusted stuff is in a different cgroup and what puts the system to sleep 
> is 'normal' power management. It doesn't sleep as long, but when it wakes 
> up the untrusted stuff is still frozen, so it doesn't stay awake long, or 
> do very much.
> 
> System B is suspend blockers where you are either awake or asleep, and 
> when you wake up you wake up fully, but oppertunistic sleep can interrupt 
> untrusted processes at any time. The system sleeps longer (as fewer things 
> can wake it), but when it wakes up it's fully awake.
> 
> David Lang

You say, that coming back from suspend takes the system to full power
(and everything runs) before it begins the descend into
runtime-low-power?
But are you referring to the fact that coming back
from suspend starts in the zero-idle-state (i.e. "consumes extra
power") or that all processes run when it is not suspended?

Because the latter would of course (theretically) profit from the
framework-controlled-cgroup-freeze/thaw (with and without
opportunistic suspend) while the former should be a problem that
both opportunistic suspend as well as suspend-from-idle have. Or not?

So, here is the question I'm asking myself: If System A were to be
complemented by suspend_blockers, wouldn't it still be better? 

With System A you could try to do a really sophisticated
power-management scheme and so on... but as soon as you allow 3rd-Party
Apps, how do you manage their cross-dependencies? I.e. you can not
automatically detect when App1 needs App2 to function. 
You need to allow all 3rd-Party apps to run as a group. 

So you can perhaps partition your software stack into "untrusted
applications" and different groups of software with audited
dependencies. 

If one group interacts with another group (as will be the case at least
with the "untrusted applications" group) you have to have them both
running at the same time.

This really gets pretty complex. Do you really think something like
this is better than a simple suspend? (I.e. suspend blockers or
having just one group)

Suppose you implement suspend blockers with a cgroup freeze... how do
you implement the freeze/thaw control? 

Cheers,
Flo

p.s.: do you see an possibility for any kind of "priority inheritance"
in the cgroup scheme? I don't.
--
To unsubscribe from this list: send the line "unsubscribe linux-omap" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Arm (vger)]     [ARM Kernel]     [ARM MSM]     [Linux Tegra]     [Linux WPAN Networking]     [Linux Wireless Networking]     [Maemo Users]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite Trails]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux