From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1762365AbYJJQbU (ORCPT ); Fri, 10 Oct 2008 12:31:20 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1759784AbYJJQbK (ORCPT ); Fri, 10 Oct 2008 12:31:10 -0400 Received: from gv-out-0910.google.com ([216.239.58.185]:13625 "EHLO gv-out-0910.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1759615AbYJJQbI (ORCPT ); Fri, 10 Oct 2008 12:31:08 -0400 DomainKey-Signature: a=rsa-sha1; c=nofws; d=gmail.com; s=gamma; h=date:from:to:cc:subject:message-id:references:mime-version :content-type:content-disposition:in-reply-to:user-agent; b=yFzEioURUCgw7dFC/6JtnxgfworYDG0AjpTlRE2wnUuC8hWGDEOnnc/AkIjCXkgzJ4 u4L31+auarDwJixyiWH1cdhHVpndoT/U/TKGaDGW38yPAhpwbp1SIi/Ykd5tp+rlvpBR xFPBYf3IxPPHGeR9laUUVnzq46WLox3u08w9g= Date: Fri, 10 Oct 2008 20:31:01 +0400 From: Cyrill Gorcunov To: "Pallipadi, Venkatesh" Cc: Ingo Molnar , "Maciej W. Rozycki" , LKML Subject: Re: [PATCH] x86: apic - unify APIC_DIVISOR Message-ID: <20081010163101.GG7328@localhost> References: <20081010150017.GD7328@localhost> <7E82351C108FA840AB1866AC776AEC46378236B8@orsmsx505.amr.corp.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <7E82351C108FA840AB1866AC776AEC46378236B8@orsmsx505.amr.corp.intel.com> User-Agent: Mutt/1.5.17+20080114 (2008-01-14) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org [Pallipadi, Venkatesh - Fri, Oct 10, 2008 at 09:11:06AM -0700] | | | >-----Original Message----- | >From: Cyrill Gorcunov [mailto:gorcunov@gmail.com] | >Sent: Friday, October 10, 2008 8:00 AM | >To: Ingo Molnar; Maciej W. Rozycki | >Cc: LKML; Pallipadi, Venkatesh | >Subject: [PATCH] x86: apic - unify APIC_DIVISOR | > | >Use APIC_DIVISOR being set to 16 for both 32/64bit | >mode. To escape APIC timer underflow during calibration | >set it to the maximum possible value. | > | >Also typo error (CONFG instead of proper CONFIG) fixed. | >The error was catched by Venkatesh Pallipadi, thanks a lot Venkatesh! | >See details on http://lkml.org/lkml/2008/10/9/425 | > | >Reported-by: Venkatesh Pallipad | >Signed-off-by: Cyrill Gorcunov | >--- | > | >Index: linux-2.6.git/arch/x86/kernel/apic.c | >=================================================================== | >--- linux-2.6.git.orig/arch/x86/kernel/apic.c 2008-09-26 | >20:43:47.000000000 +0400 | >+++ linux-2.6.git/arch/x86/kernel/apic.c 2008-10-10 | >16:37:26.000000000 +0400 | >@@ -332,11 +332,7 @@ int lapic_get_maxlvt(void) | > */ | > | > /* Clock divisor */ | >-#ifdef CONFG_X86_64 | >-#define APIC_DIVISOR 1 | >-#else | > #define APIC_DIVISOR 16 | >-#endif | > | > /* | > * This function sets up the local APIC timer, with a timeout of | >@@ -592,10 +588,10 @@ static int __init calibrate_APIC_clock(v | > global_clock_event->event_handler = lapic_cal_handler; | > | > /* | >- * Setup the APIC counter to 1e9. There is no way the lapic | >+ * Setup the APIC counter to maximum. There is no way the lapic | > * can underflow in the 100ms detection time frame | > */ | >- __setup_APIC_LVTT(1000000000, 0, 0); | >+ __setup_APIC_LVTT(0xffffffff, 0, 0); | > | > /* Let the interrupts run */ | > local_irq_enable(); | > | | Agree with the APIC_DIVISOR part. | | But, not sure why/how the second change is related to this APIC_DIVISOR being 16. | Also, another nit. Technically we are not setting the "APIC counter to maximum" | as we do divide by 16 before programming initial count register in __setup_APIC_LVTT(). | | Thanks, | Venki | >>From __setup_APIC_LVTT(0xffffffff, 0, 0) caller point of view we do set maximum possible value. How you could make it bigger? (without additional changes _inside_ __setup_APIC_LVTT itself). Actually I wouldn't mind if you fix the comment if you don't like this 'correlation' btw CLKs divisor and APIC_DIVISOR. No problem :) - Cyrill -