Received: by 2002:a05:7412:2a8c:b0:e2:908c:2ebd with SMTP id u12csp1803567rdh; Tue, 26 Sep 2023 04:14:56 -0700 (PDT) X-Google-Smtp-Source: AGHT+IHM8H4tEuqEMybNCuKWfoJD0PuvHaJKHffUF2ZO9PY8dYJtpvOJtScUx8jpRuJ5IlhhDvgB X-Received: by 2002:a17:90a:a095:b0:26b:e27:8bc2 with SMTP id r21-20020a17090aa09500b0026b0e278bc2mr8508300pjp.45.1695726896283; Tue, 26 Sep 2023 04:14:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695726896; cv=none; d=google.com; s=arc-20160816; b=oue7tTal36nPEZ2tDMkQUdxGfu9y6UT6H1V2BC4UqNU3DaQ7N7vpDFa6WK7oLgRUQ6 8JLP+CPqnMPoOI3mL0zcQtBRlIL/GBiW/oUM2fLF9VP72FjYx6X91w2zna3/ljwHI83l Cp9GXMqB1W/c+IxEUCNnq1LdPPorM94RnuQr9hHlaVyKo4KYoOPSWYpsTN+1qXh/F1qQ gGGd4nVCCWSnrj5hpGGfZbVs3OrUnjN22RKD+ow+9xYeKxX5C5PTetCsCDtlYcoivVEG b0CnUCV1zZU4M/zQIf2SCcw97hiE7J9CGP2jo+z5blsikhgz3d8aE7Rb3qwxh4WxI6kG LBnA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :content-language:references:to:subject:cc:user-agent:mime-version :date:message-id:dkim-signature; bh=6yM0KH/OFNdiqifrALwi7ox3FMuqovyQ0nkJFVv0Lr0=; fh=JbZhYmMC9mnvYa0l+kdGKleMN34I6oBTNG+jYdjydkk=; b=TYjkBn92JiJjISnh6Qo9i57WheXN3YR6tr4KlPF3oSdF3BPt0Zn3OnKA5eKR4jvfD4 1GoO3sXWxIWjFTZXqsht5R6QCM1/upuh3RIa3/qvwMVZlZlD7Rbw1tO9mb2IGixHJWBp YsFqt5CMZsNiuSQqiQ0TUwQHg3dUu5uidtqo1TzEIHbbxA1jvXfNXHMV/86p823Hvloa RSH9W821yqpO/XnmEjzPUtDNKhN3LyndpkUcm3J5ndjcmdG+BnVDseIEQaCv4kTEDKDc h9d0EatJwk7OSc6aA4/SQRJ3lhk2UKzmFaiaKa6Y9wMpQlG1EmP3odVA8Q2pAR+UGtHt zTQw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=Q2b8L9MO; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.36 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Return-Path: Received: from pete.vger.email (pete.vger.email. [23.128.96.36]) by mx.google.com with ESMTPS id e6-20020a17090a7c4600b002774c17dd73si5447272pjl.11.2023.09.26.04.14.51 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 26 Sep 2023 04:14:56 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.36 as permitted sender) client-ip=23.128.96.36; Authentication-Results: mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=Q2b8L9MO; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.36 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by pete.vger.email (Postfix) with ESMTP id 7FA6280239E7; Mon, 25 Sep 2023 22:49:30 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at pete.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233680AbjIZFtW (ORCPT + 99 others); Tue, 26 Sep 2023 01:49:22 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44520 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229472AbjIZFtV (ORCPT ); Tue, 26 Sep 2023 01:49:21 -0400 Received: from fllv0015.ext.ti.com (fllv0015.ext.ti.com [198.47.19.141]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4968EF0; Mon, 25 Sep 2023 22:49:14 -0700 (PDT) Received: from lelv0266.itg.ti.com ([10.180.67.225]) by fllv0015.ext.ti.com (8.15.2/8.15.2) with ESMTP id 38Q5n6E2114681; Tue, 26 Sep 2023 00:49:06 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1695707346; bh=6yM0KH/OFNdiqifrALwi7ox3FMuqovyQ0nkJFVv0Lr0=; h=Date:CC:Subject:To:References:From:In-Reply-To; b=Q2b8L9MOFcrlF75Xa1a1EtNf9skgsw1XySqphZ87qcKyDZRhN344olCXDuncmheos gPxkXExDMpJNtb5oP8f19E6nftxpQOisq/vk839pD5+3k2os5bO3W1H1+tk7k75F4N ImMMt3d2R4lZ3KCaP6U38LdqaY5YN8CIaehgzlYA= Received: from DFLE102.ent.ti.com (dfle102.ent.ti.com [10.64.6.23]) by lelv0266.itg.ti.com (8.15.2/8.15.2) with ESMTPS id 38Q5n6U5118150 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=FAIL); Tue, 26 Sep 2023 00:49:06 -0500 Received: from DFLE108.ent.ti.com (10.64.6.29) by DFLE102.ent.ti.com (10.64.6.23) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.2507.23; Tue, 26 Sep 2023 00:49:05 -0500 Received: from fllv0040.itg.ti.com (10.64.41.20) by DFLE108.ent.ti.com (10.64.6.29) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.2507.23 via Frontend Transport; Tue, 26 Sep 2023 00:49:05 -0500 Received: from [172.24.227.9] (ileaxei01-snat2.itg.ti.com [10.180.69.6]) by fllv0040.itg.ti.com (8.15.2/8.15.2) with ESMTP id 38Q5n2Op039725; Tue, 26 Sep 2023 00:49:02 -0500 Message-ID: Date: Tue, 26 Sep 2023 11:19:01 +0530 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.15.1 CC: , , , , , , Subject: Re: [PATCH] PCI: keystone: Fix race condition when initializing PHYs To: , , , References: <20230926054200.963803-1-s-vadapalli@ti.com> Content-Language: en-US From: Siddharth Vadapalli In-Reply-To: <20230926054200.963803-1-s-vadapalli@ti.com> Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 7bit X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 X-Spam-Status: No, score=-2.3 required=5.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,NICE_REPLY_A,SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on pete.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (pete.vger.email [0.0.0.0]); Mon, 25 Sep 2023 22:49:30 -0700 (PDT) Kindly ignore this patch. The reference to the phy(s) need to be released in the error path as well which I have missed in this patch. I will address that and post the v2 patch. On 26/09/23 11:12, Siddharth Vadapalli wrote: > The PCI driver invokes the PHY APIs using the ks_pcie_enable_phy() > function. The PHY in this case is the Serdes. It is possible that the > PCI instance is configured for 2 lane operation across two different > Serdes instances, using 1 lane of each Serdes. In such a configuration, > if the reference clock for one Serdes is provided by the other Serdes, > it results in a race condition. After the Serdes providing the reference > clock is initialized by the PCI driver by invoking its PHY APIs, it is > not guaranteed that this Serdes remains powered on long enough for the > PHY APIs based initialization of the dependent Serdes. In such cases, > the PLL of the dependent Serdes fails to lock due to the absence of the > reference clock from the former Serdes which has been powered off by the > PM Core. > > Fix this by obtaining reference to the PHYs before invoking the PHY > initialization APIs and releasing reference after the initialization is > complete. > > Fixes: 49229238ab47 ("PCI: keystone: Cleanup PHY handling") > Signed-off-by: Siddharth Vadapalli > --- > drivers/pci/controller/dwc/pci-keystone.c | 8 ++++++++ > 1 file changed, 8 insertions(+) > > diff --git a/drivers/pci/controller/dwc/pci-keystone.c b/drivers/pci/controller/dwc/pci-keystone.c > index 49aea6ce3e87..526b68100a4a 100644 > --- a/drivers/pci/controller/dwc/pci-keystone.c > +++ b/drivers/pci/controller/dwc/pci-keystone.c > @@ -1218,12 +1218,20 @@ static int __init ks_pcie_probe(struct platform_device *pdev) > goto err_link; > } > > + /* Obtain reference(s) to the phy(s) */ > + for (i = 0; i < num_lanes; i++) > + phy_pm_runtime_get_sync(ks_pcie->phy[i]); > + > ret = ks_pcie_enable_phy(ks_pcie); > if (ret) { > dev_err(dev, "failed to enable phy\n"); > goto err_link; > } > > + /* Release reference(s) to the phy(s) */ > + for (i = 0; i < num_lanes; i++) > + phy_pm_runtime_put_sync(ks_pcie->phy[i]); > + > platform_set_drvdata(pdev, ks_pcie); > pm_runtime_enable(dev); > ret = pm_runtime_get_sync(dev); -- Regards, Siddharth.