Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752912AbdCPRdn (ORCPT ); Thu, 16 Mar 2017 13:33:43 -0400 Received: from smtp5-g21.free.fr ([212.27.42.5]:14396 "EHLO smtp5-g21.free.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752072AbdCPRdl (ORCPT ); Thu, 16 Mar 2017 13:33:41 -0400 Subject: Re: Legacy PCI interrupt support in PCIe host driver From: Mason To: LKML , Linux ARM Cc: Marc Zyngier , Thomas Gleixner , Jason Cooper , linux-pci , Bjorn Helgaas , Thibaud Cornic , Phuong Nguyen , Robin Murphy , Liviu Dudau , Lorenzo Pieralisi , Uwe Kleine-Konig , Rob Herring References: <5612adb6-af5c-9fbf-e725-813ee7fe1b4b@free.fr> Message-ID: <8443b350-6aa6-75f8-af48-892c722fc2d9@free.fr> Date: Thu, 16 Mar 2017 18:33:09 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:51.0) Gecko/20100101 Firefox/51.0 SeaMonkey/2.48 MIME-Version: 1.0 In-Reply-To: <5612adb6-af5c-9fbf-e725-813ee7fe1b4b@free.fr> Content-Type: text/plain; charset=ISO-8859-15 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1668 Lines: 64 On 16/03/2017 16:40, Mason wrote: > Here is my current DT: > > msi0: msi@2e080 { > compatible = "sigma,msi"; > reg = <0x2e04c 0x40>; > interrupt-parent = <&irq0>; > interrupts = <55 IRQ_TYPE_LEVEL_HIGH>; > msi-controller; > num-vectors = <32>; > }; > > pcie@30000000 { > compatible = "sigma,smp8759-pcie"; > reg = <0x30000000 SZ_4M>, <0x2e02c 4>; > device_type = "pci"; > bus-range = <0 3>; > #size-cells = <2>; > #address-cells = <3>; > #interrupt-cells = <1>; > ranges = <0x02000000 0x0 0x00400000 0x30400000 0x0 SZ_60M>; > msi-parent = <&msi0>; > interrupt-parent = <&irq0>; > interrupts = <54 IRQ_TYPE_LEVEL_HIGH>; > }; > > > I traced the action into pdev_fixup_irq() > which calls of_irq_parse_and_map_pci() > > How do I tell Linux that > - All the legacy PCI interrupts are muxed to a single line > - And this line is routed to system interrupt 54 > > Ooooooh... Wait... > > Is this what interrupt-map is used for? > > http://elinux.org/Device_Tree_Usage#Advanced_Interrupt_Mapping I added this to my pcie@30000000 node: interrupt-map = <0 0 0 1 &irq0 54 IRQ_TYPE_LEVEL_HIGH>; to map INTA to system IRQ 54. And now it works much better :-) # cat /proc/interrupts CPU0 19: 1529 GIC-0 29 Edge twd 20: 125 irq0 1 Level serial 22: 0 irq0 54 Level tutu, xhci-hcd:usb1 About shared ISRs. Are they supposed to return IRQ_HANDLED if and only if they handled something? Will that stop the next ISR from being called? I guess if two interrupts fire at the same time, we'll just take two separate exceptions? Regards.