Received: by 2002:a25:ca44:0:0:0:0:0 with SMTP id a65csp1636854ybg; Wed, 29 Jul 2020 21:16:12 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwQU4lseIXTXC1i/FvpTTRhih+N0ajtN257pDIW9Jyx7qGQtchtbrMF0AFwwi+HgILWhF7N X-Received: by 2002:a05:6402:325:: with SMTP id q5mr900762edw.343.1596082572157; Wed, 29 Jul 2020 21:16:12 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1596082572; cv=none; d=google.com; s=arc-20160816; b=Gzbh9aLSXRQ8ys3G9fuNcltOLdreAXbg0plt/sNfMU91X8pR24youOJ5nwc595HPmT ZwpFjCr6CD4821qZXwF7Frhr08BZ2LADt4e8eYInLf/GqA+SP73jtrkRGKF1wwnEomHD jo6KRKFSDzZGvGWpMiU8PXtFVt7FxW9kT/wQVwqWmbBX74dr75L67Sp5Z832atEBq4CV UJ0JLPIJG84ZRn3Ip31xbYraBA6rDGPFX6VOv9oK9Pfwo/mHNONb/AZVCx2f3uCQm2FN Kjvf3O7puFHKXSu3nQuKh9Ro5FW04ZZSH424d7fceNeEKcjUI/lwdsdOXDh2W/TqnGlu xI/g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=oNLK7uM4PfoxFTg5k9G9c/AFUYqdGbH3MtTXOTQJaMA=; b=jEg/84990I82aBUwKudCQBBR376dtWgiokZyAa113/mNcW73Bt5WIHYmuxl8VU5UTd KHVUG/qPe6YCwI1qTbntPenCjxCVjv+KEHLqbZaZKgLE9eaTUk9NpjR1W2nk4pW/wET/ XTmgSyqxI1djv/gB8nCjrqLrBtP1kf8VZWfWZm8I5piTOWoI2fiI/22PN2le3RlkslvP sDGDPYg/qM5hyklURQnp/CiFtsnYanFeVmBB34yF8yITlZFEQneBOKymtofB4TG1x0fE 4cGj54xoZHZoUqlYnHZeuaHGzxHK2bmsU77p6GQlbRBn/ZMgHZTY9Mxa6yxcklMPhKkZ zgMg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=k9ofiJ5H; 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=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id oz19si2399865ejb.202.2020.07.29.21.15.49; Wed, 29 Jul 2020 21:16:12 -0700 (PDT) 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=@linaro.org header.s=google header.b=k9ofiJ5H; 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=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726519AbgG3ENj (ORCPT + 99 others); Thu, 30 Jul 2020 00:13:39 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45288 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725892AbgG3ENi (ORCPT ); Thu, 30 Jul 2020 00:13:38 -0400 Received: from mail-pf1-x444.google.com (mail-pf1-x444.google.com [IPv6:2607:f8b0:4864:20::444]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 98409C061794 for ; Wed, 29 Jul 2020 21:13:38 -0700 (PDT) Received: by mail-pf1-x444.google.com with SMTP id 74so6034073pfx.13 for ; Wed, 29 Jul 2020 21:13:38 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=oNLK7uM4PfoxFTg5k9G9c/AFUYqdGbH3MtTXOTQJaMA=; b=k9ofiJ5HPC2c49FkjkRDv2WrdWzMLcrlR6JVb5UEy1jRB1F2doEKibWHmYB96YHfO1 +xmyBCak32xRg5E30RrmUepIYmCfiHM8qzHx6Pf0gPPFWbfPtbbR+7U6gwEmoWX5jhzd JcZwE7oWCFIvx3B7sY1UBBgW72St1Hkj7dvReZCDIVqSAFj/A2ie8eCwDcx6oEx2u1Kk orizXhIJ2UOtsj0mTBVQVrr/JnWEfbZUazhyrSySiL5lYbK+ac15UnGKTPSOw95lT2Ua /Wqt1Xle+UOxdGBAK3e4v1iEyTpxlPUFpRQmgyCtN0IHPE+rRLrNLXpoPrQP6ONPZfr4 a2eg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=oNLK7uM4PfoxFTg5k9G9c/AFUYqdGbH3MtTXOTQJaMA=; b=PlR6Utg1pXaCpXbSh0kWZiStxP1wT/6HBqO9ll4OkK/oyhfkc96H7XjpdbnD+/Zd9b AnSyWymgxGKtoz58Pl8YP8Bmtc6J6f5Fhd5QBDa+LiIDw1G09ZkDst3jVTgZOcy7fkVj fFkIIL3iZdxjxeBJp57bbgXKeNGxNyZ5fhSn2zRsiHwOCkTtfB++ifVg7ztZYsviMwhw Tag7cdnGiNiO765rXc1SoZpt1QFFXhhdIwWilV6SxFcX9bvpAl7SavtgJDrrzaynR/mU ZLdwsCbaXFHX1doa2vHGxnr680xjMIj1ZG38/KVP765RBbrP4aQNzlHDIwhIvmUmEB0E kwEQ== X-Gm-Message-State: AOAM531JF6digCFyxp/Ebe+NfMOQ1OczMNLXBLjITFCnHe8CpaQWyFfh 1t8gSsrBdgT2CWgbQsBjDX8bVA== X-Received: by 2002:a65:4549:: with SMTP id x9mr31737542pgr.415.1596082418039; Wed, 29 Jul 2020 21:13:38 -0700 (PDT) Received: from localhost ([106.201.14.19]) by smtp.gmail.com with ESMTPSA id w9sm3769942pja.39.2020.07.29.21.13.36 (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Wed, 29 Jul 2020 21:13:37 -0700 (PDT) Date: Thu, 30 Jul 2020 09:43:34 +0530 From: Viresh Kumar To: Ionela Voinescu Cc: rjw@rjwysocki.net, dietmar.eggemann@arm.com, catalin.marinas@arm.com, sudeep.holla@arm.com, will@kernel.org, linux@armlinux.org.uk, mingo@redhat.com, peterz@infradead.org, linux-pm@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v2 2/7] cpufreq: set invariance scale factor on transition end Message-ID: <20200730041334.cjg5mc5xpopd2lst@vireshk-mac-ubuntu> References: <20200722093732.14297-1-ionela.voinescu@arm.com> <20200722093732.14297-3-ionela.voinescu@arm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200722093732.14297-3-ionela.voinescu@arm.com> User-Agent: NeoMutt/20170609 (1.8.3) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 22-07-20, 10:37, Ionela Voinescu wrote: > While the move of the invariance setter calls (arch_set_freq_scale()) > from cpufreq drivers to cpufreq core maintained the previous > functionality for existing drivers that use target_index() and > fast_switch() for frequency switching, it also gives the possibility > of adding support for users of the target() callback, which is exploited > here. > > To be noted that the target() callback has been flagged as deprecated > since: > > commit 9c0ebcf78fde ("cpufreq: Implement light weight ->target_index() routine") > > It also doesn't have that many users: > > cpufreq-nforce2.c:371:2: .target = nforce2_target, > cppc_cpufreq.c:416:2: .target = cppc_cpufreq_set_target, > gx-suspmod.c:439:2: .target = cpufreq_gx_target, > pcc-cpufreq.c:573:2: .target = pcc_cpufreq_target, > > Similarly to the path taken for target_index() calls in the cpufreq core > during a frequency change, all of the drivers above will mark the end of a > frequency change by a call to cpufreq_freq_transition_end(). > > Therefore, cpufreq_freq_transition_end() can be used as the location for > the arch_set_freq_scale() call to potentially inform the scheduler of the > frequency change. > > This change maintains the previous functionality for the drivers that > implement the target_index() callback, while also adding support for the > few drivers that implement the deprecated target() callback. > > Two notes are worthwhile here: > - In __target_index(), cpufreq_freq_transition_end() is called only for > drivers that have synchronous notifications enabled. There is only one > driver that disables them, > > drivers/cpufreq/powernow-k8.c:1142: .flags = CPUFREQ_ASYNC_NOTIFICATION, > > which is deprecated. I don't think this is deprecated. -- viresh