Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp491190pxb; Thu, 12 Nov 2020 08:39:50 -0800 (PST) X-Google-Smtp-Source: ABdhPJyMsBYe/4OijPE+UAQJ9q0+dIFol/HyhxjTBf7G5D6JovoDAC7lToOlpWZELodh5ZaNVcAR X-Received: by 2002:a17:906:4d52:: with SMTP id b18mr63829ejv.553.1605199189681; Thu, 12 Nov 2020 08:39:49 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1605199189; cv=none; d=google.com; s=arc-20160816; b=Sy7Kbb3XrUe0TvJSf3XgMkACn6Kdcv/ENJqwPDxBw+wVzmtgzUdrbaXpk7Wn7/NNYH 2mJ5ccvGNZa7gXr8YbiVBMyqtX0Lq06EalJzExbpst6IjW0b+aAvv3H8FVectnDC6ysq AzTRnD2/34kayWU7JNBMsH2Mfqnal2/vP4ToEKeWRADzvlAN0fJQgqCARywetK5JlugF Umx9ZrERhqY0HqDCYZG69kG+bbuU41mz4KXr72AMyUEuaJxnImTfGXF8DCYcysDyU42r EkuTavgpCxZqvA6P4qqTOfdyLFm1+uumzDE8lOD0yBir/kgt3FLviqMe8pqo04I1HdHE L81A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=856+wuZ3br1mkt8SsqhtyD2C7s8L5Yj2DM9tF9JbCR4=; b=KDqH8J0pg/C6mUvZ5ggzcn+6qkQqCIRgme2qrTHEbIbqVEZ/YhqckAq1j23u4OL693 nvU7M2d6oUBXVFPoJiVYsuY6KqWNZf5TmibpBjK/cKGmPPtNyJrHqnEefsR2pCpgcVTo yuJik8os7X5crYqKX3fnvX6UYNal/zMJGPtZAF2N6FcASehaXXe5vPw8rkj1NHqTxZTj Ch+ohrc/jL4jzrgyLsgxHCnG3tSgtbeXkxE2Yp75948PseARNLRuLSwliQmEyBlqBbsa zroFYrkiyqxoE+JHvvZ6/8H1VKXnskpZ2WcBztzPcBzRjI/kGT6gHKVOjl99aePOISDI 8RlQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=rToA2rji; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id b10si4020370ejv.433.2020.11.12.08.39.26; Thu, 12 Nov 2020 08:39:49 -0800 (PST) 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=@gmail.com header.s=20161025 header.b=rToA2rji; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729010AbgKLQhf (ORCPT + 99 others); Thu, 12 Nov 2020 11:37:35 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50724 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728977AbgKLQhd (ORCPT ); Thu, 12 Nov 2020 11:37:33 -0500 Received: from mail-wr1-x443.google.com (mail-wr1-x443.google.com [IPv6:2a00:1450:4864:20::443]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4B210C0613D1; Thu, 12 Nov 2020 08:37:31 -0800 (PST) Received: by mail-wr1-x443.google.com with SMTP id b8so6705751wrn.0; Thu, 12 Nov 2020 08:37:31 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=856+wuZ3br1mkt8SsqhtyD2C7s8L5Yj2DM9tF9JbCR4=; b=rToA2rjiTiGnpXYZPJTiG0pGT4UNEkaz+nlmrTtxoK9NcJDbO6ljBtxIypteTx+Hoc 4OLesTMbkHApWMtspZ+gWsMa934eQpiZ+V/mIuTXy8238dOpXI51bRigR7gS1SVyRpEp yxdAvFcQTXqOeubDrm0CH2Yz1rj6jw4m7K8iiu/5KQH17Z2jD5WmHmgOLejNCN8b5uaV AQ8FDh+U+JfuMdPVb5TxOyd08yxDwxuzoY4Q4CReYhfJJceZ8sMBfqmTHvjgF0bAbzBD 0zLsEWvXCGlEnbGZHFMGhHbs1YPgz8ZzYD2yzeG3GMZT/dL7/WLOW9gCeGhfZVCbrpNC NIJQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=856+wuZ3br1mkt8SsqhtyD2C7s8L5Yj2DM9tF9JbCR4=; b=iUPBQ7aLXWygnXQOizZDO4pj9OU4Gh4BWCZNVTce6ep/wb/1uAZs3oA8FbiHWe3khy JdIldwuV2F8JfxBLsBCrthsK3e92bho7GKrjoRlshWQpFvkzHgmeBdcK12K6lqHLDFmI a03jY8F/h6CowJCtnD78puxeMKQmuCLYhXOsO0wAlkFWFVpQcNqNVDW5LVUxcKtmv/eX Xe7RWJgAPgEqjPfYLCO5ayRDAIA0dH0ETJltCUa0gMJaKtS2yaxZqeim8okogZYMzgCJ 17DWmYiiUb90teyXfD72Fgza/Er/hE+SbOXECTo+eWNg8kEcAhGM6lHlbD+yHs+Gs6tj jLQA== X-Gm-Message-State: AOAM532I++7mg9kr28FmLPQfTl8uQ5PymYe5TXznyY+2Q1NquWMqqbUv c5iDa8e64tRL0TjH/GZA67G93v+dEZ6SDbHD1tU= X-Received: by 2002:adf:a54d:: with SMTP id j13mr475613wrb.132.1605199049893; Thu, 12 Nov 2020 08:37:29 -0800 (PST) MIME-Version: 1.0 References: <1605196144-23516-1-git-send-email-akhilpo@codeaurora.org> In-Reply-To: <1605196144-23516-1-git-send-email-akhilpo@codeaurora.org> From: Rob Clark Date: Thu, 12 Nov 2020 08:37:18 -0800 Message-ID: Subject: Re: [PATCH] drm/msm: adreno: Make speed-bin support generic To: Akhil P Oommen Cc: freedreno , dri-devel@freedesktop.org, linux-arm-msm , Linux Kernel Mailing List , Jordan Crouse , Matthias Kaehlcke , Douglas Anderson Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Nov 12, 2020 at 7:49 AM Akhil P Oommen wrote: > > So far a530v2 gpu has support for detecting its supported opps > based on a fuse value called speed-bin. This patch makes this > support generic across gpu families. This is in preparation to > extend speed-bin support to a6x family. > > Signed-off-by: Akhil P Oommen > --- > This patch is rebased on top of msm-next-staging branch in rob's tree. > > drivers/gpu/drm/msm/adreno/a5xx_gpu.c | 34 -------------- > drivers/gpu/drm/msm/adreno/adreno_device.c | 4 ++ > drivers/gpu/drm/msm/adreno/adreno_gpu.c | 71 ++++++++++++++++++++++++++++++ > drivers/gpu/drm/msm/adreno/adreno_gpu.h | 5 +++ > 4 files changed, 80 insertions(+), 34 deletions(-) > > diff --git a/drivers/gpu/drm/msm/adreno/a5xx_gpu.c b/drivers/gpu/drm/msm/adreno/a5xx_gpu.c > index 8fa5c91..7d42321 100644 > --- a/drivers/gpu/drm/msm/adreno/a5xx_gpu.c > +++ b/drivers/gpu/drm/msm/adreno/a5xx_gpu.c > @@ -1531,38 +1531,6 @@ static const struct adreno_gpu_funcs funcs = { > .get_timestamp = a5xx_get_timestamp, > }; > > -static void check_speed_bin(struct device *dev) > -{ > - struct nvmem_cell *cell; > - u32 val; > - > - /* > - * If the OPP table specifies a opp-supported-hw property then we have > - * to set something with dev_pm_opp_set_supported_hw() or the table > - * doesn't get populated so pick an arbitrary value that should > - * ensure the default frequencies are selected but not conflict with any > - * actual bins > - */ > - val = 0x80; > - > - cell = nvmem_cell_get(dev, "speed_bin"); > - > - if (!IS_ERR(cell)) { > - void *buf = nvmem_cell_read(cell, NULL); > - > - if (!IS_ERR(buf)) { > - u8 bin = *((u8 *) buf); > - > - val = (1 << bin); > - kfree(buf); > - } > - > - nvmem_cell_put(cell); > - } > - > - dev_pm_opp_set_supported_hw(dev, &val, 1); > -} > - > struct msm_gpu *a5xx_gpu_init(struct drm_device *dev) > { > struct msm_drm_private *priv = dev->dev_private; > @@ -1588,8 +1556,6 @@ struct msm_gpu *a5xx_gpu_init(struct drm_device *dev) > > a5xx_gpu->lm_leakage = 0x4E001A; > > - check_speed_bin(&pdev->dev); > - > ret = adreno_gpu_init(dev, pdev, adreno_gpu, &funcs, 4); > if (ret) { > a5xx_destroy(&(a5xx_gpu->base.base)); > diff --git a/drivers/gpu/drm/msm/adreno/adreno_device.c b/drivers/gpu/drm/msm/adreno/adreno_device.c > index 87c8b03..e0ff16c 100644 > --- a/drivers/gpu/drm/msm/adreno/adreno_device.c > +++ b/drivers/gpu/drm/msm/adreno/adreno_device.c > @@ -18,6 +18,8 @@ bool snapshot_debugbus = false; > MODULE_PARM_DESC(snapshot_debugbus, "Include debugbus sections in GPU devcoredump (if not fused off)"); > module_param_named(snapshot_debugbus, snapshot_debugbus, bool, 0600); > > +const u32 a530v2_speedbins[] = {0, 1, 2, 3, 4, 5, 6, 7}; > + > static const struct adreno_info gpulist[] = { > { > .rev = ADRENO_REV(2, 0, 0, 0), > @@ -163,6 +165,8 @@ static const struct adreno_info gpulist[] = { > ADRENO_QUIRK_FAULT_DETECT_MASK, > .init = a5xx_gpu_init, > .zapfw = "a530_zap.mdt", > + .speedbins = a530v2_speedbins, > + .speedbins_count = ARRAY_SIZE(a530v2_speedbins), > }, { > .rev = ADRENO_REV(5, 4, 0, 2), > .revn = 540, > diff --git a/drivers/gpu/drm/msm/adreno/adreno_gpu.c b/drivers/gpu/drm/msm/adreno/adreno_gpu.c > index f21561d..cdd0c11 100644 > --- a/drivers/gpu/drm/msm/adreno/adreno_gpu.c > +++ b/drivers/gpu/drm/msm/adreno/adreno_gpu.c > @@ -14,6 +14,7 @@ > #include > #include > #include > +#include > #include > #include "adreno_gpu.h" > #include "msm_gem.h" > @@ -891,6 +892,69 @@ void adreno_gpu_ocmem_cleanup(struct adreno_ocmem *adreno_ocmem) > adreno_ocmem->hdl); > } > > +static int adreno_set_supported_hw(struct device *dev, > + struct adreno_gpu *adreno_gpu) > +{ > + u8 speedbins_count = adreno_gpu->info->speedbins_count; > + const u32 *speedbins = adreno_gpu->info->speedbins; > + struct nvmem_cell *cell; > + u32 bin, i; > + u32 val = 0; > + void *buf, *opp_table; > + > + cell = nvmem_cell_get(dev, "speed_bin"); > + /* > + * -ENOENT means that the platform doesn't support speedbin which is > + * fine > + */ > + if (PTR_ERR(cell) == -ENOENT) > + return 0; > + else if (IS_ERR(cell)) > + return PTR_ERR(cell); > + > + /* A speedbin table is must if the platform supports speedbin */ > + if (!speedbins) { > + DRM_DEV_ERROR(dev, "speed-bin table is missing\n"); > + return -ENOENT; Hmm, this means that hw which supports speed-bin, but for which we haven't yet added a speedbin table, will start failing. Which seems not great. Maybe it would be better to keep the DRM_DEV_ERROR() (so people realize something is missing), but return 0? Or do you think we could add the speed-bin tables for all supported hw immediately? BR, -R > + } > + > + buf = nvmem_cell_read(cell, NULL); > + if (IS_ERR(buf)) { > + nvmem_cell_put(cell); > + return PTR_ERR(buf); > + } > + > + bin = *((u32 *) buf); > + > + for (i = 0; i < speedbins_count; i++) { > + if (bin == speedbins[i]) { > + val = (1 << i); > + break; > + } > + } > + > + kfree(buf); > + nvmem_cell_put(cell); > + > + if (!val) { > + DRM_DEV_ERROR(dev, "missing support for speed-bin: %u\n", bin); > + return -ENOENT; > + } > + > + opp_table = dev_pm_opp_set_supported_hw(dev, &val, 1); > + if (IS_ERR(opp_table)) > + return PTR_ERR(opp_table); > + > + adreno_gpu->opp_table = opp_table; > + return 0; > +} > + > +static void adreno_put_supported_hw(struct opp_table *opp_table) > +{ > + if (opp_table) > + dev_pm_opp_put_supported_hw(opp_table); > +} > + > int adreno_gpu_init(struct drm_device *drm, struct platform_device *pdev, > struct adreno_gpu *adreno_gpu, > const struct adreno_gpu_funcs *funcs, int nr_rings) > @@ -899,6 +963,7 @@ int adreno_gpu_init(struct drm_device *drm, struct platform_device *pdev, > struct adreno_platform_config *config = dev->platform_data; > struct msm_gpu_config adreno_gpu_config = { 0 }; > struct msm_gpu *gpu = &adreno_gpu->base; > + int ret; > > adreno_gpu->funcs = funcs; > adreno_gpu->info = adreno_info(config->rev); > @@ -910,6 +975,10 @@ int adreno_gpu_init(struct drm_device *drm, struct platform_device *pdev, > > adreno_gpu_config.nr_rings = nr_rings; > > + ret = adreno_set_supported_hw(dev, adreno_gpu); > + if (ret) > + return ret; > + > adreno_get_pwrlevels(dev, gpu); > > pm_runtime_set_autosuspend_delay(dev, > @@ -936,4 +1005,6 @@ void adreno_gpu_cleanup(struct adreno_gpu *adreno_gpu) > > icc_put(gpu->icc_path); > icc_put(gpu->ocmem_icc_path); > + > + adreno_put_supported_hw(adreno_gpu->opp_table); > } > diff --git a/drivers/gpu/drm/msm/adreno/adreno_gpu.h b/drivers/gpu/drm/msm/adreno/adreno_gpu.h > index c3775f7..a756ad7 100644 > --- a/drivers/gpu/drm/msm/adreno/adreno_gpu.h > +++ b/drivers/gpu/drm/msm/adreno/adreno_gpu.h > @@ -55,6 +55,7 @@ struct adreno_reglist { > }; > > extern const struct adreno_reglist a630_hwcg[], a640_hwcg[], a650_hwcg[]; > +extern const u32 a618_speedbins[]; > > struct adreno_info { > struct adreno_rev rev; > @@ -67,6 +68,8 @@ struct adreno_info { > const char *zapfw; > u32 inactive_period; > const struct adreno_reglist *hwcg; > + const u32 *speedbins; > + const u8 speedbins_count; > }; > > const struct adreno_info *adreno_info(struct adreno_rev rev); > @@ -112,6 +115,8 @@ struct adreno_gpu { > * code (a3xx_gpu.c) and stored in this common location. > */ > const unsigned int *reg_offsets; > + > + struct opp_table *opp_table; > }; > #define to_adreno_gpu(x) container_of(x, struct adreno_gpu, base) > > -- > 2.7.4 >