Received: by 2002:a25:31c3:0:0:0:0:0 with SMTP id x186csp547962ybx; Wed, 6 Nov 2019 04:53:16 -0800 (PST) X-Google-Smtp-Source: APXvYqzBx3OaFQSLvWSQ2zBDD1Fo6cza70jFO7RQhF3RTqpZmSXrChRbSlPopPuOoIE2VslgfQkz X-Received: by 2002:a17:906:8046:: with SMTP id x6mr33985031ejw.221.1573044796201; Wed, 06 Nov 2019 04:53:16 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1573044796; cv=none; d=google.com; s=arc-20160816; b=wzBRbG+POaut8nKpI6Bam3EiKuZIEAIkbg2Ynigzh9UdRcw5hYsKnaPT7wEwvYhcap qC0vNrUutwKq7Zu5erFrVq31xta9Sa5ELk1p434b9X6e9Sab40Xw6hQYeb92o7Td0PPB IA/AmXCxPc0l+3UC1g8PT0TCm8TbOKICcOQn6jeI5PHeOEpC9KYdrYfY6XmqvzHReV5d YciFNxZG4Fei5KShFL+9W72gJ4oBJ2dvD+Pow2tX6Elom/4N0hjw0sFtlxZOy72W4QFQ KwaxHPBorBpoemshD+hWmpBKQ13rqqPM6Hlx8SjTDibUEHzcxv7gsZ8yaplEG4oci0zh T3/Q== 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=m6efsQSZcVBoWZ7AN85yaTiDAzhs1Et6xCFddf98WzI=; b=Q4HuGFlaGXU9MH6Fdpf4uDfkOi4FCj/7ACed9JGkSCoDGd4V2MojId0TE5nxCEyH8Y dx66bqPNhDgGlJjed7JUOKMzHFL9jqlRVtktu8JlR3VPaDARYw4TKgIgsVxkoeFplNva JW1M7IBoQhmsS8in/Q62MeJO/SFg5XeMADwXe4Aa7MsrcntdSDqjhnvqi0m9FUDMkxPT 7Rr7s3tfNXgWJDFeCkXiJpwEz92SCaHTwo7DPmXb/b2yGEXF6ynkLZ52T+rk91pdy4LK yhCuMAYarqcw5D1K2jBgWPpVGgffyCvIIkr+gtv8rlGQ6yis3rpfvaG2DEGbVVCaitIF nRmg== 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 p37si11290307eda.405.2019.11.06.04.52.52; Wed, 06 Nov 2019 04:53:16 -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 S1730650AbfKFMu3 (ORCPT + 99 others); Wed, 6 Nov 2019 07:50:29 -0500 Received: from foss.arm.com ([217.140.110.172]:39330 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727652AbfKFMu3 (ORCPT ); Wed, 6 Nov 2019 07:50:29 -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 041FC7CD; Wed, 6 Nov 2019 04:50:29 -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 34EAC3F6C4; Wed, 6 Nov 2019 04:50:27 -0800 (PST) Subject: Re: [Patch v5 2/6] sched/fair: Add infrastructure to store and update instantaneous thermal pressure To: Ionela Voinescu , Thara Gopinath Cc: mingo@redhat.com, peterz@infradead.org, vincent.guittot@linaro.org, rui.zhang@intel.com, edubezval@gmail.com, qperret@google.com, 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-3-git-send-email-thara.gopinath@linaro.org> <20191105202037.GA17494@e108754-lin> <5DC1E348.2090104@linaro.org> <20191105211446.GA25349@e108754-lin> <5DC1E9BC.1010001@linaro.org> <20191105215233.GA6450@e108754-lin> From: Dietmar Eggemann Message-ID: <436ad772-c727-127e-1469-d99549db03fc@arm.com> Date: Wed, 6 Nov 2019 13:50:26 +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: <20191105215233.GA6450@e108754-lin> 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 22:53, Ionela Voinescu wrote: > On Tuesday 05 Nov 2019 at 16:29:32 (-0500), Thara Gopinath wrote: >> On 11/05/2019 04:15 PM, Ionela Voinescu wrote: >>> On Tuesday 05 Nov 2019 at 16:02:00 (-0500), Thara Gopinath wrote: >>>> On 11/05/2019 03:21 PM, Ionela Voinescu wrote: >>>>> Hi Thara, >>>>> >>>>> On Tuesday 05 Nov 2019 at 13:49:42 (-0500), Thara Gopinath wrote: >>>>> [...] >>>>>> +static void trigger_thermal_pressure_average(struct rq *rq) >>>>>> +{ >>>>>> +#ifdef CONFIG_SMP >>>>>> + update_thermal_load_avg(rq_clock_task(rq), rq, >>>>>> + per_cpu(thermal_pressure, cpu_of(rq))); >>>>>> +#endif >>>>>> +} >>>>> >>>>> Why did you decide to keep trigger_thermal_pressure_average and not >>>>> call update_thermal_load_avg directly? >>>>> >>>>> For !CONFIG_SMP you already have an update_thermal_load_avg function >>>>> that does nothing, in kernel/sched/pelt.h, so you don't need that >>>>> ifdef. >>>> Hi, >>>> >>>> Yes you are right. But later with the shift option added, I shift >>>> rq_clock_task(rq) by the shift. I thought it is better to contain it in >>>> a function that replicate it in three different places. I can remove the >>>> CONFIG_SMP in the next version. >>> >>> You could still keep that in one place if you shift the now argument of >>> ___update_load_sum instead. >> >> No. I cannot do this. The authors of the pelt framework prefers not to >> include a shift parameter there. I had discussed this with Vincent earlier. >> > > Right! I missed Vincent's last comment on this in v4. > > I would argue that it's more of a PELT parameter than a CFS parameter > :), where it's currently being used. I would also argue that's more of a > PELT parameter than a thermal parameter. It controls the PELT time > progression for the thermal signal, but it seems more to configure the > PELT algorithm, rather than directly characterize thermals. > > In any case, it only seemed to me that adding a wrapper function for > this purpose only was not worth doing. Coming back to the v4 discussion https://lore.kernel.org/r/379d23e5-79a5-9d90-0fb6-125d9be85e99@arm.com There is no API between pelt.c and other parts of the scheduler/kernel so why should we keep an unnecessary parameter and wrapper functions? There is also no abstraction, update_thermal_load_avg() in pelt.c even carries '_thermal_' in its name. So why not define this shift value '[sched_|pelt_]thermal_decay_shift' there as well? It belongs to update_thermal_load_avg(). All call sites of update_thermal_load_avg() use 'rq_clock_task(rq) >> sched_thermal_decay_shift' so I don't see the need to pass it in. IMHO, preparing for eventual code changes (e.g. parsing different now values) is not a good practice in the kernel. Keeping the code small and tidy is.