Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp4504562rwd; Tue, 23 May 2023 08:32:18 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ7CqBCBQBmEvPQT8H9CxsG5hWDHVRxQDQDx6VJOVqYn7XBML4vCU43tO8ukLuiR2fMvmTBj X-Received: by 2002:a17:903:1249:b0:1ac:4d01:dfec with SMTP id u9-20020a170903124900b001ac4d01dfecmr16927262plh.54.1684855937798; Tue, 23 May 2023 08:32:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1684855937; cv=none; d=google.com; s=arc-20160816; b=WIrRJZdFhlVS4017ED0IAM2DdEvuHh28w3iFvo301h3Q4T8lSH9XduW8sffSv8ZX4r jP6dpzkX6cwyxm5VuffKuBu2tkkyAs9wFtGK3EwOVPqOcOjY3G+m5QyiowCLhCikvkW6 o6Yuz1pw0nVkrDKNOIiED4Oz8nqI8s6kxrKeoUTCsIE/Ff0/e0+ajKf4fWFFFOX16qMh YRU656FmwZvAtSLvJSREGi6qvuM+d4QWj6/wGtRptQ8OaFrVZi+o8NeaEWDTUNNd9n2Y 3b5d5Ep/bhSd2E1lo9CLeMc6nSIKrNvTfPIIBfB8jJ/NG5o2mRuAauozughEyltfOkkD 6S5g== 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:cc:to:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=CT97YM7VCSOduNBoS16nt0pEUZQAqqe9T5n0hJfuXdk=; b=dMRP/GYG72C5AKmAkCvAfdX4+7gYury2b3jYRl1o2yTuEXkAX1Z9XVncf7j8zRL9vT wT79fkEcCbrMk856oMRiU6KXI3ZkZeTiAQz6mt6SRscwJSRDsb77euGgIjaYzqTQWUHm DK47o5mYzjBLQCc/ggu9efLmDprwBUZfsSkLqSC78ZwbN3QE/vCO+3S+e0p97paZE4y6 4u8mvvRUrYaGSQ102qqR1RivvCnTc7gh25kFuLSiCCPyDAJMLW9j4BKU9RiZAnYZKwCw v3a+RZhMYDZitiajT2hmd0xbHPwAabPbUJpHyepicaRUksVMEhZhNRrhHbmk6hkkvrJx rFmg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@collabora.com header.s=mail header.b=A1iFbFyd; 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=collabora.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id o11-20020a170902d4cb00b001a94b91f428si3549416plg.319.2023.05.23.08.32.01; Tue, 23 May 2023 08:32:17 -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=@collabora.com header.s=mail header.b=A1iFbFyd; 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237022AbjEWO5D (ORCPT + 99 others); Tue, 23 May 2023 10:57:03 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47414 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230024AbjEWO5B (ORCPT ); Tue, 23 May 2023 10:57:01 -0400 Received: from madras.collabora.co.uk (madras.collabora.co.uk [IPv6:2a00:1098:0:82:1000:25:2eeb:e5ab]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id D1B18FA for ; Tue, 23 May 2023 07:56:59 -0700 (PDT) Received: from [IPV6:2001:b07:2ed:14ed:a962:cd4d:a84:1eab] (unknown [IPv6:2001:b07:2ed:14ed:a962:cd4d:a84:1eab]) (using TLSv1.3 with cipher TLS_AES_128_GCM_SHA256 (128/128 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) (Authenticated sender: kholk11) by madras.collabora.co.uk (Postfix) with ESMTPSA id 6630F6601EB5; Tue, 23 May 2023 15:56:50 +0100 (BST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=collabora.com; s=mail; t=1684853811; bh=SJZt9atAoQRj3rcAzTtRqoL9FHE3CxbtatuFUkIZ7/A=; h=Date:Subject:To:Cc:References:From:In-Reply-To:From; b=A1iFbFydVp3BqMWN95Xd90xFzcZubgebSvcSsSVMayqpt/U15l42yyOzA9edNLnOd 8F1xjWVOzbbJAbIqkHPwO54nb1qh44lgbs+e0wGGVXYGxVeYJpprP+Ub4fhOspKV9r NGzJksq5HLKiF2OF1oZYmxIYnrBwJ7xE1/UIVNN7zPIToepFjTRFGi1Tq+DllnF/lJ 7f0tptQujdNHi+8ZqceJgdUi25YN8R+rsQ97X54L4TjG5KLtDuLKpcQlFeCaNFXZAG uKCjNfGO0gfFESyFTgnhuKQrlch1e7cU/r1s3mo6KfkE9I/Y531ni+UGp0iWtKI/2D XeTaPWT7f3eiw== Message-ID: Date: Tue, 23 May 2023 16:56:47 +0200 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.10.1 Subject: Re: [PATCH v2 4/4] cpufreq: mediatek: Raise proc and sram max voltage for MT7622/7623 To: Daniel Golle , "jia-wei.chang" Cc: "Rafael J . Wysocki" , Viresh Kumar , Matthias Brugger , Kevin Hilman , Rex-BC Chen , linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, linux-kernel@vger.kernel.org, Project_Global_Chrome_Upstream_Group@mediatek.com, hsinyi@google.com, Nick Hainke , Dan Carpenter References: <20230324101130.14053-1-jia-wei.chang@mediatek.com> <20230324101130.14053-5-jia-wei.chang@mediatek.com> Content-Language: en-US From: AngeloGioacchino Del Regno In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-2.2 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,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 Il 22/05/23 20:03, Daniel Golle ha scritto: > Hi Jia-Wei, > Hi AngeloGioacchino, > > On Fri, Mar 24, 2023 at 06:11:30PM +0800, jia-wei.chang wrote: >> From: AngeloGioacchino Del Regno >> >> During the addition of SRAM voltage tracking for CCI scaling, this >> driver got some voltage limits set for the vtrack algorithm: these >> were moved to platform data first, then enforced in a later commit >> 6a17b3876bc8 ("cpufreq: mediatek: Refine mtk_cpufreq_voltage_tracking()") >> using these as max values for the regulator_set_voltage() calls. >> >> In this case, the vsram/vproc constraints for MT7622 and MT7623 >> were supposed to be the same as MT2701 (and a number of other SoCs), >> but that turned out to be a mistake because the aforementioned two >> SoCs' maximum voltage for both VPROC and VPROC_SRAM is 1.36V. >> >> Fix that by adding new platform data for MT7622/7623 declaring the >> right {proc,sram}_max_volt parameter. >> >> Fixes: ead858bd128d ("cpufreq: mediatek: Move voltage limits to platform data") >> Fixes: 6a17b3876bc8 ("cpufreq: mediatek: Refine mtk_cpufreq_voltage_tracking()") >> Signed-off-by: AngeloGioacchino Del Regno >> Signed-off-by: Jia-Wei Chang >> --- >> drivers/cpufreq/mediatek-cpufreq.c | 13 +++++++++++-- >> 1 file changed, 11 insertions(+), 2 deletions(-) >> >> diff --git a/drivers/cpufreq/mediatek-cpufreq.c b/drivers/cpufreq/mediatek-cpufreq.c >> index 764e4fbdd536..9a39a7ccfae9 100644 >> --- a/drivers/cpufreq/mediatek-cpufreq.c >> +++ b/drivers/cpufreq/mediatek-cpufreq.c >> @@ -693,6 +693,15 @@ static const struct mtk_cpufreq_platform_data mt2701_platform_data = { >> .ccifreq_supported = false, >> }; >> >> +static const struct mtk_cpufreq_platform_data mt7622_platform_data = { >> + .min_volt_shift = 100000, >> + .max_volt_shift = 200000, >> + .proc_max_volt = 1360000, >> + .sram_min_volt = 0, >> + .sram_max_volt = 1360000, > > This change breaks cpufreq (with ondemand scheduler) on my BPi R64 > board (having MT7622AV SoC with MT6380N PMIC). > ... > [ 2.540091] cpufreq: __target_index: Failed to change cpu frequency: -22 > [ 2.556985] cpu cpu0: cpu0: failed to scale up voltage! > ... > (repeating a lot, every time the highest operating point is selected > by the cpufreq governor) > > The reason is that the MT6380N doesn't support 1360000uV on the supply > outputs used for SRAM and processor. > > As for some reason cpufreq-mediatek tries to rise the SRAM supply > voltage to the maximum for a short moment (probably a side-effect of > the voltage tracking algorithm), this fails because the PMIC only > supports up to 1350000uV. As the highest operating point is anyway > using only 1310000uV the simple fix is setting 1350000uV as the maximum > instead for both proc_max_volt and sram_max_volt. > > A similar situation applies also for BPi R2 (MT7623NI with MT6323L > PMIC), here the maximum supported voltage of the PMIC which also only > supports up to 1350000uV, and the SoC having its highest operating > voltage defined at 1300000uV. > > If all agree with the simple fix I will post a patch for that. > > However, to me it feels fishy to begin with that the tracking algorithm > tries to rise the voltage above the highest operating point defined in > device tree, see here: > > 6a17b3876bc830 drivers/cpufreq/mediatek-cpufreq.c (Jia-Wei Chang 2022-05-05 19:52:20 +0800 100) new_vsram = clamp(new_vproc + soc_data->min_volt_shift, > 6a17b3876bc830 drivers/cpufreq/mediatek-cpufreq.c (Jia-Wei Chang 2022-05-05 19:52:20 +0800 101) soc_data->sram_min_volt, soc_data->sram_max_volt); > > However, I did not investigate in depth the purpose of this > initial rise and can impossibly test my modifications to the > tracking algorithm on all supported SoCs. > Thanks for actually reporting that, I don't think that there's any valid reason why the algorithm should set a voltage higher than the maximum votage specified in the fastest OPP. Anyway - the logic for the platform data of this driver is to declare the maximum voltage that SoC model X supports, regardless of the actual board-specific OPPs, so that part is right; to solve this issue, I guess that the only way is for this driver to parse the OPPs during .probe() and then always use in the algorithm vproc_max = max(proc_max_volt, opp_vproc_max); vsram_max = max(sram_max_volt, vsram_vreg_max); Jia-Wei, can you please handle this? Thanks, Angelo