Received: by 2002:a05:6358:9144:b0:117:f937:c515 with SMTP id r4csp739894rwr; Wed, 19 Apr 2023 12:20:41 -0700 (PDT) X-Google-Smtp-Source: AKy350ambzKHbqGa9SVa9ziZLKdBXLdICNTHsWj0Bk0v6O3hunpwlMZ459de2+Zd90nfyRuRaCPZ X-Received: by 2002:a17:902:ab8e:b0:1a2:8c7e:f301 with SMTP id f14-20020a170902ab8e00b001a28c7ef301mr5437737plr.45.1681932041645; Wed, 19 Apr 2023 12:20:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1681932041; cv=none; d=google.com; s=arc-20160816; b=vRlgkqNDpsgzknnGyRQpN6zh8nHeOe0vW/xva992UL+IZmlA++iaWu45SdLSH11xQ6 akUsLJYyZn1frdzPs5+A+odfDepng1F8AujS9ifdaJv9hbk0qrT2a57OCNp2O4ULmovM ZoRkL3hjxc6IDcbXMLIzBiQkSYFLR/MydKzvTWInG3OiiLxjDgUpkwZn2z5SnNh3bDL+ l4vV0nuFTufynpT0ZGw4DSf1+e5H2nfTyv/DQde3UpvBL6c98+wvrCVbDjF0IShBLlOl PjvzCOG3ve3tCabboQ0jqJlczsotrKVSwp2ZsPAy0M9GvY77onwhT2iDKlUcS/KbzSw0 kWmQ== 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 :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=G/y8ctTcURCYoZmiuLkLbWXgnfrdu76wyZiUSLHo2Ho=; b=L3fjwkJfJO84W2IraDSOmybndB/m42fWKEh7A6GnwQSPmb3gKv4rMfR37cZ24eGYx/ Xks06x2rnCcocruKsyTs285oljZ0PPaUr/bp8FiPbjSwIzW66I1KR5kVwGBu5Q/lt+tG CCpy2v0K+u2dEJsCBpAxsUqVg/G+iTjT0p/HSQTvnpb68fRL78zzrscvAF5U8JUKeF3I LLMGekj0t5XafiG/TCCngphH2xEzGTetJXpo99ibopUYT5WyDsB31iVUyKjCijaTaB99 8cmPFryJ3IAui2DBDV8F9jFAj43wRkvFcn/94NvD1HKW5k44nxOKwGNAZH/q6b+v/3df wwxA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b=cDK4YRXu; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id d12-20020a170902cecc00b001a81e552dc7si2296093plg.637.2023.04.19.12.20.29; Wed, 19 Apr 2023 12:20:41 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b=cDK4YRXu; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229959AbjDSTHJ (ORCPT + 99 others); Wed, 19 Apr 2023 15:07:09 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34162 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229441AbjDSTHH (ORCPT ); Wed, 19 Apr 2023 15:07:07 -0400 Received: from mx0a-0031df01.pphosted.com (mx0a-0031df01.pphosted.com [205.220.168.131]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4130565B6; Wed, 19 Apr 2023 12:07:02 -0700 (PDT) Received: from pps.filterd (m0279863.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.17.1.19/8.17.1.19) with ESMTP id 33JGiLbp030220; Wed, 19 Apr 2023 19:06:52 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=G/y8ctTcURCYoZmiuLkLbWXgnfrdu76wyZiUSLHo2Ho=; b=cDK4YRXujHSOFTJOMGYS7EvoADjvXAdnrheVTaxZqdhZKTsqPjIQc2SNKFcGXNUIIcho CssuFkbh4TQoOf3dT6yGxG48d404avLzqkTsp4mmGoT9HqaMWhx56MJ4Q+qBGLlsJerT qMHayZ1QY+N1nr4XKCDoPOXk0a/cnPdW9o6vV7ho/qpIsaQelG01iXpZoy9DXu0er/eO SXe3Feyu5XqEQYKN6MnWbDWe3WOu+SqqhDadykXJnV6JTLZyBHuQp/cfVbg6DfBRVX8i CODSMbJPY0+vlBYUMnwmPMVjmX+mrINQMDjJ8+OFHWxJGdE5tt0/mFBp5Wd/YslTUKN1 hA== Received: from nalasppmta03.qualcomm.com (Global_NAT1.qualcomm.com [129.46.96.20]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 3q26wy29j5-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Wed, 19 Apr 2023 19:06:52 +0000 Received: from nalasex01a.na.qualcomm.com (nalasex01a.na.qualcomm.com [10.47.209.196]) by NALASPPMTA03.qualcomm.com (8.17.1.5/8.17.1.5) with ESMTPS id 33JJ6pG8019846 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Wed, 19 Apr 2023 19:06:51 GMT Received: from [10.134.71.70] (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.986.42; Wed, 19 Apr 2023 12:06:50 -0700 Message-ID: <11c72462-b256-d0db-a666-9615da4420f6@quicinc.com> Date: Wed, 19 Apr 2023 12:06:50 -0700 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:102.0) Gecko/20100101 Thunderbird/102.10.0 Subject: Re: [Freedreno] [PATCH 5/5] drm/msm/dpu1: Handle the reg bus ICC path Content-Language: en-US To: Konrad Dybcio , Rob Clark , Abhinav Kumar , Dmitry Baryshkov , Sean Paul , David Airlie , Daniel Vetter , Rob Herring , Krzysztof Kozlowski , Krishna Manikandan CC: , , , , "Marijn Suijten" , References: <20230417-topic-dpu_regbus-v1-0-06fbdc1643c0@linaro.org> <20230417-topic-dpu_regbus-v1-5-06fbdc1643c0@linaro.org> From: Jeykumar Sankaran In-Reply-To: <20230417-topic-dpu_regbus-v1-5-06fbdc1643c0@linaro.org> Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 7bit X-Originating-IP: [10.80.80.8] 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: uZuyWiNw6UBDUJjAuj75d_TvKXv1_VVz X-Proofpoint-ORIG-GUID: uZuyWiNw6UBDUJjAuj75d_TvKXv1_VVz X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.254,Aquarius:18.0.942,Hydra:6.0.573,FMLib:17.11.170.22 definitions=2023-04-19_13,2023-04-18_01,2023-02-09_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 priorityscore=1501 impostorscore=0 clxscore=1011 mlxscore=0 malwarescore=0 spamscore=0 mlxlogscore=999 adultscore=0 bulkscore=0 suspectscore=0 lowpriorityscore=0 phishscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2303200000 definitions=main-2304190167 X-Spam-Status: No, score=-5.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,RCVD_IN_DNSWL_LOW, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 4/17/2023 8:30 AM, Konrad Dybcio wrote: > Apart from the already handled data bus (MAS_MDP_Pn<->DDR), there's > another path that needs to be handled to ensure MDSS functions properly, > namely the "reg bus", a.k.a the CPU-MDSS interconnect. > > Gating that path may have a variety of effects.. from none to otherwise > inexplicable DSI timeouts.. > > On the DPU side, we need to keep the bus alive. The vendor driver > kickstarts it to max (300Mbps) throughput on first commit, but in > exchange for some battery life in rare DPU-enabled-panel-disabled > usecases, we can request it at DPU init and gate it at suspend. > > Signed-off-by: Konrad Dybcio > --- > drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c | 22 ++++++++++++++++++++-- > drivers/gpu/drm/msm/disp/dpu1/dpu_kms.h | 1 + > 2 files changed, 21 insertions(+), 2 deletions(-) > > diff --git a/drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c b/drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c > index dd6c1c40ab9e..d1f77faebbc0 100644 > --- a/drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c > +++ b/drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c > @@ -384,15 +384,17 @@ static int dpu_kms_global_obj_init(struct dpu_kms *dpu_kms) > return 0; > } > > -static int dpu_kms_parse_data_bus_icc_path(struct dpu_kms *dpu_kms) > +static int dpu_kms_parse_icc_paths(struct dpu_kms *dpu_kms) > { > struct icc_path *path0; > struct icc_path *path1; > + struct icc_path *reg_bus_path; > struct drm_device *dev = dpu_kms->dev; > struct device *dpu_dev = dev->dev; > > path0 = msm_icc_get(dpu_dev, "mdp0-mem"); > path1 = msm_icc_get(dpu_dev, "mdp1-mem"); > + reg_bus_path = msm_icc_get(dpu_dev, "cpu-cfg"); > > if (IS_ERR_OR_NULL(path0)) > return PTR_ERR_OR_ZERO(path0); > @@ -404,6 +406,10 @@ static int dpu_kms_parse_data_bus_icc_path(struct dpu_kms *dpu_kms) > dpu_kms->mdp_path[1] = path1; > dpu_kms->num_mdp_paths++; > } > + > + if (!IS_ERR_OR_NULL(reg_bus_path)) > + dpu_kms->reg_bus_path = reg_bus_path; > + > return 0; > } > > @@ -1039,7 +1045,7 @@ static int dpu_kms_hw_init(struct msm_kms *kms) > DPU_DEBUG("REG_DMA is not defined"); > } > > - dpu_kms_parse_data_bus_icc_path(dpu_kms); > + dpu_kms_parse_icc_paths(dpu_kms); > > rc = pm_runtime_resume_and_get(&dpu_kms->pdev->dev); > if (rc < 0) > @@ -1241,6 +1247,9 @@ static int __maybe_unused dpu_runtime_suspend(struct device *dev) > for (i = 0; i < dpu_kms->num_mdp_paths; i++) > icc_set_bw(dpu_kms->mdp_path[i], 0, 0); > > + if (dpu_kms->reg_bus_path) > + icc_set_bw(dpu_kms->reg_bus_path, 0, 0); > + > return 0; > } > > @@ -1261,6 +1270,15 @@ static int __maybe_unused dpu_runtime_resume(struct device *dev) > return rc; > } > > + /* > + * The vendor driver supports setting 76.8 / 150 / 300 Mbps on this How do you arrive at these distint BW values? Are they provided by the ICC fwk for the given path? > + * path, but it seems to go for the highest level when display output > + * is enabled and zero otherwise. For simplicity, we can assume that > + * DPU being enabled and running implies that. > + */ > + if (dpu_kms->reg_bus_path) > + icc_set_bw(dpu_kms->reg_bus_path, 0, MBps_to_icc(300)); > + > dpu_vbif_init_memtypes(dpu_kms); > > drm_for_each_encoder(encoder, ddev) > diff --git a/drivers/gpu/drm/msm/disp/dpu1/dpu_kms.h b/drivers/gpu/drm/msm/disp/dpu1/dpu_kms.h > index d5d9bec90705..c332381d58c4 100644 > --- a/drivers/gpu/drm/msm/disp/dpu1/dpu_kms.h > +++ b/drivers/gpu/drm/msm/disp/dpu1/dpu_kms.h > @@ -111,6 +111,7 @@ struct dpu_kms { > atomic_t bandwidth_ref; > struct icc_path *mdp_path[2]; > u32 num_mdp_paths; > + struct icc_path *reg_bus_path; > }; > > struct vsync_info { >