From mboxrd@z Thu Jan 1 00:00:00 1970 From: Mika Westerberg Subject: Re: [Patch V4 29/42] x86, irq: introduce two helper functions to support irqdomain map operation Date: Fri, 22 Aug 2014 15:41:45 +0300 Message-ID: <20140822124145.GF1660@lahna.fi.intel.com> References: <1402302011-23642-1-git-send-email-jiang.liu@linux.intel.com> <1402302011-23642-30-git-send-email-jiang.liu@linux.intel.com> <20140821141729.GT1660@lahna.fi.intel.com> <20140821165728.GV1660@lahna.fi.intel.com> <53F641E0.8040401@linux.intel.com> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Return-path: Received: from mga02.intel.com ([134.134.136.20]:61628 "EHLO mga02.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1756166AbaHVMl6 (ORCPT ); Fri, 22 Aug 2014 08:41:58 -0400 Content-Disposition: inline In-Reply-To: <53F641E0.8040401@linux.intel.com> Sender: linux-acpi-owner@vger.kernel.org List-Id: linux-acpi@vger.kernel.org To: Jiang Liu Cc: Benjamin Herrenschmidt , Thomas Gleixner , Grant Likely , Ingo Molnar , "H. Peter Anvin" , "Rafael J. Wysocki" , Bjorn Helgaas , Randy Dunlap , Yinghai Lu , x86@kernel.org, Konrad Rzeszutek Wilk , Andrew Morton , Tony Luck , Joerg Roedel , Paul Gortmaker , Greg Kroah-Hartman , linux-kernel@vger.kernel.org, linux-pci@vger.kernel.org, linux-acpi@vger.kernel.org, Ingo Molnar On Fri, Aug 22, 2014 at 03:00:48AM +0800, Jiang Liu wrote: > Hi Mika, > I'm out of office until next Tuesday. Will handle this > when back to work. Could you please help to take a look at > mp_set_gsi_attr() to check whether it could be used to resolve > this issue. The problem seems to be that when we allocate the legacy 16 IRQ range, they will be set to edge-triggered and then info->set is set to 1 preventing any further configuration (if I understand that part right). I tried simply following and it seems to work. Not sure how correct it is, though. diff --git a/arch/x86/kernel/apic/io_apic.c b/arch/x86/kernel/apic/io_apic.c index 29290f554e79..29c5d4fa9e86 100644 --- a/arch/x86/kernel/apic/io_apic.c +++ b/arch/x86/kernel/apic/io_apic.c @@ -1531,8 +1531,7 @@ static void __init setup_IO_APIC_irqs(void) KERN_DEBUG " apic %d pin %d not connected\n", mpc_ioapic_id(ioapic), pin); else - pin_2_irq(idx, ioapic, pin, - ioapic ? 0 : IOAPIC_MAP_ALLOC); + pin_2_irq(idx, ioapic, pin, 0); } }