From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from gabe.freedesktop.org (gabe.freedesktop.org [131.252.210.177]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 4DA63C87FCB for ; Fri, 8 Aug 2025 17:22:29 +0000 (UTC) Received: from gabe.freedesktop.org (localhost [127.0.0.1]) by gabe.freedesktop.org (Postfix) with ESMTP id 77FD410E03A; Fri, 8 Aug 2025 17:22:28 +0000 (UTC) Authentication-Results: gabe.freedesktop.org; dkim=pass (2048-bit key; unprotected) header.d=qualcomm.com header.i=@qualcomm.com header.b="SENV1KcE"; dkim-atps=neutral Received: from mx0a-0031df01.pphosted.com (mx0a-0031df01.pphosted.com [205.220.168.131]) by gabe.freedesktop.org (Postfix) with ESMTPS id 6554A10E03A for ; Fri, 8 Aug 2025 17:22:27 +0000 (UTC) Received: from pps.filterd (m0279864.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.18.1.2/8.18.1.2) with ESMTP id 578EjPdC007642 for ; Fri, 8 Aug 2025 17:22:27 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=qualcomm.com; h= cc:content-transfer-encoding:content-type:date:from:in-reply-to :message-id:mime-version:references:subject:to; s=qcppdkim1; bh= jyBcXhZj2R8UGlkk97Lt6qighcQ9HpYxu7rqj/QliiY=; b=SENV1KcELHeGZRqf IjVMPy8ZWUeiLQ9+XVXT2Zp/RN2dvaXHHww0ldnOYODlJn+b1e4NdpvZ8Ey2bKZB 2Lpvvn7SkQs1xRzHkfMY8AujzQ256aLJEb/fu09g77Xg/7znQPZw3y7Roa2v166I kVdyoDW6bRGVl1mRIV5tYIXvGqG/InfGDP3sKL9AXYFjpMHnM2B2f4m4ctKPJiDm mMySRYZvJoslz8SBkVrZ0U9fQ6HpgiPBI7/0OWBmts9g1wVsxCJoebg9WVMrXbBn 4iODIWDyfbeLZaNPu9OuzRbzcUPr8BRHFzFy62/v2/TpvLSFvMdsf0nn9MOa1V1A VmuGhg== Received: from mail-pf1-f197.google.com (mail-pf1-f197.google.com [209.85.210.197]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 48c8u27t5c-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128 verify=NOT) for ; Fri, 08 Aug 2025 17:22:26 +0000 (GMT) Received: by mail-pf1-f197.google.com with SMTP id d2e1a72fcca58-76bb326ad0bso2592081b3a.0 for ; Fri, 08 Aug 2025 10:22:26 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1754673746; x=1755278546; h=content-transfer-encoding:in-reply-to:from:content-language :references:cc:to:subject:user-agent:mime-version:date:message-id :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=jyBcXhZj2R8UGlkk97Lt6qighcQ9HpYxu7rqj/QliiY=; b=YJpwCdBOqb5ISj0qWklXf3gvYf/4i45q/JWi6PHtkA3lyZkBDoXJmgh7tu36AeF8mF puHvKCttxZXcSyK2tT+7hmhxjk1zS1bhJenIndf6Wch0A3GpZV+SneNbHq65e1xUh7Lr lxQnSx5LzcMEX51j5i7iGrkEe+/Cb6mNeR1Ta7iZJq+jb9X1l+AL27S+kEmmzkea+SRR 2cB+MlFfH155u3kPkcS5KyZy2sx/fixQ+Q3IjDecROIeuPae1cqSnzqVc9/XN4+D+Lb8 YPXKjVfbY22htpe4/tleeEQ+EfjgNAfReNa3xEES8OWEKYz1U60KZqP3IZPMvooQPTt4 910Q== X-Forwarded-Encrypted: i=1; AJvYcCXWur8XzXb1koQiYYcmbSlrIskrNysUmObCyFhdY24n1yf1+1EBKORaoVoEfGmuwIyFUi8FRdY0dVc=@lists.freedesktop.org X-Gm-Message-State: AOJu0YxVh+G7tYZF95v+Et8K6tO7dwmU1bMtwnehjwgj3BNi6aWXeHow E0tc8lvZ8H+IDUzK0HPVhgL4ccNdXXmIOes4m3SJia3PCxY5WQrGMaiU+H4kg4tpm01CU3+TRjN b6IwNV/lYiLqTtZn6lHcJl0CCCZKxlTIvbTuFodf64KmNwO/wKJicT865tl3Y7c8VX8eMnF4= X-Gm-Gg: ASbGncv4OauaD3YEUl2jdiHqSJfDKASiG6ruhrOQjtzvzIFC1ovldz5cqSQLrRkFk8t phakNKppBcFhqFoN9AQ6DQuEAhq32bDhCTDGAC2XoIvWbQeCGdkhAQQYBG6Kg2gQmsh3AKeWasX lZQpJXVs6G5JSA8HaF85rVagXlSQvkdnV1FljWWNYDAIG6Ld518RrQTIbpktCOKA4tvaTX/6SnT Bu00OhfrXNCoYlzH/Aihqlm7Zy9AoB5M1gdGPFmGNf9Xqe0L53UF1sbFyRcXseg44YzVoFoiWtQ kMA4aEM2F2qOvl2pdx4wZiBzspqnEjjbvqYlUeqZpKlAtZlL+q/+RpGdWDRQ7XhD X-Received: by 2002:a05:6a20:7d9f:b0:240:1132:6f0 with SMTP id adf61e73a8af0-240551eeac0mr6475867637.43.1754673745699; Fri, 08 Aug 2025 10:22:25 -0700 (PDT) X-Google-Smtp-Source: AGHT+IFi0ezLAvd5RkULpFWK7WLTaadsd+/Ps2gsqlHJKq3156s96y5T3Pq4HOvg12o43Wrff+vHAA== X-Received: by 2002:a05:6a20:7d9f:b0:240:1132:6f0 with SMTP id adf61e73a8af0-240551eeac0mr6475822637.43.1754673745264; Fri, 08 Aug 2025 10:22:25 -0700 (PDT) Received: from [192.168.1.4] ([106.222.234.151]) by smtp.gmail.com with ESMTPSA id 41be03b00d2f7-b422bac0d14sm18058211a12.41.2025.08.08.10.22.21 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Fri, 08 Aug 2025 10:22:24 -0700 (PDT) Message-ID: Date: Fri, 8 Aug 2025 22:52:19 +0530 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH 05/17] drm/msm/a6xx: Fix PDC sleep sequence To: Konrad Dybcio , Rob Clark , Sean Paul , Konrad Dybcio , Dmitry Baryshkov , Abhinav Kumar , Jessica Zhang , Marijn Suijten , David Airlie , Simona Vetter Cc: linux-arm-msm@vger.kernel.org, dri-devel@lists.freedesktop.org, freedreno@lists.freedesktop.org, linux-kernel@vger.kernel.org References: <20250720-ifpc-support-v1-0-9347aa5bcbd6@oss.qualcomm.com> <20250720-ifpc-support-v1-5-9347aa5bcbd6@oss.qualcomm.com> <937197e9-09dd-4f3c-bdb4-4001f5217c07@oss.qualcomm.com> Content-Language: en-US From: Akhil P Oommen In-Reply-To: <937197e9-09dd-4f3c-bdb4-4001f5217c07@oss.qualcomm.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-Proofpoint-GUID: xpsReZjQjokALhLgFlT5DMmoCkKk37RX X-Authority-Analysis: v=2.4 cv=Q/TS452a c=1 sm=1 tr=0 ts=68963252 cx=c_pps a=rEQLjTOiSrHUhVqRoksmgQ==:117 a=YZlS21pjlsXJIaRBoB+Oqw==:17 a=IkcTkHD0fZMA:10 a=2OwXVqhp2XgA:10 a=EUspDBNiAAAA:8 a=g_v6zqOf2VaQD3ULXM8A:9 a=QEXdDO2ut3YA:10 a=2VI0MkxyNR6bbpdq8BZq:22 X-Proofpoint-ORIG-GUID: xpsReZjQjokALhLgFlT5DMmoCkKk37RX X-Proofpoint-Spam-Details-Enc: AW1haW4tMjUwODA2MDA5MCBTYWx0ZWRfXxMe1/72/sWpH O5US/Y7J6Ll32AKFhBmak50IHIczr9Pp5NyO3E27I5lSE7uUBYXNd85vRkviq0rPEHCpMGKyhlp ZzeeQ+64JNEErpM+i+38khsWejdzLF2PC5icxkz8R4VwOTCN+nRvwPqtfCR4LDhPOOT0sXlxyE5 O+KWfPROzfm40Cs5O54aMjUvSeZKJJLEpT/zc5juQjB+DtJGUsrs8lLnu/PHCu0k97lpHZxwhN1 OLThdqI8FnFh5eOGapdsTlun0RcnqNjinWG4f/vAisTJXTrOrw+BilhZy9jQ89Pp058uqzaARdW 4DimpVTiY1bjIiwkh08ORAlck60C7YnLJwM5ud5kjs6njvODSfy1Y/7vrl0Ak1EMNgE6C4Ti+Lv nlwAjTRW X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1099,Hydra:6.1.9,FMLib:17.12.80.40 definitions=2025-08-08_05,2025-08-06_01,2025-03-28_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 spamscore=0 adultscore=0 clxscore=1015 suspectscore=0 malwarescore=0 priorityscore=1501 impostorscore=0 phishscore=0 bulkscore=0 classifier=typeunknown authscore=0 authtc= authcc= route=outbound adjust=0 reason=mlx scancount=1 engine=8.19.0-2507300000 definitions=main-2508060090 X-BeenThere: dri-devel@lists.freedesktop.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Direct Rendering Infrastructure - Development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" On 8/7/2025 7:21 PM, Konrad Dybcio wrote: > On 7/20/25 2:16 PM, Akhil P Oommen wrote: >> Since the PDC resides out of the GPU subsystem and cannot be reset in >> case it enters bad state, utmost care must be taken to trigger the PDC >> wake/sleep routines in the correct order. >> >> The PDC wake sequence can be exercised only after a PDC sleep sequence. >> Additionally, GMU firmware should initialize a few registers before the >> KMD can trigger a PDC sleep sequence. So PDC sleep can't be done if the >> GMU firmware has not initialized. Track these dependencies using a new >> status variable and trigger PDC sleep/wake sequences appropriately. >> >> Signed-off-by: Akhil P Oommen >> --- > > FWIW some time ago I made this patch, which tackles a similar issue, > perhaps it's a good idea to merge both: > > From 7d6441fc6ec5ee7fe723e1ad86d11fdd17bee922 Mon Sep 17 00:00:00 2001 > From: Konrad Dybcio > Date: Thu, 20 Feb 2025 10:28:51 +0100 > Subject: [PATCH] drm/msm/adreno: Delay the Adreno RPMh startup to HFI init > > There's no use in trying to power up the GX logic before we're almost > ready to fire up the GPU. In fact, with A8xx the PDC and RSC uCode are > loaded by the GMU firmware, so we *must* wait for the GMU to fully > initialize before trying to do so. > iirc, this wake up sequence should be done before fw start. That aligns with downstream sequence order too. -Akhil > Move it to right before HFI init. > > Signed-off-by: Konrad Dybcio > --- > drivers/gpu/drm/msm/adreno/a6xx_gmu.c | 12 ++---------- > drivers/gpu/drm/msm/adreno/a6xx_gmu.h | 1 + > drivers/gpu/drm/msm/adreno/a6xx_hfi.c | 2 +- > 3 files changed, 4 insertions(+), 11 deletions(-) > > diff --git a/drivers/gpu/drm/msm/adreno/a6xx_gmu.c b/drivers/gpu/drm/msm/adreno/a6xx_gmu.c > index 28e6705c6da6..3335583ada45 100644 > --- a/drivers/gpu/drm/msm/adreno/a6xx_gmu.c > +++ b/drivers/gpu/drm/msm/adreno/a6xx_gmu.c > @@ -513,7 +513,7 @@ static int a6xx_gmu_notify_slumber(struct a6xx_gmu *gmu) > return ret; > } > > -static int a6xx_rpmh_start(struct a6xx_gmu *gmu) > +int a6xx_rpmh_start(struct a6xx_gmu *gmu) > { > int ret; > u32 val; > @@ -842,19 +842,11 @@ static int a6xx_gmu_fw_start(struct a6xx_gmu *gmu, unsigned int state) > else > gmu_write(gmu, REG_A6XX_GMU_GENERAL_7, 1); > > - if (state == GMU_WARM_BOOT) { > - ret = a6xx_rpmh_start(gmu); > - if (ret) > - return ret; > - } else { > + if (state == GMU_COLD_BOOT) { > if (WARN(!adreno_gpu->fw[ADRENO_FW_GMU], > "GMU firmware is not loaded\n")) > return -ENOENT; > > - ret = a6xx_rpmh_start(gmu); > - if (ret) > - return ret; > - > ret = a6xx_gmu_fw_load(gmu); > if (ret) > return ret; > diff --git a/drivers/gpu/drm/msm/adreno/a6xx_gmu.h b/drivers/gpu/drm/msm/adreno/a6xx_gmu.h > index d1ce11131ba6..309305298a45 100644 > --- a/drivers/gpu/drm/msm/adreno/a6xx_gmu.h > +++ b/drivers/gpu/drm/msm/adreno/a6xx_gmu.h > @@ -216,5 +216,6 @@ bool a6xx_gmu_gx_is_on(struct a6xx_gmu *gmu); > bool a6xx_gmu_sptprac_is_on(struct a6xx_gmu *gmu); > void a6xx_sptprac_disable(struct a6xx_gmu *gmu); > int a6xx_sptprac_enable(struct a6xx_gmu *gmu); > +int a6xx_rpmh_start(struct a6xx_gmu *gmu); > > #endif > diff --git a/drivers/gpu/drm/msm/adreno/a6xx_hfi.c b/drivers/gpu/drm/msm/adreno/a6xx_hfi.c > index 8e69b1e84657..9ea01daf2995 100644 > --- a/drivers/gpu/drm/msm/adreno/a6xx_hfi.c > +++ b/drivers/gpu/drm/msm/adreno/a6xx_hfi.c > @@ -910,7 +910,7 @@ int a6xx_hfi_start(struct a6xx_gmu *gmu, int boot_state) > if (ret) > return ret; > > - return 0; > + return a6xx_rpmh_start(gmu); > } > > void a6xx_hfi_stop(struct a6xx_gmu *gmu)