Received: by 2002:a25:31c3:0:0:0:0:0 with SMTP id x186csp548354ybx; Wed, 6 Nov 2019 04:53:43 -0800 (PST) X-Google-Smtp-Source: APXvYqyAWfBH1+ZJH4R7WF67vyxt4RycS3BlJEVGZ8h/vKaLnw020nXgM2aQv514rRNMxx+Kfqfp X-Received: by 2002:a50:b2c4:: with SMTP id p62mr2439446edd.128.1573044823642; Wed, 06 Nov 2019 04:53:43 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1573044823; cv=none; d=google.com; s=arc-20160816; b=fZ6leFyNkAq+wG+hindiJDvsmc8WDUl+cG08dWiZ+JjPsdMNxkeI5PPBzctKxiuje8 nvAdAODR3wlRP0OprkHFm1tGCKa1O3XtJJ8QCnhOp4TYIB3M7JxXKBaM+7Vanwz6aRe4 mD27HU7XnBFJgSQ90sNy/yryoAqm9oQQce7ni9wnOGLggjZ3Cmqtvu8ci6mdsTvO049Q CF+xJtltREJTcPbhuUf9D1QrCHkDGJUb75som4AiMIiX+cnpY5G72ykmuIUhyasFHhIK EvUds6P7x6lmleg4Get5kjRQaLvPDO8pjgcpL+WDOmVXLChWJ75w+hCrLZhHSSnmT3w8 gKOQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=Hlh8bg9NjgK6VLUA7BeEs16NW+0gcAupNOgLLQ0dBFg=; b=IOkqnX/f2TAmAtrvWK53KiCCUafZ7JD0Lt+vGdJxZk0Cdhn220lEDXAuI1S++to6tl vce1FdiFJ+DFMR+59xmW8TpNP8NsZmXIAyM0+NoFUmOyOjTaxUS+FrUsyFmCKtt1RKee I/ohHeeMAKAbrgyVbnSgizunmdde7vrmb7JdKR2T2m7+GOvJdK4FEnh7E/g1vTxXLYZ4 LJB8NuwvjOYo+UnFvgwC7iW+SurNIiD2olD5uzwxS+NOY8eWNCUICJHKpJpUCWolob58 P8xhLOjW9K/YavP/lnDG5bgvd9Cdmuq7W8lkfRq5ENasDAEx8UWJP5+sTxC0V4Cuqssd 1lAQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id qh15si6961768ejb.295.2019.11.06.04.53.20; Wed, 06 Nov 2019 04:53:43 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730794AbfKFMud (ORCPT + 99 others); Wed, 6 Nov 2019 07:50:33 -0500 Received: from foss.arm.com ([217.140.110.172]:39352 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727652AbfKFMud (ORCPT ); Wed, 6 Nov 2019 07:50:33 -0500 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 AF4917A7; Wed, 6 Nov 2019 04:50:32 -0800 (PST) Received: from [192.168.0.9] (unknown [172.31.20.19]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id E29923F6C4; Wed, 6 Nov 2019 04:50:30 -0800 (PST) Subject: Re: [Patch v5 5/6] thermal/cpu-cooling: Update thermal pressure in case of a maximum frequency capping To: Thara Gopinath , mingo@redhat.com, peterz@infradead.org, ionela.voinescu@arm.com, vincent.guittot@linaro.org, rui.zhang@intel.com, edubezval@gmail.com, qperret@google.com Cc: linux-kernel@vger.kernel.org, amit.kachhap@gmail.com, javi.merino@kernel.org, daniel.lezcano@linaro.org References: <1572979786-20361-1-git-send-email-thara.gopinath@linaro.org> <1572979786-20361-6-git-send-email-thara.gopinath@linaro.org> From: Dietmar Eggemann Message-ID: <05c53b6f-fd16-3e8b-e8da-ea56325cec33@arm.com> Date: Wed, 6 Nov 2019 13:50:29 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.9.0 MIME-Version: 1.0 In-Reply-To: <1572979786-20361-6-git-send-email-thara.gopinath@linaro.org> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 05/11/2019 19:49, Thara Gopinath wrote: [...] > diff --git a/drivers/thermal/cpu_cooling.c b/drivers/thermal/cpu_cooling.c > index 391f397..c65b7c4 100644 > --- a/drivers/thermal/cpu_cooling.c > +++ b/drivers/thermal/cpu_cooling.c > @@ -218,6 +218,27 @@ static u32 cpu_power_to_freq(struct cpufreq_cooling_device *cpufreq_cdev, > } > > /** > + * update_sched_max_capacity - update scheduler about change in cpu > + * max frequency. > + * @cpus: list of cpus whose max capacity needs udating in scheduler. > + * @cur_max_freq: current maximum frequency. > + * @max_freq: highest possible frequency. > + */ > +static void update_sched_max_capacity(struct cpumask *cpus, > + unsigned int cur_max_freq, > + unsigned int max_freq) > +{ > + int cpu; > + unsigned long capacity; > + > + for_each_cpu(cpu, cpus) { > + capacity = cur_max_freq * arch_scale_cpu_capacity(cpu); > + capacity /= max_freq; > + update_thermal_pressure(cpu, capacity); > + } > +} > + > +/** Have you seen https://lore.kernel.org/r/2b19d7da-412c-932f-7251-110eadbef3e3@arm.com ? Also the naming 'update_thermal_pressure()' is not really suitable for an external task scheduler interface. If I see this called in the cooling device code, I wouldn't guess that this is a task scheduler interface. [...]