Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756953Ab0FBHBt (ORCPT ); Wed, 2 Jun 2010 03:01:49 -0400 Received: from www.tglx.de ([62.245.132.106]:51688 "EHLO www.tglx.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751059Ab0FBHBs (ORCPT ); Wed, 2 Jun 2010 03:01:48 -0400 Date: Wed, 2 Jun 2010 09:00:33 +0200 (CEST) From: Thomas Gleixner To: =?ISO-8859-15?Q?Arve_Hj=F8nnev=E5g?= cc: James Bottomley , Peter Zijlstra , tytso@mit.edu, LKML , Florian Mickler , Linux PM , Linux OMAP Mailing List , felipe.balbi@nokia.com, Alan Cox Subject: Re: [linux-pm] [PATCH 0/8] Suspend block api (version 8) In-Reply-To: Message-ID: References: <20100527222514.0a1710bf@lxorguk.ukuu.org.uk> <20100527230806.4deb6de3@lxorguk.ukuu.org.uk> <20100527220949.GB10602@srcf.ucam.org> <20100527232357.6d14fdb2@lxorguk.ukuu.org.uk> <20100527223605.GB11364@srcf.ucam.org> <20100527235546.09f3ce8a@lxorguk.ukuu.org.uk> <20100528043114.GC26177@thunk.org> <1275030704.32462.11.camel@laptop> <1275120618.27810.12699.camel@twins> <1275149418.4503.128.camel@mulgrave.site> <1275340869.2823.344.camel@mulgrave.site> User-Agent: Alpine 2.00 (LFD 1167 2008-08-23) MIME-Version: 1.0 Content-Type: MULTIPART/MIXED; BOUNDARY="8323328-983960478-1275462035=:2933" Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2759 Lines: 64 This message is in MIME format. The first part should be readable text, while the remaining parts are likely unreadable without MIME-aware tools. --8323328-983960478-1275462035=:2933 Content-Type: TEXT/PLAIN; charset=ISO-8859-1 Content-Transfer-Encoding: 8BIT On Tue, 1 Jun 2010, Arve Hj?nnev?g wrote: > 2010/6/1 Thomas Gleixner : > > > > On Mon, 31 May 2010, Arve Hj?nnev?g wrote: > > > >> On Mon, May 31, 2010 at 2:46 PM, Thomas Gleixner wrote: > >> > On Mon, 31 May 2010, James Bottomley wrote: > >> >> > >> >> For MSM hardware, it looks possible to unify the S and C states by doing > >> >> suspend to ram from idle but I'm not sure how much work that is. > >> > > >> > On ARM, it's not rocket science and we have in tree support for this > >> > already (OMAP). I have done the same thing on a Samsung part as a > >> > prove of concept two years ago and it's really easy as the hardware is > >> > sane. Hint: It's designed for mobile devices :) > >> > > >> > >> We already enter the same power state from idle and suspend on msm. In > >> the absence of misbehaving apps, the difference in power consumption > >> is entirely caused by periodic timers in the user-space framework > >> _and_ kernel. It only takes a few timers triggering per second (I > >> think 3 if they do no work) to double the average power consumption on > >> the G1 if the radio is off. We originally added wakelocks because the > >> hardware we had at the time had much lower power consumption in > >> suspend then idle, but we still use suspend because it saves power. > > > > So how do you differentiate between timers which _should_ fire and > > those you do not care about ? > > > > Only alarms are allowed to fire while suspended. > > > We have mechanisms in place to defer timers so the wakeups are > > minimized. If that's not enough we need to revisit. > > > > Deferring the the timers forever without stopping the clock can cause > problems. Our user space code has a lot of timeouts that will trigger > an error if an app does not respond in time. Freezing everything and > stopping the clock while suspended is a lot simpler than trying to > stop individual timers and processes from running. And resume updates timekeeping to account for the slept time. So the only way to get away with that is to sleep under a second or just ignoring the update by avoiding the access to rtc. So how do you keep timekeeping happy ? Thanks, tglx --8323328-983960478-1275462035=:2933-- -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/