Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp550420imj; Thu, 7 Feb 2019 08:16:01 -0800 (PST) X-Google-Smtp-Source: AHgI3IbjV8QWCZP+2C8ePMW2PxvjNgowdgNierJHKJO9mTJQpT5y7RJIYVItTh3ZcozALsygrXp4 X-Received: by 2002:a17:902:20e9:: with SMTP id v38mr16656971plg.250.1549556161119; Thu, 07 Feb 2019 08:16:01 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1549556161; cv=none; d=google.com; s=arc-20160816; b=gcAWNJe5kZupXe1xdh4DrFjRj/0u6Rj2JFqj+SR4zfHRQHfVocjvwFTo6p4leL1Qgd wO79moBNDm/71sS23zn0IAGBgNxib58pGYosSIZA3xHhVPqlJ2TyN+1+EMhejSvQJA42 uEoMwPKEl7ZRKIz4Rje+4271k6AKwQSOgaaXziTiraH4yK2+KSdC9VW2nDKY27xfqnvt wrX6/cH7K8X/RB3Uzk3s+lv1+mxI+Fm02kX/Eqz+O2JPfhlrjQZyiG5bZtmTGfxQRV9X fvP37BBMxmg0/gHoXSqkHKYIMEHuTRu8Q2GrXyW9hiUIuGrSvN/UYm6zt4NFZFQ4rG1V zO8Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=nFeoOiKqV9TZe7Nduyv3WF+iu+EVVIrSse6yz6IM4PY=; b=iy8Npon6BgMqRbT3LldV76R9TvIt1OgfWZLvvYatH61jDYoz0y5MmmkCjOTnCvzuKs dOZSSyNpvLwlmUnGAgJi9UPjnv5UjLBO26NhH/2/FSdjYAWtoDWjWXGihTtZzJXDALEL hAjDWzkqpq5CIEEY63Qvq2lmegHVsAT6Xsfc5L6X6rdzCxro8A61EwBViEKIhZKdOk3A l7VHe3w/nLTxqA87O7W7ssdFDHPVusL/pI+ICJbMTMW9ttO/PKzndYQT0qJK0i4ou7ZZ Mo2PzejpC/Tt+Xsc5iotJ4TH5IQDNgTsya3TF/5ZWuRuJJPwPrPctsUruatPgV8zJV4C V3jQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f17si8798715pgj.208.2019.02.07.08.15.42; Thu, 07 Feb 2019 08:16:01 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726832AbfBGQPI (ORCPT + 99 others); Thu, 7 Feb 2019 11:15:08 -0500 Received: from usa-sjc-mx-foss1.foss.arm.com ([217.140.101.70]:39592 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726558AbfBGQPI (ORCPT ); Thu, 7 Feb 2019 11:15:08 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 77532A78; Thu, 7 Feb 2019 08:15:07 -0800 (PST) Received: from e107981-ln.cambridge.arm.com (e107981-ln.cambridge.arm.com [10.1.197.40]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id F15133F675; Thu, 7 Feb 2019 08:15:05 -0800 (PST) Date: Thu, 7 Feb 2019 16:15:02 +0000 From: Lorenzo Pieralisi To: Kishon Vijay Abraham I Cc: Murali Karicheri , Bjorn Helgaas , Jingoo Han , Gustavo Pimentel , linux-pci@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v2 2/9] PCI: keystone: Modify legacy_irq_handler to check the IRQ_STATUS of INTA/B/C/D Message-ID: <20190207161502.GC21111@e107981-ln.cambridge.arm.com> References: <20190207110924.30716-1-kishon@ti.com> <20190207110924.30716-3-kishon@ti.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190207110924.30716-3-kishon@ti.com> User-Agent: Mutt/1.5.24 (2015-08-30) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Feb 07, 2019 at 04:39:17PM +0530, Kishon Vijay Abraham I wrote: > The legacy interrupt handler directly checks the IRQ_STATUS register > corresponding to a interrupt line inorder to invoke generic_handle_irq. > > While this is okay for K2G platform which has separate interrupt line for > each of the 4 legacy interrupts, AM654 which uses the same PCIe wrapper > has a single interrupt line for all the legacy interrupts. So for AM654 > the interrupt handler won't be able to directly check the IRQ_STATUS > register corresponding to the interrupt line. > > Also the legacy interrupt handler uses 'virq' obtained from > irq_of_parse_and_map to find the correct interrupt line which raised the > interrupt. There is no guarantee that virq assigned for contiguous hardware > irq will be contiguous and the interrupt handler might end up checking > the wrong IRQ_STATUS register. > > In order to overcome the above issues, read the IRQ_STATUS register of > all the 4 legacy interrupts to determine which interrupt was raised. > > Link: https://lkml.kernel.org/r/bb081d21-7c03-0357-4294-7e92d95d838c@arm.com > Signed-off-by: Kishon Vijay Abraham I > --- > drivers/pci/controller/dwc/pci-keystone.c | 22 ++++++++++++---------- > 1 file changed, 12 insertions(+), 10 deletions(-) > > diff --git a/drivers/pci/controller/dwc/pci-keystone.c b/drivers/pci/controller/dwc/pci-keystone.c > index 5286a480f76b..4cf9849d5a1d 100644 > --- a/drivers/pci/controller/dwc/pci-keystone.c > +++ b/drivers/pci/controller/dwc/pci-keystone.c > @@ -214,16 +214,11 @@ static void ks_pcie_handle_legacy_irq(struct keystone_pcie *ks_pcie, > { > struct dw_pcie *pci = ks_pcie->pci; > struct device *dev = pci->dev; > - u32 pending; > int virq; > > - pending = ks_pcie_app_readl(ks_pcie, IRQ_STATUS(offset)); > - > - if (BIT(0) & pending) { > - virq = irq_linear_revmap(ks_pcie->legacy_irq_domain, offset); > - dev_dbg(dev, ": irq: irq_offset %d, virq %d\n", offset, virq); > - generic_handle_irq(virq); > - } > + virq = irq_linear_revmap(ks_pcie->legacy_irq_domain, offset); > + dev_dbg(dev, ": irq: irq_offset %d, virq %d\n", offset, virq); > + generic_handle_irq(virq); > > /* EOI the INTx interrupt */ > ks_pcie_app_writel(ks_pcie, IRQ_EOI, offset); > @@ -607,8 +602,9 @@ static void ks_pcie_legacy_irq_handler(struct irq_desc *desc) > struct keystone_pcie *ks_pcie = irq_desc_get_handler_data(desc); > struct dw_pcie *pci = ks_pcie->pci; > struct device *dev = pci->dev; > - u32 irq_offset = irq - ks_pcie->legacy_host_irqs[0]; > struct irq_chip *chip = irq_desc_get_chip(desc); > + unsigned int irq_no; > + u32 reg; > > dev_dbg(dev, ": Handling legacy irq %d\n", irq); > > @@ -618,7 +614,13 @@ static void ks_pcie_legacy_irq_handler(struct irq_desc *desc) > * ack operation. > */ > chained_irq_enter(chip, desc); > - ks_pcie_handle_legacy_irq(ks_pcie, irq_offset); > + for (irq_no = 0; irq_no < PCI_NUM_INTX; irq_no++) { I understand the aim of this code but now on platforms where there is a 1:1 relationship between Linux IRQ and INTX this loop has steps carried out for nothing. If I understand the code correctly what this code does is force looping over INTX status regs regardless of what linux IRQ number was actually active. You could do something faster by creating a matrix LinuxIRQ x INTx to detect what INTx status register should actually be checked. This seems overkill to me but it is not that complicated to implement and may clarify the code (and avoid reading up to three registers for nothing on the IRQ code path, which can make things faster too). Lorenzo > + reg = ks_pcie_app_readl(ks_pcie, IRQ_STATUS(irq_no)); > + if (!(reg & INTx_EN)) > + continue; > + ks_pcie_handle_legacy_irq(ks_pcie, irq_no); > + } > + > chained_irq_exit(chip, desc); > } > > -- > 2.17.1 >