Received: by 10.213.65.68 with SMTP id h4csp639985imn; Tue, 27 Mar 2018 06:11:14 -0700 (PDT) X-Google-Smtp-Source: AG47ELs676qxmrloIXjxr9JVcj+gZg982wJW1/pXuzPsjsld8gAh0/5/4rJdDRiLpEEiq8HFBuE6 X-Received: by 10.99.145.193 with SMTP id l184mr30768221pge.394.1522156274583; Tue, 27 Mar 2018 06:11:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1522156274; cv=none; d=google.com; s=arc-20160816; b=OEEoXL0D+kCtCuVwCF0JLkPY4sfvGBt2zx7UZAMOp7D3AMkF37biVLmAeKFkB4+s97 CVXg3jSN+9RQhQU/MLhMMxkr9QGMDnf+2l8he0Th5pJqH+ndU47y1NryPM/JlUg/C8hD RyzqRgHl+tY1ngA9VWBIN+QaNBPGyCBdGRsVOgF4uH4VvtpIfTmx3PzxG411Pm756Mn9 YFagHzcPTKLZNjkDzSfNSVZ9QtsSDEz28/37BzWnjE09r2mj57E8ZuRfwUg4encC0CwB 1QtQA1dNEZtVFJrkYfTIHl/4hEVyj9tVs7yydJZjRgKIo1PJpoUDqOH2a5A2yo0W8P+P NVSw== 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:arc-authentication-results; bh=BUTrcFaoQ4RuDYuO2awb92DhfdgsgFHN0SSLW//uC0w=; b=jCl3Fcu311sepY6s52CArFqCSh3Rk9pErVB4XTEshSrBfrJbVuwsIXcsOn2jlI6JG+ JuQ9hEITDKVs912FJX4tDdjopCPWrn2dkyb6HvQcXMmf+P1wwsKNow705w+zwMmFx4B5 QCtWHRdIf8msRu/XxeIDLTXL1Ybuozg3VgPNAOYW8pd6p4VSv1Aoj+wakZhnSclwmLeO KYvP+pfaOUCIwcTAPX3rCosrVx+F+d/zWIWV3db7G+M8JhylUQoYPfKCyzFt84Xv2g1K eHGpTO7M3AK9/0Mfl7OOFTnAPxf020XvDj0S40ZMc3m4v81FqH/4jAG7lRj9rJFSTifS F6+Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=Xz250+Mf; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id y22-v6si1189161pll.270.2018.03.27.06.10.59; Tue, 27 Mar 2018 06:11:14 -0700 (PDT) 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; dkim=pass header.i=@gmail.com header.s=20161025 header.b=Xz250+Mf; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752623AbeC0NIO (ORCPT + 99 others); Tue, 27 Mar 2018 09:08:14 -0400 Received: from mail-wr0-f196.google.com ([209.85.128.196]:36268 "EHLO mail-wr0-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752538AbeC0NIN (ORCPT ); Tue, 27 Mar 2018 09:08:13 -0400 Received: by mail-wr0-f196.google.com with SMTP id y55so1772783wry.3; Tue, 27 Mar 2018 06:08:12 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=BUTrcFaoQ4RuDYuO2awb92DhfdgsgFHN0SSLW//uC0w=; b=Xz250+MfWlPsn5PDtNephf9ezc341dYjZVfC6OXNrZG3DIZWYOMs7CtxTMGL+qi9N7 ayoJzP4bFI+PBSkTAkQLkN3WHRCO9TZNMIFKZn9TlzcxSM0Hck7L+ncxw0q/eqDjtYqy 8I3UDn0MBWsKhElY0JLSpIYyAX73plAeOnMRxodtSH9iqHn4ad8Ifo+ZDMmh9F3vVIxp M1uV9DD8Govxiy6dp4Q8/gqMnPGQ70y+Qp2TA4LeaZn9I4Hi6gfdO2ArTbwnL2Vza3K/ BE+th8BuD0/SJlhzzSo5/2obgTQPXuKYfZmQLi53HGZ7ADMCYQBC5IHqFYFI0nC9/XFV J3Tw== 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=BUTrcFaoQ4RuDYuO2awb92DhfdgsgFHN0SSLW//uC0w=; b=Lei8YLgTXb17mpWxTlI9xdF/1Fhovzg0CUx5ri/LvlU70M48pjdUjK1L1sSUpupVkt vlpvphVRo+L1Fh0y6FM3epJCdxxbMFwViKfQTbDTK8F+Gz6HUdGXXv7UI41pwbYY9a6+ XkPJQeEhtMEP6hhXNyGRCoTosTeX9jsXodRGkPYmvzZvbfoRP53QJ1Si2XN4cMdnorDD tj0VJ4W6TjHzjpDVmT54jTbLtEIW6R9jQQoeWPWZ8gl/e/NWwkYeEbN38dtOkCWzP2jW ODC0Ati1taKPwSxglv0wD8Wx9Ok8Gpng7wQwA8xOG5SKkzzt62v7m+kL8eDehZDvOiIB n90Q== X-Gm-Message-State: AElRT7FTgqezHgpzrJaqQzwqX1jTqbW3b0gdRMrksrQw/HfUcHsM+wvX ACL0j8lnmugM6cnQNiAO0HgWurh2oeg= X-Received: by 10.223.136.67 with SMTP id e3mr14415935wre.250.1522156091413; Tue, 27 Mar 2018 06:08:11 -0700 (PDT) Received: from localhost.localdomain ([151.15.243.46]) by smtp.gmail.com with ESMTPSA id 33sm1091531wrs.74.2018.03.27.06.08.09 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Tue, 27 Mar 2018 06:08:10 -0700 (PDT) Date: Tue, 27 Mar 2018 15:08:08 +0200 From: Juri Lelli To: Daniel Lezcano Cc: Leo Yan , edubezval@gmail.com, kevin.wangtao@linaro.org, vincent.guittot@linaro.org, amit.kachhap@gmail.com, linux-kernel@vger.kernel.org, javi.merino@kernel.org, rui.zhang@intel.com, daniel.thompson@linaro.org, linux-pm@vger.kernel.org, Viresh Kumar Subject: Re: [PATCH V2 6/7] thermal/drivers/cpu_cooling: Introduce the cpu idle cooling driver Message-ID: <20180327130808.GE10639@localhost.localdomain> References: <1519226968-19821-1-git-send-email-daniel.lezcano@linaro.org> <1519226968-19821-7-git-send-email-daniel.lezcano@linaro.org> <20180327020331.GA21693@leoy-ThinkPad-X240s> <8ee2cb0d-9afe-6626-0911-90ff6660bf8a@linaro.org> <20180327122836.GD10639@localhost.localdomain> <719e1d94-170c-f208-d4a2-f3e882b1e20e@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <719e1d94-170c-f208-d4a2-f3e882b1e20e@linaro.org> User-Agent: Mutt/1.9.2 (2017-12-15) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 27/03/18 14:31, Daniel Lezcano wrote: > On 27/03/2018 14:28, Juri Lelli wrote: > > Hi Daniel, > > > > On 27/03/18 12:26, Daniel Lezcano wrote: > >> On 27/03/2018 04:03, Leo Yan wrote: > >>> Hi Daniel, > >>> > >>> On Wed, Feb 21, 2018 at 04:29:27PM +0100, Daniel Lezcano wrote: > >>>> The cpu idle cooling driver performs synchronized idle injection across all > >>>> cpus belonging to the same cluster and offers a new method to cool down a SoC. > >>>> > >>>> Each cluster has its own idle cooling device, each core has its own idle > >>>> injection thread, each idle injection thread uses play_idle to enter idle. In > >>>> order to reach the deepest idle state, each cooling device has the idle > >>>> injection threads synchronized together. > >>>> > >>>> It has some similarity with the intel power clamp driver but it is actually > >>>> designed to work on the ARM architecture via the DT with a mathematical proof > >>>> with the power model which comes with the Documentation. > >>>> > >>>> The idle injection cycle is fixed while the running cycle is variable. That > >>>> allows to have control on the device reactivity for the user experience. At > >>>> the mitigation point the idle threads are unparked, they play idle the > >>>> specified amount of time and they schedule themselves. The last thread sets > >>>> the next idle injection deadline and when the timer expires it wakes up all > >>>> the threads which in turn play idle again. Meanwhile the running cycle is > >>>> changed by set_cur_state. When the mitigation ends, the threads are parked. > >>>> The algorithm is self adaptive, so there is no need to handle hotplugging. > >>> > >>> The idle injection threads are RT threads (FIFO) and I saw in > >>> play_idle() set/clear flag PF_IDLE for it. Will these idle injection > >>> threads utilization be accounted into RT utilization? > >>> > >>> If idle injection threads utilization is accounted as RT tasks > >>> utilization, will this impact CPUFreq governor 'schedutil' for OPP > >>> selection? > >> > >> Hi Leo, > >> > >> The idle injection task has a very low utilization when it is not in the > >> play_idle function, basically it wakes up, sets a timer and play_idle(). > >> > >> Regarding the use case, the idle injection is the base brick for an > >> combo cooling device with cpufreq + cpuidle. When the idle injection is > >> used alone, it is because there is no cpufreq driver for the platform. > >> If there is a cpufreq driver, then we should endup with the cpu cooling > >> device where we have control of the OPP (and there is no idle injection > >> threads) or the combo cooling device. > >> > >> Except I'm missing something, the idle injection threads won't impact > >> the OPP selection. > > > > Mmm, they actually might. schedutil selects max OPP as soon as it sees > > an RT thread. I fear these guys might generate unwanted spikes. Maybe > > you can filter them out? > > Yes, absolutely. Leo pointed it also. > > We might want to change the check at: > > https://elixir.bootlin.com/linux/v4.16-rc7/source/kernel/sched/cpufreq_schedutil.c#L364 > > in order to ignore PF_IDLE tagged tasks. We might yes. And also for the update_single cases, I guess. Best, - Juri