Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp254470ybb; Fri, 3 Apr 2020 02:02:17 -0700 (PDT) X-Google-Smtp-Source: APiQypKW0UQnVTgP9bR7y6iTH7rvOW7bKR16RltrDaRTwYAK2EQI2wKBvZe5A8Ohfrp95KWGfjKr X-Received: by 2002:a05:6830:55:: with SMTP id d21mr5741110otp.29.1585904537045; Fri, 03 Apr 2020 02:02:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1585904537; cv=none; d=google.com; s=arc-20160816; b=m1VgIJ9x508RrutzsEn8LyX6h1fJwJ45W8np5++cE2b3XcSU7wJ9GWIbOekrJwYK0u OCBvH8JcBZOFM8G9LMJneshriXY9A15eUtTtLvtJRi3zMAPE7dhLyMMF90Jnjd/Fc/IA 8HfQGM1T4YVCj2qwC1jvWOgPwGJnNKtaU0+L5s6Om+TNecsSrhVZ3XGdeYQtFfMKeKkg jUDkNs+FP10pyBsU6u4w/pieZzal7Rbdj0IQsCXSXz/1J8Qvu/NAYnbUVKmcglfQca6G EyegI9ZVa+X/ACI7+5Gd0DlPTKHqb6gxNtYmsjbwI32fIM51796dogEzG/Z+FSKLKaL3 Su8w== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=NkIrJAUdwI/+nuXtCpI3Ra4/OZkMAr/VdCcFWoMxr6U=; b=G0nsvr9ibGF/COZ9VEArZaETtWyVQnQXhFicDUoZZ9dzg7SPQnpx+8fSOgoJxVeL84 +9WFuDSBvoFF6Nwgbs022kE52LO3E5pY2Ga08OBQrn8nswrjq07PvS2i+MvSLTX3SBYn guQsNV8n4Oj2Tv4lgFDEaZGGJtUNNvk2QhG7RQR83O8V7frqRdORjppjBOhbwDd9B/d/ baV60bwhbqw0Sw4bJtSL2imPCiYw3uNG/bh3ENHs3Tl+Y7Yr+rzojdKdcWvnea7T//oL rwnpeeuw5UFxWerq1IjcfyjjG+q5YK8T0wKcZtxGue7kCd7dBhR062wG/YLjcPGaQaMV U+ew== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@mm-sol.com header.s=201706 header.b=PT1YeIlP; 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; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=mm-sol.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r15si3543116otc.316.2020.04.03.02.01.44; Fri, 03 Apr 2020 02:02:17 -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=@mm-sol.com header.s=201706 header.b=PT1YeIlP; 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; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=mm-sol.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2390569AbgDCJBI (ORCPT + 99 others); Fri, 3 Apr 2020 05:01:08 -0400 Received: from ns.mm-sol.com ([37.157.136.199]:49533 "EHLO extserv.mm-sol.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727860AbgDCJBI (ORCPT ); Fri, 3 Apr 2020 05:01:08 -0400 Received: from [192.168.1.4] (212-5-158-241.ip.btc-net.bg [212.5.158.241]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client did not present a certificate) by extserv.mm-sol.com (Postfix) with ESMTPSA id A4673CFB0; Fri, 3 Apr 2020 12:01:04 +0300 (EEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=mm-sol.com; s=201706; t=1585904465; bh=XlPPAmhstG/r8uQst4kUmOIq26pF12Vho8l1S5UqRUI=; h=Subject:To:Cc:From:Date:From; b=PT1YeIlPmjcT/MMFYSXxhK6MEa0u/rHW/38RL00YVsdt+xXtK90TAdpVTunjfB3YG U+iQan+H/8+Ug8PuXKx5fLRu57nZtPhQ6d5RAxzjNksxihD0OZXUsypaMqHRboWQe2 V/w8qCSg4sTLJsEOLLgoGg2lrnot5ycLJNJiOOW8npQyBEYYdyzy6npThl0euzP6HK ccmaJ1mPZb1KzhiARYV/JdV8pXjPw/A8M4uGkBIbMxYeqj5/Wz1I4h2e8cxRuJvrkh uB0Ed4OW5w24xPwCaMEwFaHOu4UY+6yATvMpHzgMfVI8mOpAF5QFjgezvwmcFrQxXg g+IQ9J7R5oj0A== Subject: Re: [PATCH v2 10/10] PCIe: qcom: add Force GEN1 support To: Ansuel Smith , Andy Gross Cc: Sham Muthayyan , Bjorn Andersson , Bjorn Helgaas , Rob Herring , Mark Rutland , Lorenzo Pieralisi , Andrew Murray , Philipp Zabel , linux-arm-msm@vger.kernel.org, linux-pci@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org References: <20200402121148.1767-1-ansuelsmth@gmail.com> <20200402121148.1767-11-ansuelsmth@gmail.com> From: Stanimir Varbanov Message-ID: <8e0ada17-c858-59d2-8d5c-5129e7625f33@mm-sol.com> Date: Fri, 3 Apr 2020 12:01:01 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.4.1 MIME-Version: 1.0 In-Reply-To: <20200402121148.1767-11-ansuelsmth@gmail.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Ansuel, On 4/2/20 3:11 PM, Ansuel Smith wrote: > From: Sham Muthayyan > > Add Force GEN1 support needed in some ipq806x board > that needs to limit some pcie line to gen1 for some > hardware limitation. > This is set by the max-link-speed dts entry and needed > by some soc based on ipq806x. (for example Netgear R7800 > router) > > Signed-off-by: Sham Muthayyan > Signed-off-by: Ansuel Smith > --- > drivers/pci/controller/dwc/pcie-qcom.c | 13 +++++++++++++ > 1 file changed, 13 insertions(+) > > diff --git a/drivers/pci/controller/dwc/pcie-qcom.c b/drivers/pci/controller/dwc/pcie-qcom.c > index 8047ac7dc8c7..2212e9498b91 100644 > --- a/drivers/pci/controller/dwc/pcie-qcom.c > +++ b/drivers/pci/controller/dwc/pcie-qcom.c > @@ -27,6 +27,7 @@ > #include > #include > > +#include "../../pci.h" This looks suspiciously (even ugly), but I saw that the other users of of_pci_get_max_link_speed is doing the same. Bjorn H. : do you know why the prototype is there? Perhaps it must be in linux/of_pci.h. > #include "pcie-designware.h" > > #define PCIE20_PARF_SYS_CTRL 0x00 > @@ -99,6 +100,8 @@ > #define PCIE20_v3_PARF_SLV_ADDR_SPACE_SIZE 0x358 > #define SLV_ADDR_SPACE_SZ 0x10000000 > > +#define PCIE20_LNK_CONTROL2_LINK_STATUS2 0xA0 tabs instead of spaces and hex numbers should be lower-case > + > #define DEVICE_TYPE_RC 0x4 > > #define QCOM_PCIE_2_1_0_MAX_SUPPLY 3 > @@ -199,6 +202,7 @@ struct qcom_pcie { > struct phy *phy; > struct gpio_desc *reset; > const struct qcom_pcie_ops *ops; > + bool force_gen1; could you rename this and make it int: int gen; > }; > > #define to_qcom_pcie(x) dev_get_drvdata((x)->dev) > @@ -441,6 +445,11 @@ static int qcom_pcie_init_2_1_0(struct qcom_pcie *pcie) > > /* wait for clock acquisition */ > usleep_range(1000, 1500); add a blank line here > + if (pcie->force_gen1) { if (pcie->gen == 1) { > + writel_relaxed((readl_relaxed( > + pcie->pci->dbi_base + PCIE20_LNK_CONTROL2_LINK_STATUS2) | 1), > + pcie->pci->dbi_base + PCIE20_LNK_CONTROL2_LINK_STATUS2); > + } why you are using writel/readl_relaxed ? Also could you split the line to two: val = read() write(val | 1, address) > > > /* Set the Max TLP size to 2K, instead of using default of 4K */ > @@ -1440,6 +1449,10 @@ static int qcom_pcie_probe(struct platform_device *pdev) > goto err_pm_runtime_put; > } > > + ret = of_pci_get_max_link_speed(pdev->dev.of_node);> + if (ret == 1) > + pcie->force_gen1 = true; drop this, handle ret < 0 and default to generation 2 pcie->gen = of_pci_get_max_link_speed(pdev->dev.of_node); if (pcie->gen < 0) pcie->gen = 2; > + > res = platform_get_resource_byname(pdev, IORESOURCE_MEM, "parf"); > pcie->parf = devm_ioremap_resource(dev, res); > if (IS_ERR(pcie->parf)) { > -- regards, Stan