Received: by 2002:a05:6a10:9afc:0:0:0:0 with SMTP id t28csp411482pxm; Wed, 2 Mar 2022 00:39:30 -0800 (PST) X-Google-Smtp-Source: ABdhPJxdg5bF/4BHp9HpC6oA/qq8C+ArUc2OyOSt5OXQHPPYmomqI2/GomSzAbcLTQOZGvyXl3NV X-Received: by 2002:a50:e693:0:b0:413:7889:8050 with SMTP id z19-20020a50e693000000b0041378898050mr23277215edm.294.1646210369773; Wed, 02 Mar 2022 00:39:29 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1646210369; cv=none; d=google.com; s=arc-20160816; b=Hxl9doP2nFkrcnwnOQTIPJU3jyQ2PPPCJxT1e/CAiW3ykuJl8PVy8+JMhjbfsiDcUO z9pRRaM0n8x3nLMS8gOTr76HpEqfsVOi1gpvpxJO4SL1Ctg6OeDRvDCmVlo1JjVZNRsL AOzExcD3LI+FdpFt0S5fWDQmLK4xp/LYPhg4OAJdDKNRMMZ1miSZYWKX2Mj6ZzRJBhyy QPDJj4DFOgskqpnSnN1py43n6g2fScwa/mwfOGUNIZ7HDdhrywDTO6KAqsJ1Xwe7Q6ZY HhhdG8Bhgw3yz8iqIPx1cF4WFcoothlMecNNsenFSjYIfAsT4M4WWzR4XXd2ecMSlH11 LeAg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from; bh=aQn9v156z28MoJWRWU0P2GaXG3tF792hUlxDcYum1Jw=; b=BAnDVVpoLBJFOeTZ6l3MNH0yBC3SsWKhl11FeY9HcEP8UGJCrO9z65o/ygjtyxg1s8 KE3c76jL4qmtsj9UlljmqePSu8vhXt9KqJSkaU9j4DnIqYQr9ty5qxYK8FgS5f9rd8dM /hufrBWB26xkA1ekpFKYoBTibJpNI4DMywvMsH2bLc5LykAoABmF9X5PShHr7OiHcRnJ lwIDH/YkkrGSlG2bm5zq0sYt5YTE4FpZwiwiKcYlRxJxOyOI4vr1JRZ/MLJ5DFRrXK7u hC64o7hajCJE3c6SDnBBNp2Mj4M/x4tKM7znsEdEX1uooO1QswL9g9Qnvx6JVzGJfBm7 5Emg== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id nc26-20020a1709071c1a00b006d6e4356a5bsi3343787ejc.583.2022.03.02.00.39.07; Wed, 02 Mar 2022 00:39:29 -0800 (PST) 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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233916AbiCAJhB (ORCPT + 99 others); Tue, 1 Mar 2022 04:37:01 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34746 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233843AbiCAJgy (ORCPT ); Tue, 1 Mar 2022 04:36:54 -0500 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 0942A8AE7A; Tue, 1 Mar 2022 01:36:14 -0800 (PST) Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id C8BF1106F; Tue, 1 Mar 2022 01:36:13 -0800 (PST) Received: from e123648.arm.com (unknown [10.57.20.71]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id 825F03F73D; Tue, 1 Mar 2022 01:36:11 -0800 (PST) From: Lukasz Luba To: linux-kernel@vger.kernel.org Cc: lukasz.luba@arm.com, dietmar.eggemann@arm.com, viresh.kumar@linaro.org, rafael@kernel.org, daniel.lezcano@linaro.org, nm@ti.com, sboyd@kernel.org, mka@chromium.org, dianders@chromium.org, robh+dt@kernel.org, devicetree@vger.kernel.org, linux-pm@vger.kernel.org Subject: [PATCH v4 3/4] OPP: Add support of "opp-microwatt" for advanced EM registration Date: Tue, 1 Mar 2022 09:35:23 +0000 Message-Id: <20220301093524.8870-4-lukasz.luba@arm.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20220301093524.8870-1-lukasz.luba@arm.com> References: <20220301093524.8870-1-lukasz.luba@arm.com> X-Spam-Status: No, score=-6.9 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE 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 The Energy Model (EM) can be created based on DT entry: 'dynamic-power-coefficient'. It's a 'simple' EM which is limited to the dynamic power. It has to fit into the math formula which requires also information about voltage. Some of the platforms don't expose voltage information, thus it's not possible to use EM registration using DT. This patch aims to fix it. It introduces new implementation of the EM registration callback. The new mechanism relies on the new OPP feature allowing to get power (which is coming from "opp-microwatt" DT property) expressed in micro-Watts. The patch also opens new opportunity to better support platforms, which have a decent static power. It allows to register 'advanced' EM (based on real power measurements) which models total power (static + dynamic), so better reflects real HW. Signed-off-by: Lukasz Luba --- drivers/opp/of.c | 57 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 57 insertions(+) diff --git a/drivers/opp/of.c b/drivers/opp/of.c index 7bff30f27dc1..9bae26577aca 100644 --- a/drivers/opp/of.c +++ b/drivers/opp/of.c @@ -1438,6 +1438,38 @@ struct device_node *dev_pm_opp_get_of_node(struct dev_pm_opp *opp) } EXPORT_SYMBOL_GPL(dev_pm_opp_get_of_node); +/* + * Callback function provided to the Energy Model framework upon registration. + * It provides the power used by @dev at @kHz if it is the frequency of an + * existing OPP, or at the frequency of the first OPP above @kHz otherwise + * (see dev_pm_opp_find_freq_ceil()). This function updates @kHz to the ceiled + * frequency and @mW to the associated power. + * + * Returns 0 on success or a proper -EINVAL value in case of error. + */ +static int __maybe_unused +_get_dt_power(unsigned long *mW, unsigned long *kHz, struct device *dev) +{ + struct dev_pm_opp *opp; + unsigned long opp_freq, opp_power; + + /* Find the right frequency and related OPP */ + opp_freq = *kHz * 1000; + opp = dev_pm_opp_find_freq_ceil(dev, &opp_freq); + if (IS_ERR(opp)) + return -EINVAL; + + opp_power = dev_pm_opp_get_power(opp); + dev_pm_opp_put(opp); + if (!opp_power) + return -EINVAL; + + *kHz = opp_freq / 1000; + *mW = opp_power / 1000; + + return 0; +} + /* * Callback function provided to the Energy Model framework upon registration. * This computes the power estimated by @dev at @kHz if it is the frequency @@ -1488,6 +1520,24 @@ static int __maybe_unused _get_power(unsigned long *mW, unsigned long *kHz, return 0; } +static bool _of_has_opp_microwatt_property(struct device *dev) +{ + unsigned long power, freq = 0; + struct dev_pm_opp *opp; + + /* Check if at least one OPP has needed property */ + opp = dev_pm_opp_find_freq_ceil(dev, &freq); + if (IS_ERR(opp)) + return false; + + power = dev_pm_opp_get_power(opp); + dev_pm_opp_put(opp); + if (!power) + return false; + + return true; +} + /** * dev_pm_opp_of_register_em() - Attempt to register an Energy Model * @dev : Device for which an Energy Model has to be registered @@ -1517,6 +1567,12 @@ int dev_pm_opp_of_register_em(struct device *dev, struct cpumask *cpus) goto failed; } + /* First, try to find more precised Energy Model in DT */ + if (_of_has_opp_microwatt_property(dev)) { + em_cb.active_power = _get_dt_power; + goto register_em; + } + np = of_node_get(dev->of_node); if (!np) { ret = -EINVAL; @@ -1538,6 +1594,7 @@ int dev_pm_opp_of_register_em(struct device *dev, struct cpumask *cpus) goto failed; } +register_em: ret = em_dev_register_perf_domain(dev, nr_opp, &em_cb, cpus, true); if (ret) goto failed; -- 2.17.1