2010/6/2 Thomas Gleixner <tglx@xxxxxxxxxxxxx>: > On Wed, 2 Jun 2010, Arve Hjønnevåg wrote: >> 2010/6/2 Thomas Gleixner <tglx@xxxxxxxxxxxxx>: >> > On Tue, 1 Jun 2010, Arve Hjønnevåg wrote: >> >> >> >> Because suspend itself causes you to not be idle you cannot abort >> >> suspend just because you are not idle anymore. >> > >> > You still are addicted to the current suspend mechanism. :) >> > >> >> No I want you to stop confusing low power idle modes with suspend. I >> know how to enter low power modes from idle if that low power mode is >> not too disruptive. > > What prevents us from going into a disruptive mode from idle ? I don't > see a reason - except crappy ACPI stuff, which I'm happy to ignore. > What do you consider disruptive? Disabling active interrupts? Stopping the monotonic clock? >> > If I understood you correctly then you can shutdown the CPU in idle >> > completelty already, but that's not enough due to: >> > >> > 1) crappy applications keeping the cpu away from idle >> > 2) timers firing >> > >> > Would solving those two issues be sufficient for you or am I missing >> > something ? >> >> Solving those two is enough for current android phones, but it may not >> be enough for other android devices. > > In which way ? May not be enough is a pretty vague statement. They may not be based on hardware that can get to the same power mode from idle as suspend. This could be acpi based hardware, it could be like the hardware we started with that did not have regular timers that could run in the low power mode, or devices could loose their state in the lowest power mode. > >> 1 is not solvable (meaning we cannot fix all apps), > > We can mitigate it with cgroups and confine crap there, i.e. force > idle them. > I think using suspend is much simpler. It avoids having to worry about dependencies between processes. >> and 2 is difficult to fix since the periodic >> work is useful while the device is actually in use. One possible way >> to solve 2 is to allow timers on a not-idle clock. > > That's what I had in mind. > >> Unrelated to Android, I also want to use opportunistic suspend on my >> desktop. > > I expect that intel/amd fixing their stuff is going to happen way > before we sprinkled suspend blockers over a full featured desktop > distro. > You do not need to sprinkle suspend blocker all over the distro for it to be useful. You can convert the existing auto-suspend code to use opportunistic suspend and all apps that don't use suspend blocker will behave as they do today while allowing apps to use suspend blockers to keep the system running after the auto-suspend timeout expired. -- Arve Hjønnevåg _______________________________________________ linux-pm mailing list linux-pm@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linux-foundation.org/mailman/listinfo/linux-pm