Received: by 2002:a05:6a10:5bc5:0:0:0:0 with SMTP id os5csp3746273pxb; Wed, 13 Oct 2021 12:05:17 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxywfTpv9V6nk0WeKSxqCckIUmAn+ARhWkSbRo3aB76cYXDubatfARcQen3O/xh72A1xyZQ X-Received: by 2002:a17:906:4084:: with SMTP id u4mr1153519ejj.369.1634151917034; Wed, 13 Oct 2021 12:05:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1634151917; cv=none; d=google.com; s=arc-20160816; b=LfuNTMCdwbWkO4owDzRj/WlCBH0K6dFt9djGASWIpbAP857YvLJjlFX/gtwYOjuYq6 HSFO1+Z0nqTVv404V3TERmTbODgm6+KGJdOKCHwKoCmXuCfadLWrsyEQT5k2fsdL6x7N hBvVM22JxvXbpdREVo9bfXmvUC/3EVZYj28yPMxeNJiFmyW1NYVVmideQJi0wtOMV6qC 5NPsghvJgUQcaxbTiW4h4pgvcLV0iU0YVYjQP4KDiIPgG1nUCYia6kcOS4/5kjBO1a6w MLQ1I/kWrT19zQhobJzxARK8vyrFGNrCrDEoJd9EJt6jhNrpdQ/mSu72Pom9QZAw9REv rxvw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :message-id:subject:cc:to:from:date:dkim-signature; bh=JH+A6t5L2QLqAL+ui571fCS/7jQxwrV4TCrCqEftKbk=; b=o/6WUKKC+KP7hb7StBMRUeO1QP9vpPkMntsj45qKKGgsCA7KVifDg/IYAswu5GpjS2 JVvYgToT9mhMx51SboYWtpiv/yMme4Nh2XmtdaYHC+u4kxOTzXixEURCR8/xsq05i5Ct R1BHVWjB9TjMrJBf6bTjWzOVEaHZf+78x+B6qVYjGVAVRMeV3yP90nyh54W7345tK6WY pYFZGyOtfjjoIPyJipH4FzYyp+n17r4d6Iu67pksKYOoYAi4OPtzr8OgA8AfBV3Pc9Ra 0h6OPF3LlzwemG+Fy1jnvTSnT0FltJyD4K9+/gKhXPFT8t4907nYZ3jEGmJfxtncKRDm OQAg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=SOy4uik6; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id m4si450044edj.623.2021.10.13.12.04.52; Wed, 13 Oct 2021 12:05:17 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=SOy4uik6; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238877AbhJMTEh (ORCPT + 99 others); Wed, 13 Oct 2021 15:04:37 -0400 Received: from mail.kernel.org ([198.145.29.99]:46926 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230118AbhJMTEc (ORCPT ); Wed, 13 Oct 2021 15:04:32 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 6284060E96; Wed, 13 Oct 2021 19:02:28 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1634151749; bh=nrpmV2aL7Yyo2rvXkWXL6W7OTMDFqb0qTu+6E6wA2jw=; h=Date:From:To:Cc:Subject:In-Reply-To:From; b=SOy4uik6jEZWbxmPABrbRogV42T8n5r6jEXXfPGNkk6SIgKDyIO6cbZHoarlAkULH kjFBy8PONij7Kl/a60F5hUAIVGNFG9k12KIb2imfqAi2rJcNiU8z+4/0Pb3gpVh9NV ZE3BZ4ySVphSPjAHTDam/ZsH5e6jxU/R6OI0hHiCymtbcuanXohqSbDNMLVzpcPMG4 +ZwTDIG4PZnBHVWK/y0yyxATl1P2Qxh2c1shr3aCXxIkGCWdlLx0vEnrb+FK0vCgIV liF96uxIaP05sMPqKAeIkyXUSC0pKpdUh2TTdPkiCAvJs5qPoCYm3v145cEdkU6kNk 2BB+INXZ2Oo4Q== Date: Wed, 13 Oct 2021 14:02:26 -0500 From: Bjorn Helgaas To: Jianjun Wang Cc: Lorenzo Pieralisi , Rob Herring , Krzysztof =?utf-8?Q?Wilczy=C5=84ski?= , Bjorn Helgaas , Ryder Lee , Matthias Brugger , linux-pci@vger.kernel.org, linux-mediatek@lists.infradead.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, qizhong.cheng@mediatek.com, Ryan-JH.Yu@mediatek.com, Tzung-Bi Shih Subject: Re: [PATCH v2] PCI: mediatek-gen3: Disable DVFSRC voltage request Message-ID: <20211013190226.GA1910352@bhelgaas> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20211013183515.GA1907868@bhelgaas> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Oct 13, 2021 at 01:35:17PM -0500, Bjorn Helgaas wrote: > On Wed, Oct 13, 2021 at 03:53:28PM +0800, Jianjun Wang wrote: > > When the DVFSRC feature is not implemented, the MAC layer will > > assert a voltage request signal when exit from the L1ss state, > > but cannot receive the voltage ready signal, which will cause > > the link to fail to exit the L1ss state correctly. > > > > Disable DVFSRC voltage request by default, we need to find > > a common way to enable it in the future. > > Rewrap commit log to fill 75 columns. > > Does "L1ss" above refer to L1.1 and L1.2? If so, please say that > explicitly or say something like "L1 PM Substates" (the term used in > the PCIe spec) so it's clear. > > This seems on the boundary of PCIe-specified things and Mediatek > implementation details, so I'm not sure what "DVFSRC," "MAC," and > "voltage request signal" mean. Since I don't recognize those terms, > I'm guessing they are Mediatek-specific things. > > But if they are things specified by the PCIe spec, please use the > exact names used in the spec. > > > Signed-off-by: Jianjun Wang > > Reviewed-by: Tzung-Bi Shih > > Tested-by: Qizhong Cheng Krzysztof also pointed out that if this is a bug fix, we may want a stable tag here. And, ideally, a Fixes: tag with the specific commit that introduced the bug. > > --- > > drivers/pci/controller/pcie-mediatek-gen3.c | 8 ++++++++ > > 1 file changed, 8 insertions(+) > > > > diff --git a/drivers/pci/controller/pcie-mediatek-gen3.c b/drivers/pci/controller/pcie-mediatek-gen3.c > > index f3aeb8d4eaca..79fb12fca6a9 100644 > > --- a/drivers/pci/controller/pcie-mediatek-gen3.c > > +++ b/drivers/pci/controller/pcie-mediatek-gen3.c > > @@ -79,6 +79,9 @@ > > #define PCIE_ICMD_PM_REG 0x198 > > #define PCIE_TURN_OFF_LINK BIT(4) > > > > +#define PCIE_MISC_CTRL_REG 0x348 > > +#define PCIE_DISABLE_DVFSRC_VLT_REQ BIT(1) > > + > > #define PCIE_TRANS_TABLE_BASE_REG 0x800 > > #define PCIE_ATR_SRC_ADDR_MSB_OFFSET 0x4 > > #define PCIE_ATR_TRSL_ADDR_LSB_OFFSET 0x8 > > @@ -297,6 +300,11 @@ static int mtk_pcie_startup_port(struct mtk_pcie_port *port) > > val &= ~PCIE_INTX_ENABLE; > > writel_relaxed(val, port->base + PCIE_INT_ENABLE_REG); > > > > + /* Disable DVFSRC voltage request */ > > + val = readl_relaxed(port->base + PCIE_MISC_CTRL_REG); > > + val |= PCIE_DISABLE_DVFSRC_VLT_REQ; > > + writel_relaxed(val, port->base + PCIE_MISC_CTRL_REG); > > + > > /* Assert all reset signals */ > > val = readl_relaxed(port->base + PCIE_RST_CTRL_REG); > > val |= PCIE_MAC_RSTB | PCIE_PHY_RSTB | PCIE_BRG_RSTB | PCIE_PE_RSTB; > > -- > > 2.25.1 > >