From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755387AbdLTOI2 (ORCPT ); Wed, 20 Dec 2017 09:08:28 -0500 Received: from mga03.intel.com ([134.134.136.65]:47260 "EHLO mga03.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755060AbdLTOIZ (ORCPT ); Wed, 20 Dec 2017 09:08:25 -0500 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.45,432,1508828400"; d="scan'208";a="14229052" Message-ID: <1513778901.2592.0.camel@intel.com> Subject: Re: Regression: unable to boot after commit bd9240a18edf ("x86/apic: Add TSC_DEADLINE quirk due to errata") - Surface Pro 4 SKL From: Zhang Rui To: Peter Zijlstra Cc: Thomas Gleixner , LKML , linux-x86 , Len Brown , "Chen, Yu C" Date: Wed, 20 Dec 2017 22:08:21 +0800 In-Reply-To: <20171219172327.bcpss5in2k4346xh@hirez.programming.kicks-ass.net> References: <1511857335.2498.22.camel@intel.com> <1511866741.2441.5.camel@intel.com> <20171128123607.fmgpq76brf6bdkk4@hirez.programming.kicks-ass.net> <1511966690.2750.9.camel@intel.com> <20171218202822.juwyxsd7millme7o@hirez.programming.kicks-ass.net> <1513680504.2569.1.camel@intel.com> <20171219152307.ugmlynst574wsdne@hirez.programming.kicks-ass.net> <1513698161.2745.14.camel@intel.com> <20171219160155.zgu5clv5mj2l4aaj@hirez.programming.kicks-ass.net> <20171219172327.bcpss5in2k4346xh@hirez.programming.kicks-ass.net> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.18.5.2-0ubuntu3 Mime-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, 2017-12-19 at 18:23 +0100, Peter Zijlstra wrote: > On Tue, Dec 19, 2017 at 05:01:55PM +0100, Peter Zijlstra wrote: > > > > On Tue, Dec 19, 2017 at 11:42:41PM +0800, Zhang Rui wrote: > > > > > > On Tue, 2017-12-19 at 16:23 +0100, Peter Zijlstra wrote: > > > > > > > > > > > [    0.000000] ACPI: INT_SRC_OVR (bus 0 bus_irq 0 global_irq 2 > > > > dfl dfl) > > > > [    0.000000] ACPI: IRQ0 used by override. > > > > > > > > So your ACPI table has an override for IRQ2 and routes it to > > > > IRQ0. > > ^ this > > > > > > > > > > > > >  The HPET document says: > > > > > > > >   If the ENABLE_CNF bit and the LEG_RT_CNF bit are both set, > > > > then the > > > >   interrupts will be routed as follows: > > > > > > > >     Timer 0 will be routed to IRQ0 in Non-APIC or IRQ2 in the > > > > I/O APIC > > > But AFAICS, the HPET emulated timer interrupts goes to IRQ0 > > Right, so see that ACPI override, that routes I/O APIC IRQ2 to > > IRQ0, or > > it _should_. > > > > Clearly something is messed up here.. but I've no idea what. That > > whole > > IRQ routing stuff is confusing. > Does this help? > No. thanks, rui > diff --git a/arch/x86/kernel/time.c b/arch/x86/kernel/time.c > index 749d189f8cd4..45675072771c 100644 > --- a/arch/x86/kernel/time.c > +++ b/arch/x86/kernel/time.c > @@ -69,8 +69,6 @@ static struct irqaction irq0  = { >   >  static void __init setup_default_timer_irq(void) >  { > - if (!nr_legacy_irqs()) > - return; >   setup_irq(0, &irq0); >  } >