Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S966812AbbLPVxM (ORCPT ); Wed, 16 Dec 2015 16:53:12 -0500 Received: from mail.kernel.org ([198.145.29.136]:53547 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S966654AbbLPVxH (ORCPT ); Wed, 16 Dec 2015 16:53:07 -0500 Date: Wed, 16 Dec 2015 15:53:04 -0600 From: Bjorn Helgaas To: Stanimir Varbanov Cc: linux-arm-msm@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, devicetree@vger.kernel.org, linux-pci@vger.kernel.org, Bjorn Helgaas , Srinivas Kandagatla , Rob Herring , Rob Herring , Mark Rutland , Pawel Moll , Ian Campbell , Arnd Bergmann , Jingoo Han , Pratyush Anand , Bjorn Andersson , Stanimir Varbanov Subject: Re: [PATCH v4 3/5] PCI: qcom: Add Qualcomm PCIe controller driver Message-ID: <20151216215304.GB27791@localhost> References: <1449149725-27607-1-git-send-email-stanimir.varbanov@linaro.org> <1449149725-27607-4-git-send-email-stanimir.varbanov@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1449149725-27607-4-git-send-email-stanimir.varbanov@linaro.org> User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2408 Lines: 64 On Thu, Dec 03, 2015 at 03:35:22PM +0200, Stanimir Varbanov wrote: > From: Stanimir Varbanov > > The PCIe driver reuse the Designware common code for host > and MSI initialization, and also program the Qualcomm > application specific registers. > > Signed-off-by: Stanimir Varbanov > Signed-off-by: Stanimir Varbanov > --- > MAINTAINERS | 7 + > drivers/pci/host/Kconfig | 10 + > drivers/pci/host/Makefile | 1 + > drivers/pci/host/pcie-qcom.c | 624 ++++++++++++++++++++++++++++++++++++++++++ > +#define PCIE20_CAP 0x70 > +#define PCIE20_CAP_LINKCTRLSTATUS (PCIE20_CAP + 0x10) > +#define PCIE20_CAP_LINKCTRLSTATUS_LINK_UP BIT(29) This looks like it could be referring to a standard PCIe Capability; could you use the existing PCI_EXP_LNKSTA and PCI_EXP_LNKSTA_DLLLA symbols here? And readw() instead of readl()? > +static int qcom_pcie_enable_link_training(struct qcom_pcie *pcie) > +{ > + struct device *dev = pcie->dev; > + u32 val; > + int ret; > + > + /* enable link training */ > + val = readl(pcie->elbi + PCIE20_ELBI_SYS_CTRL); > + val |= PCIE20_ELBI_SYS_CTRL_LT_ENABLE; > + writel(val, pcie->elbi + PCIE20_ELBI_SYS_CTRL); > + > + /* wait for up to 100ms for the link to come up */ > + ret = readl_poll_timeout(pcie->elbi + PCIE20_ELBI_SYS_STTS, val, > + val & XMLH_LINK_UP, LINKUP_DELAY_US, > + LINKUP_TIMEOUT_US); > + > + if (ret < 0 || !dw_pcie_link_up(&pcie->pp)) { > + dev_err(dev, "link initialization failed\n"); > + return -ETIMEDOUT; > + } > + > + return 0; > +} This looks a lot like the *_establish_link() functions in other DesignWare-based drivers. Can you make it look even more similar, e.g., by renaming it to qcom_pcie_establish_link() and maybe moving some of the PHY functionality here? readl_poll_timeout() is nice and avoids the hand-coded timeout loop the other drivers use. But is there benefit in checking for XMLH_LINK_UP, or could you simply poll dw_pcie_link_up() like the others do? If it's sufficient, I'd prefer using dw_pcie_link_up() by itself because it's a little more generic. Bjorn -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/