Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp5069776imm; Tue, 12 Jun 2018 01:54:07 -0700 (PDT) X-Google-Smtp-Source: ADUXVKIPJ/rta57Za3IDjmbkmA6aLo057HiJS4FsETxOdcACcqIQk7JjsgrvCzgU7dLVsxzGQ3Tc X-Received: by 2002:a17:902:b483:: with SMTP id y3-v6mr3138258plr.66.1528793647438; Tue, 12 Jun 2018 01:54:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1528793647; cv=none; d=google.com; s=arc-20160816; b=IdQ3vQKgoRst0AK4iXGuQ2QrMx5RQ09t/Yul6N8qS6pxez4t4pE9Ub/uXpTv5uZa4f f+g54jm0zYezM5CFSGjQHYb97bM5D9uRxOVA9w/NIF0qZvA0zENlY5SDJRDbubVcoyRe baaUkmVlyObU2MGeeEnol8ANWTqS4jR7E/bPvrXV81LtHr3qT7RLyRTbdOcQJaD4nyq1 YFiYGceOKNfbCib7s53LqwKCMAuCWxFTKPwKBLlDAmWhPsYdvRHMxS5qbsv9hmODv2b/ IQKZwU1mQrjsHAhvgVG17IrkkI6L0L63p5n2zKdVF/ckxcKv3S1RkVTIlKTproSjyr2P zYQA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:message-id:references :in-reply-to:subject:cc:to:from:date:content-transfer-encoding :mime-version:dkim-signature:dkim-signature :arc-authentication-results; bh=F8X0lyhOkRIqJCmQCouyHc5yY2/f2Vj5IRnm8o2Bb0E=; b=okxVP3FscOORot8OgGnq+G1eC/DuAc5l+uvexcWBHiE0ebyKJ7LA2fpT6buy4NObl4 8W00LygrDlvOCT/8UMzibwUww91OjPIWRigYOwgc+2K0j+9u+DCEraV6s+ul0zoAoGuf ZNjMwjFwkOJiSyS0mB+vYFe3WttfZ+AxFUFXg+sYsjmmOVarlxexSHL4dy7P4LVWls7+ +6TOsVxy0Lc6LF+OxnH5cWJGVqkQa6ZqHGb6MqI1ek73zG8M33q9T6oKp3CGZU2T84n+ Y22DR3kQTiypmVch/JzlhRz82avGS7mSEl2KAgD8AbLQ32KumFshVvDob/UhKLOd6Ln2 WR4A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=DBYU+EEh; dkim=pass header.i=@codeaurora.org header.s=default header.b=bKsI6PPp; 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 89-v6si433563plc.59.2018.06.12.01.53.53; Tue, 12 Jun 2018 01:54:07 -0700 (PDT) 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; dkim=pass header.i=@codeaurora.org header.s=default header.b=DBYU+EEh; dkim=pass header.i=@codeaurora.org header.s=default header.b=bKsI6PPp; 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 S933881AbeFLIwM (ORCPT + 99 others); Tue, 12 Jun 2018 04:52:12 -0400 Received: from smtp.codeaurora.org ([198.145.29.96]:60018 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S933817AbeFLIwJ (ORCPT ); Tue, 12 Jun 2018 04:52:09 -0400 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id CC4A7607E7; Tue, 12 Jun 2018 08:52:08 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1528793528; bh=sIHZzJPhncAHnBYV5VrveZetBQvZAkSIxYx9tUl1q4U=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=DBYU+EEhPGJa16nKlZgd1DlPgo8PzuXxY+YSAtt9sCfb96KsAY8IRIh+AF1/Cs/C4 9s3/u5kAJMpniEielh3quPXICVeEJMF00MCTpAtJM71MnQ0V/Oqv3iPeCWHr/GspFx MZgRPLWEtMMv0OAkFtZR2jnUwg7Y92DQoU/ylZMc= X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on pdx-caf-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.8 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_SIGNED,T_DKIM_INVALID autolearn=no autolearn_force=no version=3.4.0 Received: from mail.codeaurora.org (localhost.localdomain [127.0.0.1]) by smtp.codeaurora.org (Postfix) with ESMTP id C4CF1601C3; Tue, 12 Jun 2018 08:52:07 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1528793527; bh=sIHZzJPhncAHnBYV5VrveZetBQvZAkSIxYx9tUl1q4U=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=bKsI6PPpNYqOa9zwLOAhr3OlKfOegVfGEHEB8+3EYI2F/TBTvRR5JpEmPykyeTfjh iszq9jaO8eUaS7N+unB9IEwwM6xpAV1gQwSkAMwtKC2T5ASlhoduP/LqiHyBa+imUn q9wl1Xc9uOUhonOhUInlytczBEnd6vLErBS/UJ+M= MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII; format=flowed Content-Transfer-Encoding: 7bit Date: Tue, 12 Jun 2018 14:22:07 +0530 From: poza@codeaurora.org To: Ray Jui Cc: Lorenzo Pieralisi , Bjorn Helgaas , Rob Herring , Mark Rutland , linux-kernel@vger.kernel.org, bcm-kernel-feedback-list@broadcom.com, linux-pci@vger.kernel.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-pci-owner@vger.kernel.org Subject: Re: [PATCH 2/6] PCI: iproc: Add INTx support with better modeling In-Reply-To: <1527631130-20045-3-git-send-email-ray.jui@broadcom.com> References: <1527631130-20045-1-git-send-email-ray.jui@broadcom.com> <1527631130-20045-3-git-send-email-ray.jui@broadcom.com> Message-ID: <3ecc33ebe3db1f010f5c8938dfb87677@codeaurora.org> X-Sender: poza@codeaurora.org User-Agent: Roundcube Webmail/1.2.5 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2018-05-30 03:28, Ray Jui wrote: > Add PCIe legacy interrupt INTx support to the iProc PCIe driver by > modeling it with its own IRQ domain. All 4 interrupts INTA, INTB, INTC, > INTD share the same interrupt line connected to the GIC in the system, > while the status of each INTx can be obtained through the INTX CSR > register > > Signed-off-by: Ray Jui > --- > drivers/pci/host/pcie-iproc-platform.c | 2 + > drivers/pci/host/pcie-iproc.c | 95 > +++++++++++++++++++++++++++++++++- > drivers/pci/host/pcie-iproc.h | 6 +++ > 3 files changed, 101 insertions(+), 2 deletions(-) > > diff --git a/drivers/pci/host/pcie-iproc-platform.c > b/drivers/pci/host/pcie-iproc-platform.c > index e764a2a..7a51e6c 100644 > --- a/drivers/pci/host/pcie-iproc-platform.c > +++ b/drivers/pci/host/pcie-iproc-platform.c > @@ -70,6 +70,8 @@ static int iproc_pcie_pltfm_probe(struct > platform_device *pdev) > } > pcie->base_addr = reg.start; > > + pcie->irq = platform_get_irq(pdev, 0); > + > if (of_property_read_bool(np, "brcm,pcie-ob")) { > u32 val; > > diff --git a/drivers/pci/host/pcie-iproc.c > b/drivers/pci/host/pcie-iproc.c > index 14f374d..0bd2c14 100644 > --- a/drivers/pci/host/pcie-iproc.c > +++ b/drivers/pci/host/pcie-iproc.c > @@ -14,6 +14,7 @@ > #include > #include > #include > +#include > #include > #include > #include > @@ -264,6 +265,7 @@ enum iproc_pcie_reg { > > /* enable INTx */ > IPROC_PCIE_INTX_EN, > + IPROC_PCIE_INTX_CSR, > > /* outbound address mapping */ > IPROC_PCIE_OARR0, > @@ -305,6 +307,7 @@ static const u16 iproc_pcie_reg_paxb_bcma[] = { > [IPROC_PCIE_CFG_ADDR] = 0x1f8, > [IPROC_PCIE_CFG_DATA] = 0x1fc, > [IPROC_PCIE_INTX_EN] = 0x330, > + [IPROC_PCIE_INTX_CSR] = 0x334, > [IPROC_PCIE_LINK_STATUS] = 0xf0c, > }; > > @@ -316,6 +319,7 @@ static const u16 iproc_pcie_reg_paxb[] = { > [IPROC_PCIE_CFG_ADDR] = 0x1f8, > [IPROC_PCIE_CFG_DATA] = 0x1fc, > [IPROC_PCIE_INTX_EN] = 0x330, > + [IPROC_PCIE_INTX_CSR] = 0x334, > [IPROC_PCIE_OARR0] = 0xd20, > [IPROC_PCIE_OMAP0] = 0xd40, > [IPROC_PCIE_OARR1] = 0xd28, > @@ -332,6 +336,7 @@ static const u16 iproc_pcie_reg_paxb_v2[] = { > [IPROC_PCIE_CFG_ADDR] = 0x1f8, > [IPROC_PCIE_CFG_DATA] = 0x1fc, > [IPROC_PCIE_INTX_EN] = 0x330, > + [IPROC_PCIE_INTX_CSR] = 0x334, > [IPROC_PCIE_OARR0] = 0xd20, > [IPROC_PCIE_OMAP0] = 0xd40, > [IPROC_PCIE_OARR1] = 0xd28, > @@ -782,9 +787,90 @@ static int iproc_pcie_check_link(struct iproc_pcie > *pcie) > return link_is_active ? 0 : -ENODEV; > } > > -static void iproc_pcie_enable(struct iproc_pcie *pcie) > +static int iproc_pcie_intx_map(struct irq_domain *domain, unsigned int > irq, > + irq_hw_number_t hwirq) > { > + irq_set_chip_and_handler(irq, &dummy_irq_chip, handle_simple_irq); > + irq_set_chip_data(irq, domain->host_data); > + > + return 0; > +} > + > +static const struct irq_domain_ops intx_domain_ops = { > + .map = iproc_pcie_intx_map, > +}; > + > +static void iproc_pcie_isr(struct irq_desc *desc) > +{ > + struct irq_chip *chip = irq_desc_get_chip(desc); > + struct iproc_pcie *pcie; > + struct device *dev; > + unsigned long status; > + u32 bit, virq; > + > + chained_irq_enter(chip, desc); > + pcie = irq_desc_get_handler_data(desc); > + dev = pcie->dev; > + > + /* go through INTx A, B, C, D until all interrupts are handled */ > + while ((status = iproc_pcie_read_reg(pcie, IPROC_PCIE_INTX_CSR) & > + SYS_RC_INTX_MASK) != 0) { > + for_each_set_bit(bit, &status, PCI_NUM_INTX) { > + virq = irq_find_mapping(pcie->irq_domain, bit + 1); > + if (virq) > + generic_handle_irq(virq); > + else > + dev_err(dev, "unexpected INTx%u\n", bit); > + } > + } > + Are these level or edge interrupts ? although I see DT says: IRQ_TYPE_NONE do you not need to clear interrupt status bits in IPROC_PCIE_INTX_CSR ? > + chained_irq_exit(chip, desc); > +} > + > +static int iproc_pcie_intx_enable(struct iproc_pcie *pcie) > +{ > + struct device *dev = pcie->dev; > + struct device_node *node = dev->of_node; > + int ret; > + > iproc_pcie_write_reg(pcie, IPROC_PCIE_INTX_EN, SYS_RC_INTX_MASK); > + > + /* > + * BCMA devices do not map INTx the same way as platform devices. All > + * BCMA needs is the above code to enable INTx > + */ > + if (pcie->irq <= 0) > + return 0; > + > + /* set IRQ handler */ > + irq_set_chained_handler_and_data(pcie->irq, iproc_pcie_isr, pcie); > + > + /* add IRQ domain for INTx */ > + pcie->irq_domain = irq_domain_add_linear(node, PCI_NUM_INTX + 1, > + &intx_domain_ops, pcie); > + if (!pcie->irq_domain) { > + dev_err(dev, "failed to add INTx IRQ domain\n"); > + ret = -ENOMEM; > + goto err_rm_handler_data; > + } > + > + return 0; > + > +err_rm_handler_data: > + irq_set_chained_handler_and_data(pcie->irq, NULL, NULL); > + > + return ret; > +} > + > +static void iproc_pcie_intx_disable(struct iproc_pcie *pcie) > +{ > + iproc_pcie_write_reg(pcie, IPROC_PCIE_INTX_EN, 0x0); > + > + if (pcie->irq <= 0) > + return; > + > + irq_domain_remove(pcie->irq_domain); > + irq_set_chained_handler_and_data(pcie->irq, NULL, NULL); > } > > static inline bool iproc_pcie_ob_is_valid(struct iproc_pcie *pcie, > @@ -1410,7 +1496,11 @@ int iproc_pcie_setup(struct iproc_pcie *pcie, > struct list_head *res) > goto err_power_off_phy; > } > > - iproc_pcie_enable(pcie); > + ret = iproc_pcie_intx_enable(pcie); > + if (ret) { > + dev_err(dev, "failed to enable INTx\n"); > + goto err_power_off_phy; > + } > > if (IS_ENABLED(CONFIG_PCI_MSI)) > if (iproc_pcie_msi_enable(pcie)) > @@ -1455,6 +1545,7 @@ int iproc_pcie_remove(struct iproc_pcie *pcie) > pci_remove_root_bus(pcie->root_bus); > > iproc_pcie_msi_disable(pcie); > + iproc_pcie_intx_disable(pcie); > > phy_power_off(pcie->phy); > phy_exit(pcie->phy); > diff --git a/drivers/pci/host/pcie-iproc.h > b/drivers/pci/host/pcie-iproc.h > index 67081cb..cbcaf9d 100644 > --- a/drivers/pci/host/pcie-iproc.h > +++ b/drivers/pci/host/pcie-iproc.h > @@ -72,6 +72,9 @@ struct iproc_msi; > * @ib: inbound mapping related parameters > * @ib_map: outbound mapping region related parameters > * > + * @irq: interrupt line wired to the generic GIC for INTx > + * @irq_domain: IRQ domain for INTx > + * > * @need_msi_steer: indicates additional configuration of the iProc > PCIe > * controller is required to steer MSI writes to external interrupt > controller > * @msi: MSI data > @@ -99,6 +102,9 @@ struct iproc_pcie { > struct iproc_pcie_ib ib; > const struct iproc_pcie_ib_map *ib_map; > > + int irq; > + struct irq_domain *irq_domain; > + > bool need_msi_steer; > struct iproc_msi *msi; > };