Received: by 2002:a05:6a10:87d6:0:0:0:0 with SMTP id g22csp924309pxr; Mon, 11 Apr 2022 10:25:32 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzjx0FmUy9l9UUNzp33+MVotQyxymT6zSw0UtGewiZ9eNoubsLp0QdNJY8gjaBdF1LxoPjs X-Received: by 2002:a63:3718:0:b0:398:1086:e8ec with SMTP id e24-20020a633718000000b003981086e8ecmr27894545pga.498.1649697931966; Mon, 11 Apr 2022 10:25:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1649697931; cv=none; d=google.com; s=arc-20160816; b=Ybx+wodHbKY2snln4ZOMow3PCbfZbLUt0kF+uyDjO4r2DTCempa7VEA9HvtzAdFGUu qkKFyI26K+vZ3bN6hjoaVIbu7gCqw+lADuY8Kzg5VieH3diiE8f6Gh9vgSrOi1jGL9uF csdlWOVNIv0wlHoUY27N9Z8xFcQRXjDY5u0SI4EN5tEG74iLAHgmwiI8Tp/NTvUhlnfM FN8UwDcxi8ZkL6cW1cOPVHQZWRSw69kUMsoChAE7LX7in3JGD4+OefegVNu/K/Va25AG 91TY/qcVkBM4aGWisumjk032qF031aGdGRM1Qo2r0dcnMrkp6QZdYXd7tY5YOYx2ASxM UN6g== 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 :content-language:references:cc:to:subject:from:user-agent :mime-version:date:message-id; bh=P9cEDgukL7ZIk+zS5Xb+sZAWxcGQqhSjI0kcSHpsk3A=; b=ilLOWeRPpA21Gh5X35xqj5VG5uVnMw+T1CPCdnjyFeF0mscJZp/j9lpp/7GKazjp8Z Vpcc9vDJuGLfeL+u/rErZgM6vk8XayyXYemznvAHcBQRXWhRaAPgKB8uAKbttPvhvWu2 E56FJyB7wuk1PSOzdkeLKEhaIX5GI/Sw6LBuSlS4k5VKgAiJateOLHM59fjhnn/oVCZQ TMEGFY99dUgdMnv0AbJ4HzVsj06evKPvpyQIXPOSdSiYaJz3cjRPJip3g4A6ZleOsSdw oGH0BUbc077ssog5DxbPXpi1x4SuAHmw//dnUBZ/tNQ+BRVJsAzbtgMyhDMQnVB+RqHr 1QLg== 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 y1-20020a056a00190100b004fa3a8e002esi9647865pfi.229.2022.04.11.10.24.52; Mon, 11 Apr 2022 10:25:31 -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; 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 S1343697AbiDKIXz (ORCPT + 99 others); Mon, 11 Apr 2022 04:23:55 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33782 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236432AbiDKIXx (ORCPT ); Mon, 11 Apr 2022 04:23:53 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 462033E0DD for ; Mon, 11 Apr 2022 01:21:40 -0700 (PDT) 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 EDDEAED1; Mon, 11 Apr 2022 01:21:39 -0700 (PDT) Received: from [192.168.178.6] (unknown [172.31.20.19]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 586A33F73B; Mon, 11 Apr 2022 01:21:38 -0700 (PDT) Message-ID: <02350916-aa36-ea53-2c98-91b97f49d27e@arm.com> Date: Mon, 11 Apr 2022 10:21:22 +0200 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.5.0 From: Dietmar Eggemann Subject: Re: [PATCH] sched: Take thermal pressure into account when determine rt fits capacity To: Xuewen Yan , lukasz.luba@arm.com Cc: rafael@kernel.org, viresh.kumar@linaro.org, mingo@redhat.com, peterz@infradead.org, vincent.guittot@linaro.org, rostedt@goodmis.org, linux-kernel@vger.kernel.org, di.shen@unisoc.com, xuewen.yan94@gmail.com References: <20220407051932.4071-1-xuewen.yan@unisoc.com> Content-Language: en-US In-Reply-To: <20220407051932.4071-1-xuewen.yan@unisoc.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-10.0 required=5.0 tests=BAYES_00,NICE_REPLY_A, 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 On 07/04/2022 07:19, Xuewen Yan wrote: > There are cases when the cpu max capacity might be reduced due to thermal. > Take into the thermal pressure into account when judge whether the rt task > fits the cpu. And when schedutil govnor get cpu util, the thermal pressure > also should be considered. > > Signed-off-by: Xuewen Yan > --- > kernel/sched/cpufreq_schedutil.c | 1 + > kernel/sched/rt.c | 1 + > 2 files changed, 2 insertions(+) > > diff --git a/kernel/sched/cpufreq_schedutil.c b/kernel/sched/cpufreq_schedutil.c > index 3dbf351d12d5..285ad51caf0f 100644 > --- a/kernel/sched/cpufreq_schedutil.c > +++ b/kernel/sched/cpufreq_schedutil.c > @@ -159,6 +159,7 @@ static void sugov_get_util(struct sugov_cpu *sg_cpu) > struct rq *rq = cpu_rq(sg_cpu->cpu); > unsigned long max = arch_scale_cpu_capacity(sg_cpu->cpu); > > + max -= arch_scale_thermal_pressure(sg_cpu->cpu); max' = arch_scale_cpu_capacity() - arch_scale_thermal_pressure() For the energy part (A) we use max' in compute_energy() to cap sum_util and max_util at max' and to call em_cpu_energy(..., max_util, sum_util, max'). This was done to match (B)'s `policy->max` capping. For the frequency part (B) we have freq_qos_update_request() in: power_actor_set_power() ... cdev->ops->set_cur_state() cpufreq_set_cur_state() freq_qos_update_request() <-- ! arch_update_thermal_pressure() restricting `policy->max` which then clamps `target_freq` in: cpufreq_update_util() ... get_next_freq() cpufreq_driver_resolve_freq() __resolve_freq() [...] > diff --git a/kernel/sched/rt.c b/kernel/sched/rt.c > index a32c46889af8..d9982ebd4821 100644 > --- a/kernel/sched/rt.c > +++ b/kernel/sched/rt.c > @@ -466,6 +466,7 @@ static inline bool rt_task_fits_capacity(struct task_struct *p, int cpu) > max_cap = uclamp_eff_value(p, UCLAMP_MAX); > > cpu_cap = capacity_orig_of(cpu); > + cpu_cap -= arch_scale_thermal_pressure(cpu); > > return cpu_cap >= min(min_cap, max_cap); > } IMHO, this should follow what we do with rq->cpu_capacity (capacity_of(), the remaining capacity for CFS). E.g. we use capacity_of() in find_energy_efficient_cpu() and select_idle_capacity() to compare capacities. So we would need a function like scale_rt_capacity() for RT (minus the rq->avg_rt.util_avg) but then also one for DL (minus rq->avg_dl.util_avg and rq->avg_rt.util_avg).