Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932103AbWAaXT3 (ORCPT ); Tue, 31 Jan 2006 18:19:29 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S932106AbWAaXT3 (ORCPT ); Tue, 31 Jan 2006 18:19:29 -0500 Received: from smtp.osdl.org ([65.172.181.4]:39865 "EHLO smtp.osdl.org") by vger.kernel.org with ESMTP id S932103AbWAaXT1 (ORCPT ); Tue, 31 Jan 2006 18:19:27 -0500 Date: Tue, 31 Jan 2006 15:21:13 -0800 From: Andrew Morton To: Andy Whitcroft Cc: johnstul@us.ibm.com, linux-kernel@vger.kernel.org Subject: Re: [PATCH] timer tsc ensure we allow for initial tsc and tsc sync Message-Id: <20060131152113.14781abf.akpm@osdl.org> In-Reply-To: <43DE14F0.5070208@shadowen.org> References: <20060120125342.GA7632@shadowen.org> <1138399887.14289.107.camel@cog.beaverton.ibm.com> <43DE14F0.5070208@shadowen.org> X-Mailer: Sylpheed version 1.0.0 (GTK+ 1.2.10; i386-vine-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2092 Lines: 50 Andy Whitcroft wrote: > > From: John Stultz > > Suppress lost tick detection until we are fully initialised. > This prevents any modifications to the high resolution timers > from causing non-linearities in the flow of time. For example on > an SMP system we resyncronise the TSC values for all processors. > This results in a TSC reset which will be seen as a huge apparent > tick loss. This can cause premature expiry of timers and in extreme > cases can cause the soft lockup detection to fire. > > Acked-by: Andy Whitcroft > > diff --git a/arch/i386/kernel/timers/timer_tsc.c b/arch/i386/kernel/timers/timer_tsc.c > --- a/arch/i386/kernel/timers/timer_tsc.c > +++ b/arch/i386/kernel/timers/timer_tsc.c > @@ -45,6 +45,15 @@ static unsigned long last_tsc_high; /* m > static unsigned long long monotonic_base; > static seqlock_t monotonic_lock = SEQLOCK_UNLOCKED; > > +/* Avoid compensating for lost ticks before TSCs are synched */ > +static int detect_lost_ticks; > +static int __init start_lost_tick_compensation(void) > +{ > + detect_lost_ticks = 1; > + return 0; > +} > +late_initcall(start_lost_tick_compensation); > + > /* convert from cycles(64bits) => nanoseconds (64bits) > * basic equation: > * ns = cycles / (freq / ns_per_sec) > @@ -196,7 +205,8 @@ static void mark_offset_tsc_hpet(void) > > /* lost tick compensation */ > offset = hpet_readl(HPET_T0_CMP) - hpet_tick; > - if (unlikely(((offset - hpet_last) > hpet_tick) && (hpet_last != 0))) { > + if (unlikely(((offset - hpet_last) > hpet_tick) && (hpet_last != 0)) > + && detect_lost_ticks) { Simple enough. John, so you feel that this is 2.6.16 material? Note that the time changes in -mm will blow this change away, so I'd be needing a fresh version of this patch against next-mm, please. - 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/