Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp690744imu; Thu, 13 Dec 2018 02:49:32 -0800 (PST) X-Google-Smtp-Source: AFSGD/XAO68suSKflu3w4bOyfL0M9wxElEWkiQ1qjK0E/h7SGhgIWhG42Vow6C47RswXrRB6oSTG X-Received: by 2002:a17:902:541:: with SMTP id 59mr23631998plf.88.1544698172205; Thu, 13 Dec 2018 02:49:32 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1544698172; cv=none; d=google.com; s=arc-20160816; b=k1H3yW92mT2vfxed7x5A1AOIihnRyWpZkCZxlLWfqCHrHg98Lj5eMS3iHL07XJOKTu KAooim6XMnTD3WBlhGDQ9LkYpQ0QBdrMT9BfVyK5/aAcW2I0M1bb+Gai/lU0bW2fpJlU 6k6ScF0CJnjhzPjHiF9TBhcFw8bohsqbGmhEEmraGZnh9Bmuca9jtdNTaSFTYpITg9Hj 76YWkx5Yp4SB6UykBKUFDd5vaf3XOusb6X+62ZosecA1/rj7NZdwOWwww//iTRok7u9w lzP4mHG8jOGFnNj95oIyIpNGcx3YZYwhJfe++Sz07c4bYRJ2U2cbL7hQqB0XHhbv1zeH IACg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:date:cc:to:from:subject:message-id; bh=bWowOsLo4C1qdSG9c2DAWPNmQ+TGtG5h1IVslF+vFsI=; b=rWW4IZcFcKXPeVatdoCeBLRvvLdSrheq+SmmH8UxK8OLaUwep1IVBN0VqZ5X5qgjve ONcLf9hJwhVqYh1FXjFZjWoFMQ+qmeRBvmjjHWNkutqSCjFP+44otddBZtw582OuBWJo FcaAAYhF1ECTUkneI+ldQz0NpiNLv/LBy2eX2lFgUVm+T4BnaON3ofRyDBb7CEs54Kdj AamphtJqb9zJQ1ZrzxEY6NogqzqUE+BgdTMnue02BkiIUYvrBG+C+cVh7k2JJT0ok9de 2O+EM2IaS5FFUoXZqGvGEpVohkCb8e1CoIBpsVts91WNbyQ7cqC0DrNzO9esbUXn7FUG y9QQ== 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 k30si1264156pgb.113.2018.12.13.02.49.16; Thu, 13 Dec 2018 02:49:32 -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 S1728647AbeLMKq6 (ORCPT + 99 others); Thu, 13 Dec 2018 05:46:58 -0500 Received: from metis.ext.pengutronix.de ([85.220.165.71]:36101 "EHLO metis.ext.pengutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727403AbeLMKq6 (ORCPT ); Thu, 13 Dec 2018 05:46:58 -0500 Received: from kresse.hi.pengutronix.de ([2001:67c:670:100:1d::2a]) by metis.ext.pengutronix.de with esmtp (Exim 4.89) (envelope-from ) id 1gXOW5-0000m9-Ln; Thu, 13 Dec 2018 11:46:53 +0100 Message-ID: <1544698012.3137.28.camel@pengutronix.de> Subject: Re: [v3] PCI: imx: make msi work without pcieportbus From: Lucas Stach To: Richard Zhu , "bhelgaas@google.com" , "lorenzo.pieralisi@arm.com" , "andrew.smirnov@gmail.com" Cc: "linux-pci@vger.kernel.org" , "linux-arm-kernel@lists.infradead.org" , "linux-kernel@vger.kernel.org" Date: Thu, 13 Dec 2018 11:46:52 +0100 In-Reply-To: <1544696723-1673-1-git-send-email-hongxing.zhu@nxp.com> References: <1544696723-1673-1-git-send-email-hongxing.zhu@nxp.com> Content-Type: text/plain; charset="UTF-8" X-Mailer: Evolution 3.22.6-1+deb9u1 Mime-Version: 1.0 Content-Transfer-Encoding: 8bit X-SA-Exim-Connect-IP: 2001:67c:670:100:1d::2a X-SA-Exim-Mail-From: l.stach@pengutronix.de X-SA-Exim-Scanned: No (on metis.ext.pengutronix.de); SAEximRunCond expanded to false X-PTX-Original-Recipient: linux-kernel@vger.kernel.org Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Am Donnerstag, den 13.12.2018, 10:43 +0000 schrieb Richard Zhu: > MSI_EN of iMX PCIe RC would be asserted when > PCIEPORTBUS driver is selected. > Thus, the MSI works fine on iMX PCIe before. > Assert it unconditionally when MSI is enabled. > Otherwise, the MSI wouldn't be triggered although > the EP is present and the MSIs are assigned. > > Signed-off-by: Richard Zhu Reviewed-by: Lucas Stach > --- > Changes v1 -> v2: > * Assert the MSI_EN unconditionally when MSI is supported. > Changes v2 -> v3: > * Remove the IS_ENABLED(CONFIG_PCI_MSI) since the driver > depends on PCI_MSI_IRQ_DOMAIN > * Extended with a check for pci_msi_enabled() to see > if the user explicitly want legacy IRQs > --- >  drivers/pci/controller/dwc/pci-imx6.c | 8 ++++++++ >  1 file changed, 8 insertions(+) > > diff --git a/drivers/pci/controller/dwc/pci-imx6.c b/drivers/pci/controller/dwc/pci-imx6.c > index 26087b3..1c59a93 100644 > --- a/drivers/pci/controller/dwc/pci-imx6.c > +++ b/drivers/pci/controller/dwc/pci-imx6.c > @@ -74,6 +74,7 @@ struct imx6_pcie { > >  #define PHY_PLL_LOCK_WAIT_USLEEP_MAX 200 >   >  /* PCIe Root Complex registers (memory-mapped) */ > > +#define PCI_MSI_CAP 0x50 > >  #define PCIE_RC_LCR 0x7c > >  #define PCIE_RC_LCR_MAX_LINK_SPEEDS_GEN1 0x1 > >  #define PCIE_RC_LCR_MAX_LINK_SPEEDS_GEN2 0x2 > @@ -926,6 +927,7 @@ static int imx6_pcie_probe(struct platform_device *pdev) > >   struct resource *dbi_base; > >   struct device_node *node = dev->of_node; > >   int ret; > > + u16 val; >   > >   imx6_pcie = devm_kzalloc(dev, sizeof(*imx6_pcie), GFP_KERNEL); > >   if (!imx6_pcie) > @@ -1071,6 +1073,12 @@ static int imx6_pcie_probe(struct platform_device *pdev) > >   if (ret < 0) > >   return ret; >   > > + if (pci_msi_enabled()) { > > + val = dw_pcie_readw_dbi(pci, PCI_MSI_CAP + PCI_MSI_FLAGS); > > + val |= PCI_MSI_FLAGS_ENABLE; > > + dw_pcie_writew_dbi(pci, PCI_MSI_CAP + PCI_MSI_FLAGS, val); > > + } > + > >   return 0; >  } >