Re: Attempted summary of suspend-blockers LKML thread

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

 



2010/8/4  <david@xxxxxxx>:
> On Wed, 4 Aug 2010, Arve Hj?nnev?g wrote:
>
>> On Wed, Aug 4, 2010 at 3:31 PM,  <david@xxxxxxx> wrote:
>>>
>>> On Wed, 4 Aug 2010, Matthew Garrett wrote:
>>>
>>>> On Wed, Aug 04, 2010 at 10:51:07PM +0200, Rafael J. Wysocki wrote:
>>>>>
>>>>> On Wednesday, August 04, 2010, Matthew Garrett wrote:
>>>>>>
>>>>>> No! And that's precisely the issue. Android's existing behaviour could
>>>>>> be entirely implemented in the form of binary that manually triggers
>>>>>> suspend when (a) the screen is off and (b) no userspace applications
>>>>>> have indicated that the system shouldn't sleep, except for the wakeup
>>>>>> event race. Imagine the following:
>>>>>>
>>>>>> 1) The policy timeout is about to expire. No applications are holding
>>>>>> wakelocks. The system will suspend providing nothing takes a wakelock.
>>>>>> 2) A network packet arrives indicating an incoming SIP call
>>>>>> 3) The VOIP application takes a wakelock and prevents the phone from
>>>>>> suspending while the call is in progress
>>>>>>
>>>>>> What stops the system going to sleep between (2) and (3)? cgroups
>>>>>> don't,
>>>>>> because the voip app is an otherwise untrusted application that you've
>>>>>> just told the scheduler to ignore.
>>>>>
>>>>> I _think_ you can use the just-merged /sys/power/wakeup_count mechanism
>>>>> to
>>>>> avoid the race (if pm_wakeup_event() is called at 2)).
>>>>
>>>> Yes, I think that solves the problem. The only question then is whether
>>>> it's preferable to use cgroups or suspend fully, which is pretty much up
>>>> to the implementation. In other words, is there a reason we're still
>>>> having this conversation? :) It'd be good to have some feedback from
>>>> Google as to whether this satisfies their functional requirements.
>>>
>>> the proposal that I nade was not to use cgroups to freeze some processes
>>> and
>>> not others, but to use cgroups to decide to ignore some processes when
>>> deciding if the system is idle, stop everything or nothing. cgroups are
>>> just
>>> a way of easily grouping processes (and their children) into different
>>> groups.
>>>
>>
>> That does not avoid the dependency problem. A process may be waiting
>> on a resource that a process you ignore owns. I you ignore the process
>> that owns the resource and enter idle when it is ready to run (or
>> waiting on a timer), you are still effectively blocking the other
>> process.
>
> and if you don't have a wakelock the same thing will happen. If you expect

Not the same thing. If you don't hold a wakelock the entire system
will suspend and when it wakes up it continues where it left off.
Timeout still have time left before they expire.

> the process to take a while you can set a timeout to wake up every 30
> seconds or so and wait again, this would be enough to prevent you from going

I don't think polling is an acceptable solution to this problem. You
user space code know needs to know what "idle" timeout you have
selected so it can choose a faster poll rate. When is it safe to stop
polling?

> to sleep (or am I misunderstanding how long before you go into suspend
> without a wakelock set, see my other e-mail for the full question)
>

We suspend as soon as no wakelocks are held. There is no delay.

-- 
Arve Hjønnevåg
_______________________________________________
linux-pm mailing list
linux-pm@xxxxxxxxxxxxxxxxxxxxxxxxxx
https://lists.linux-foundation.org/mailman/listinfo/linux-pm



[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