Received: by 2002:ab2:3350:0:b0:1f4:6588:b3a7 with SMTP id o16csp1235014lqe; Mon, 8 Apr 2024 02:59:47 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCXAhbMopTV1qmqsPjB2w07zQzWoqc1MJ1zav9dKq9qApWQjrNo44d8f84BFncm6CsEGTbp8/ROuor4y6mJGW9QPLQYpH71J/z4xZfgUPQ== X-Google-Smtp-Source: AGHT+IE6XW/iiZQ4qCpSpd9ZsIGfgFFrH6xrNnOK141jFc/5D0iu0epl2wPCrafKm8hSRR44BYOv X-Received: by 2002:a05:6a20:7355:b0:1a7:42b1:f18 with SMTP id v21-20020a056a20735500b001a742b10f18mr7925819pzc.52.1712570386810; Mon, 08 Apr 2024 02:59:46 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1712570386; cv=pass; d=google.com; s=arc-20160816; b=oveHoP2mUdpfVch/PfegJguAU+2Cw4zPbhG3pijK6fclPHRlRauA2LB5dN44LEceEx 1WO5q11pj75CV6cd4bgoU2PGIi8maT6qfVmTBYCbVhyzc09xWa2H4QnrEMCi8sksfX6O McLzJBjNKpA5fOJtHjjSNfulQ6vPrGmj3Dm60prcrd8vNHFo13R5Ko8VMRlv2SobMYjJ DSrZ9MJZHfpcqNcY6txUaPKQZKybu4oxJkvJEaghDqpCn/XCsmZ9m0u2DjVGXmWrcnTd JmB1Q4VT/ZwWPyacLfwTJyHJjVnOLcXHen31WQqzRyNTtsyzz1ZohyowiP4ToyirumIJ Reow== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:date:message-id:dkim-signature; bh=a867BXPNAL7S1LSZKB6Z1PPmPo7m27VujxgxS1VpLfg=; fh=9otEHVMncT/ULv3FdSE/0jfrRLh38+TTiNSTvo1XZD4=; b=xVXNxIcD/f59saSGuMwoSvUyqgO1HTKZlTlLYxEP7fMHi7T7p+8D4Nq/E5MiP6gOLs Nde2YvNmr/+9sNLVILiGA6pazWmQA4HWrqK5c91jlF8EIU7wtGqwZsu9QSXauc5AwRAn rNHVCFi3n3KZHOdRx1oTOtA0akOIU0Qvov7NbCg9ONakV+ivCZ65LUQoBdIXMPJfD4bF lev258gLo+WMKLf9cdr/yGtAWRT1GImvHrwHax5KLEj4rrN5l/RoybzbyP0WJAveji/L Sohky3S+sXQXM3Jn1S3iwCdW2AkTFMgAj5+pE15QRGIcXI35kcqGHW6sg3GDUyNzHquG jQVw==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b="l8N/kCju"; arc=pass (i=1 spf=pass spfdomain=quicinc.com dkim=pass dkdomain=quicinc.com dmarc=pass fromdomain=quicinc.com); spf=pass (google.com: domain of linux-kernel+bounces-135183-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-135183-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Return-Path: Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [139.178.88.99]) by mx.google.com with ESMTPS id q15-20020a63e94f000000b005eb028e2887si6127967pgj.709.2024.04.08.02.59.46 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 08 Apr 2024 02:59:46 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-135183-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) client-ip=139.178.88.99; Authentication-Results: mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b="l8N/kCju"; arc=pass (i=1 spf=pass spfdomain=quicinc.com dkim=pass dkdomain=quicinc.com dmarc=pass fromdomain=quicinc.com); spf=pass (google.com: domain of linux-kernel+bounces-135183-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-135183-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sv.mirrors.kernel.org (Postfix) with ESMTPS id F3A532859AB for ; Mon, 8 Apr 2024 09:53:02 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 9E1BF4E1A8; Mon, 8 Apr 2024 09:52:52 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=quicinc.com header.i=@quicinc.com header.b="l8N/kCju" Received: from mx0b-0031df01.pphosted.com (mx0b-0031df01.pphosted.com [205.220.180.131]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 9E9064EB3D; Mon, 8 Apr 2024 09:52:49 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=205.220.180.131 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1712569971; cv=none; b=jlzRheZkjUuLaLN5584fj4jmXrsod1W0gWz65LekJmbB5L6YM13f/Lc3VxlBa5I2dLNl/HJMTQrlYGPDKG+Fr+BLOueBUBQb406s2vE5J9ZT4VnroyuTBmU4C8midnpR4A5NgUtekozuo5bUKzpByO/hGZ+/YrbU39ulc3MVD3o= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1712569971; c=relaxed/simple; bh=/VOELRbH4plEYJOGwePqrosJ6i7I1OteBbFhhfratW8=; h=Message-ID:Date:MIME-Version:Subject:To:CC:References:From: In-Reply-To:Content-Type; b=P+tiFdjSPyQ+Nb6bg9h3NXnhR+O2dUP2DKIc9J9b6BS0o/CXtIlIVi6dBRiaANTFpNHk6G+mGwJC6MtopoJtP62yWiGPeic7w0xQJfNM8+KD+h663GyaYN3pxMKw7D035CHY+P9QcNY+aROZhqgGACTUmOnE1ss//Cg2sJ9b9w8= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=quicinc.com; spf=pass smtp.mailfrom=quicinc.com; dkim=pass (2048-bit key) header.d=quicinc.com header.i=@quicinc.com header.b=l8N/kCju; arc=none smtp.client-ip=205.220.180.131 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=quicinc.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=quicinc.com Received: from pps.filterd (m0279872.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.17.1.24/8.17.1.24) with ESMTP id 4386e931026786; Mon, 8 Apr 2024 09:52:41 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quicinc.com; h= message-id:date:mime-version:subject:to:cc:references:from :in-reply-to:content-type:content-transfer-encoding; s= qcppdkim1; bh=a867BXPNAL7S1LSZKB6Z1PPmPo7m27VujxgxS1VpLfg=; b=l8 N/kCjuySa8CK9vHmhgCxnEyT/9c5XGzT0NxWp76ulpDoSb+UGv42m+sUW638XoP2 N8n9WAL+slsj0h4OC5TUNRa4akrmbobVAOlTwlGc3p86y+pMZ40SQfyVVvTidLA7 1WMvzgoR1L8lYlrDi40HS9xUltqabxbylbokGQu0tgNnC9kCbCW5hdbikmscGOSV iM5XYylLc7FnxiEtVRwdKO3d7cy47JuUQSTSeC4cxXM7oQuHYL9y0yOmyWsv3iCm TyjEs1KZ3LBNQY+lG9bQL2kSnTaqLP+jHJD2PMji1UxBTzmfteVnnBhETIigyXTz xr4quzBFUDD6DHedxkkA== Received: from nalasppmta01.qualcomm.com (Global_NAT1.qualcomm.com [129.46.96.20]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 3xcbg00bcc-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 08 Apr 2024 09:52:40 +0000 (GMT) Received: from nalasex01a.na.qualcomm.com (nalasex01a.na.qualcomm.com [10.47.209.196]) by NALASPPMTA01.qualcomm.com (8.17.1.5/8.17.1.5) with ESMTPS id 4389qd3Y018645 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 8 Apr 2024 09:52:39 GMT Received: from [10.216.26.18] (10.80.80.8) by nalasex01a.na.qualcomm.com (10.47.209.196) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1544.4; Mon, 8 Apr 2024 02:52:30 -0700 Message-ID: <2a579464-b66b-0186-9e7d-723aaf304a89@quicinc.com> Date: Mon, 8 Apr 2024 15:22:25 +0530 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:91.0) Gecko/20100101 Thunderbird/91.13.1 Subject: Re: [PATCH v9 6/6] PCI: qcom: Add OPP support to scale performance state of power domain Content-Language: en-US To: Manivannan Sadhasivam CC: Bjorn Andersson , Konrad Dybcio , Rob Herring , "Krzysztof Kozlowski" , Conor Dooley , Lorenzo Pieralisi , =?UTF-8?Q?Krzysztof_Wilczy=c5=84ski?= , Bjorn Helgaas , , , , , , , , , , , , , References: <20240407-opp_support-v9-0-496184dc45d7@quicinc.com> <20240407-opp_support-v9-6-496184dc45d7@quicinc.com> <20240407150048.GE2679@thinkpad> <6e9b4379-5849-73cd-4d89-5e809b4c71a4@quicinc.com> <20240408094525.GB5727@thinkpad> From: Krishna Chaitanya Chundru In-Reply-To: <20240408094525.GB5727@thinkpad> Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 7bit X-ClientProxiedBy: nasanex01b.na.qualcomm.com (10.46.141.250) To nalasex01a.na.qualcomm.com (10.47.209.196) X-QCInternal: smtphost X-Proofpoint-Virus-Version: vendor=nai engine=6200 definitions=5800 signatures=585085 X-Proofpoint-GUID: -LSZ8ZKRg0_NcZCM9_z_wNg8r0d0qRsr X-Proofpoint-ORIG-GUID: -LSZ8ZKRg0_NcZCM9_z_wNg8r0d0qRsr X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.272,Aquarius:18.0.1011,Hydra:6.0.619,FMLib:17.11.176.26 definitions=2024-04-08_08,2024-04-05_02,2023-05-22_02 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 clxscore=1015 mlxscore=0 lowpriorityscore=0 phishscore=0 priorityscore=1501 bulkscore=0 impostorscore=0 mlxlogscore=999 suspectscore=0 adultscore=0 malwarescore=0 spamscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.19.0-2404010003 definitions=main-2404080076 On 4/8/2024 3:15 PM, Manivannan Sadhasivam wrote: > On Mon, Apr 08, 2024 at 02:32:18PM +0530, Krishna Chaitanya Chundru wrote: >> >> >> On 4/7/2024 8:30 PM, Manivannan Sadhasivam wrote: >>> On Sun, Apr 07, 2024 at 10:07:39AM +0530, Krishna chaitanya chundru wrote: >>>> QCOM Resource Power Manager-hardened (RPMh) is a hardware block which >>>> maintains hardware state of a regulator by performing max aggregation of >>>> the requests made by all of the clients. >>>> >>>> PCIe controller can operate on different RPMh performance state of power >>>> domain based on the speed of the link. And this performance state varies >>>> from target to target, like some controllers support GEN3 in NOM (Nominal) >>>> voltage corner, while some other supports GEN3 in low SVS (static voltage >>>> scaling). >>>> >>>> The SoC can be more power efficient if we scale the performance state >>>> based on the aggregate PCIe link bandwidth. >>>> >>>> Add Operating Performance Points (OPP) support to vote for RPMh state based >>>> on the aggregate link bandwidth. >>>> >>>> OPP can handle ICC bw voting also, so move ICC bw voting through OPP >>>> framework if OPP entries are present. >>>> >>>> Different link configurations may share the same aggregate bandwidth, >>>> e.g., a 2.5 GT/s x2 link and a 5.0 GT/s x1 link have the same bandwidth >>>> and share the same OPP entry. >>>> >>> >>> This info should be part of the dts change. >>> >> ok I will move this to dts patch in next patch series. >>>> As we are moving ICC voting as part of OPP, don't initialize ICC if OPP >>>> is supported. >>>> >>>> Before PCIe link is initialized vote for highest OPP in the OPP table, >>>> so that we are voting for maximum voltage corner for the link to come up >>>> in maximum supported speed. >>>> >>>> Signed-off-by: Krishna chaitanya chundru >>>> --- >>>> drivers/pci/controller/dwc/pcie-qcom.c | 72 +++++++++++++++++++++++++++------- >>>> 1 file changed, 58 insertions(+), 14 deletions(-) >>>> >>>> diff --git a/drivers/pci/controller/dwc/pcie-qcom.c b/drivers/pci/controller/dwc/pcie-qcom.c >>>> index b4893214b2d3..4ad5ef3bf8fc 100644 >>>> --- a/drivers/pci/controller/dwc/pcie-qcom.c >>>> +++ b/drivers/pci/controller/dwc/pcie-qcom.c >>>> @@ -22,6 +22,7 @@ >>>> #include >>>> #include >>>> #include >>>> +#include >>>> #include >>>> #include >>>> #include >>>> @@ -1442,15 +1443,13 @@ static int qcom_pcie_icc_init(struct qcom_pcie *pcie) >>>> return 0; >>>> } >>>> -static void qcom_pcie_icc_update(struct qcom_pcie *pcie) >>>> +static void qcom_pcie_icc_opp_update(struct qcom_pcie *pcie) >>>> { >>>> struct dw_pcie *pci = pcie->pci; >>>> - u32 offset, status; >>>> + u32 offset, status, freq; >>>> + struct dev_pm_opp *opp; >>>> int speed, width; >>>> - int ret; >>>> - >>>> - if (!pcie->icc_mem) >>>> - return; >>>> + int ret, mbps; >>>> offset = dw_pcie_find_capability(pci, PCI_CAP_ID_EXP); >>>> status = readw(pci->dbi_base + offset + PCI_EXP_LNKSTA); >>>> @@ -1462,10 +1461,26 @@ static void qcom_pcie_icc_update(struct qcom_pcie *pcie) >>>> speed = FIELD_GET(PCI_EXP_LNKSTA_CLS, status); >>>> width = FIELD_GET(PCI_EXP_LNKSTA_NLW, status); >>>> - ret = icc_set_bw(pcie->icc_mem, 0, width * QCOM_PCIE_LINK_SPEED_TO_BW(speed)); >>>> - if (ret) { >>>> - dev_err(pci->dev, "failed to set interconnect bandwidth for PCIe-MEM: %d\n", >>>> - ret); >>>> + if (pcie->icc_mem) { >>>> + ret = icc_set_bw(pcie->icc_mem, 0, width * QCOM_PCIE_LINK_SPEED_TO_BW(speed)); >>>> + if (ret) { >>>> + dev_err(pci->dev, "failed to set interconnect bandwidth for PCIe-MEM: %d\n", >>> >>> s/failed/Failed >>> >>>> + ret); >>>> + } >>>> + } else { >>>> + mbps = pcie_link_speed_to_mbps(pcie_link_speed[speed]); >>>> + if (mbps < 0) >>>> + return; >>>> + >>>> + freq = mbps * 1000; >>>> + opp = dev_pm_opp_find_freq_exact(pci->dev, freq * width, true); >>> >>> As per the API documentation, dev_pm_opp_put() should be called for both success >>> and failure case. >>> >> ACK. >>>> + if (!IS_ERR(opp)) { >>> >>> So what is the action if OPP is not found for the freq? >>> >> There is already a vote for maximum freq in the probe, so if it fails >> here we can continue here. >> If you feel otherwise let me know I Can make changes as suggested. > > You should just log the error and continue. > >>>> + ret = dev_pm_opp_set_opp(pci->dev, opp); >>>> + if (ret) >>>> + dev_err(pci->dev, "Failed to set opp: freq %ld ret %d\n", >>> >>> 'Failed to set OPP for freq (%ld): %d' >>> >>>> + dev_pm_opp_get_freq(opp), ret); >>>> + dev_pm_opp_put(opp); >>>> + } >>>> } >>>> } >>>> @@ -1509,8 +1524,10 @@ static void qcom_pcie_init_debugfs(struct qcom_pcie *pcie) >>>> static int qcom_pcie_probe(struct platform_device *pdev) >>>> { >>>> const struct qcom_pcie_cfg *pcie_cfg; >>>> + unsigned long max_freq = INT_MAX; >>>> struct device *dev = &pdev->dev; >>>> struct qcom_pcie *pcie; >>>> + struct dev_pm_opp *opp; >>>> struct dw_pcie_rp *pp; >>>> struct resource *res; >>>> struct dw_pcie *pci; >>>> @@ -1577,9 +1594,33 @@ static int qcom_pcie_probe(struct platform_device *pdev) >>>> goto err_pm_runtime_put; >>>> } >>>> - ret = qcom_pcie_icc_init(pcie); >>>> - if (ret) >>>> + /* OPP table is optional */ >>>> + ret = devm_pm_opp_of_add_table(dev); >>>> + if (ret && ret != -ENODEV) { >>>> + dev_err_probe(dev, ret, "Failed to add OPP table\n"); >>>> goto err_pm_runtime_put; >>>> + } >>>> + >>>> + /* >>>> + * Use highest OPP here if the OPP table is present. At the end of >>> >>> I believe I asked you to add the information justifying why the highest OPP >>> should be used. >>> >> I added the info in the commit message, I will add as the comment in the >> next patch. >> >>>> + * the probe(), OPP will be updated using qcom_pcie_icc_opp_update(). >>>> + */ >>>> + if (!ret) { >>>> + opp = dev_pm_opp_find_freq_floor(dev, &max_freq); >>> >>> Same comment as dev_pm_opp_find_freq_exact(). >>> >>>> + if (!IS_ERR(opp)) { >>>> + ret = dev_pm_opp_set_opp(dev, opp); >>>> + if (ret) >>>> + dev_err_probe(pci->dev, ret, >>>> + "Failed to set OPP: freq %ld\n", >>> >>> Same comment as above. >>> >>>> + dev_pm_opp_get_freq(opp)); >>>> + dev_pm_opp_put(opp); >>> >>> So you want to continue even in the case of failure? >>> >> I wil make changes to fallback to driver voting for icc bw if it fails here. > > That's not needed. If the OPP table is present, then failure to set OPP should > be treated as a hard failure. > Sure, I will make changes to fail the probe then - Krishna Chaitanya. > - Mani >