Received: by 10.213.65.68 with SMTP id h4csp1337998imn; Wed, 21 Mar 2018 08:18:10 -0700 (PDT) X-Google-Smtp-Source: AG47ELswTf94Iq1kaIFMJK8IKrntEYqXnXItxFoC6ubP2IJbZunJKrb9V/onY86PX8tWqwJa28n/ X-Received: by 10.98.16.131 with SMTP id 3mr17411123pfq.188.1521645490643; Wed, 21 Mar 2018 08:18:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521645490; cv=none; d=google.com; s=arc-20160816; b=uwLuuws9tHa5EMsBDoV1N2bJYq4WWK+C52slmiwQNs8ADeg2hpmVgIv4+j3E16qljV HtUESlWbIEY4gyULZO9w7jmfBRAaDAnptQXy4oqdb8tBq2HBxKIhOGTsMDZEFb6hR3eU tad55EnWyylgNcJJ05Y2BgjBhOLHK1VgXN37KZYJgtFglsxJb9uUdLhpQEvbjxzVKvYK mSx0AOC2viOnCaO6e2sCsv1wJHeQZihXVvoqRZo99+PlyP511srnMFm7g/SgddL3rmNZ wcUElkoGW0YmkpOgVhHFyFd4qWtkqXiOiOflOAcEQV9IsiOiqoaWM+MgUyf69kF84a/r Ir9w== 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=RMUjyZCxaylKrBXYQ+ONMJ+gsET60Wt5LXbij/KtA6g=; b=SceKoOrrlP39A6/7LKjPJkv3dFTxCZLV1zPlhU0vYiNnHkWnRI506Z3bhEGEZo6vMb Bmz+du9TlkDAF5A4y1BhQbGboqlfGYqpI+D8Bm/YlSCCafeVmMhG9+6m3QPRdxH3AuDG wAL7h/AJ5r1w/jxCU9+Mg+hzK7pXls0tzBpVxcj9qz6c3nkWPkiy5fWfu6yz8B/k5SWN 1T+/vkJgYE2xqUonIOQ58DTxUwcnREw7kDk3nEn8ORAIpnf8vFlKvVT3oBOiv/NMgV7e GIiqERRr34TsT/4PliIk7lMVki4Aiy2/ITRm2WfgzFzqT/aHOLboYIQdBd9ELccOKMTC 0hZA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=KhBdEfNg; 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 s8-v6si4473064plk.550.2018.03.21.08.17.56; Wed, 21 Mar 2018 08:18:10 -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=KhBdEfNg; 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 S1752649AbeCUPPY (ORCPT + 99 others); Wed, 21 Mar 2018 11:15:24 -0400 Received: from mail-wm0-f68.google.com ([74.125.82.68]:38196 "EHLO mail-wm0-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752629AbeCUPPT (ORCPT ); Wed, 21 Mar 2018 11:15:19 -0400 Received: by mail-wm0-f68.google.com with SMTP id l16so10523431wmh.3; Wed, 21 Mar 2018 08:15:19 -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=RMUjyZCxaylKrBXYQ+ONMJ+gsET60Wt5LXbij/KtA6g=; b=KhBdEfNgCcm7BGpFT93NCphjycw06TokeONTuHWMuvxDZn2z8QuJ6xUySZm4Q4ARDa rCY5ngBBIoqRQvDW8Ff51Ygm+qvJC80fX1aiNbFZ8EzqLlsH5UGrdQ7pMr2zSqd0jKn1 D6alwVKEqlH/ezdzO4dPq/RVe/Z0H+HQGR7wanhn0kFXzJha4mH1w0TcoJ41/YYHgc9j /fb4j51KwlYY+X8E3Wwg60El65vOd/l0u6STTXgopnE18dy3gbSBJDD0rnGwVHz+8Jlz x7zVhxxZI60swmA7ez2xGFnkW9hFn1wx5RZukbcjwTloh0GhvVifxbI9g0RHAh0Rmwfp vPsA== 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=RMUjyZCxaylKrBXYQ+ONMJ+gsET60Wt5LXbij/KtA6g=; b=pwr2wDk8QQQA828aXV1OrG3ZPBNKwV9IGeUP2ejpkcdhe2GKBhFkk358074UWl8bk7 96yXOZ8vEMZzzLNXzPy1QNjPl+XefllwJisK/drw/Pg+y5bKJNMrZVfQxECBNCRFEx3V W8NggjNv60gqfUdO/tMQL0NIXqvsmgZFgLajOpQSRI1j9hd7CLnf0SRShOJPdcqKMMzD Y6dUvCWQlEnLFVB/fntlo9COETlUhl/5CfVc4RG5TV7pxa6RNNYp78fQHHoT13kFmSP8 bVs4wtkNPsdeN2XTt7qZK+faELKvs1YphMG5VfiHE5RHbrqS3JnxYy557rkMBfGH5GOG ZotA== X-Gm-Message-State: AElRT7F9ga4rr+YPoPiD4ZalkRlnVQbh1wA96g9Pez9Xa42fSLkCtcDQ TGiPb/T0uxAXgc1fNNkEiME= X-Received: by 10.28.51.213 with SMTP id z204mr2758689wmz.74.1521645318103; Wed, 21 Mar 2018 08:15:18 -0700 (PDT) Received: from localhost.localdomain ([151.15.242.31]) by smtp.gmail.com with ESMTPSA id f84sm5164230wmh.44.2018.03.21.08.15.15 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Wed, 21 Mar 2018 08:15:16 -0700 (PDT) Date: Wed, 21 Mar 2018 16:15:13 +0100 From: Juri Lelli To: Quentin Perret Cc: Patrick Bellasi , Dietmar Eggemann , linux-kernel@vger.kernel.org, Peter Zijlstra , Thara Gopinath , linux-pm@vger.kernel.org, Morten Rasmussen , Chris Redpath , Valentin Schneider , "Rafael J . Wysocki" , Greg Kroah-Hartman , Vincent Guittot , Viresh Kumar , Todd Kjos , Joel Fernandes Subject: Re: [RFC PATCH 4/6] sched/fair: Introduce an energy estimation helper function Message-ID: <20180321151513.GE15165@localhost.localdomain> References: <20180320094312.24081-1-dietmar.eggemann@arm.com> <20180320094312.24081-5-dietmar.eggemann@arm.com> <20180321090430.GA6913@localhost.localdomain> <20180321122621.GA13951@e110439-lin> <20180321125925.GB15165@localhost.localdomain> <20180321135557.GB1373@queper01-VirtualBox> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20180321135557.GB1373@queper01-VirtualBox> 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 21/03/18 13:55, Quentin Perret wrote: > On Wednesday 21 Mar 2018 at 13:59:25 (+0100), Juri Lelli wrote: > > On 21/03/18 12:26, Patrick Bellasi wrote: > > > On 21-Mar 10:04, Juri Lelli wrote: [...] > > > > > + /* > > > > > + * As the goal is to estimate the OPP reached for a specific util > > > > > + * value, mimic the behaviour of schedutil with a 1.25 coefficient > > > > > + */ > > > > > + util += util >> 2; > > > > > > > > What about other governors (ondemand for example). Is this supposed to > > > > work only when schedutil is in use (if so we should probably make it > > > > conditional on that)? > > > > > > Yes, I would say that EAS mostly makes sense when you have a "minimum" > > > control on OPPs... otherwise all the energy estimations are really > > > fuzzy. > > > > Make sense to me. Shouldn't we then make all this conditional on using > > schedutil? > > So, in theory, EAS could make sense even for other governors than > schedutil. Even with the performance governor it is probably more > energy efficient (although users using "performance" probably don't care > about energy, but that's just an example) to place small tasks onto little > CPUs up to a certain point given by the energy model. The ideal solution > would be to change the behaviour of find_cap_state() depending on the > governor being used, but I don't know if this extra complexity is worth > it really. > I'm happy to make all this conditional on schedutil as a first step and > we can see later if that makes sense to extend EAS to other use-cases. I agree that EAS makes still sense even for !schedutil cases (your performance example being one of them, powersave maybe another one?). Making it work with ondemand is tricky, though. So, not sure what's the best thing to do, but we should be at least aware of limitations. > > > > > > > > > > Also, even when schedutil is in use, shouldn't we ask it for a util > > > > "computation" instead of replicating its _current_ heuristic? > > > > > > Are you proposing to have the 1.25 factor only here and remove it from > > > schedutil? > > > > I'm only saying that we shouldn't probably have two places where we add > > this 1.25 factor to utilization before using it, as in the future one of > > the two might modify that 1.25 to something else and then we'll have > > problems. So, maybe a common wrapper that adds such factor? > > Ok, I can definitely factorize this code between schedutil and EAS. And > BTW, would it make sense to make schedutil use "capacity_margin" instead > of an arbitrary value ? The semantics feels pretty close. Out of curiosity, > what was the reason to use C=1.25 in the first place ? I seem to remember it was choosen out of experiments, but I might surely be wrong and Rafael, Viresh, others will correct me. :) > > > > > > > > > > I fear the two might diverge in the future. > > > > > > That could be avoided by factoring out from schedutil the > > > "compensation" factor into a proper function to be used by all the > > > interested playes, isn't it? > > > > And I should have read till the end before writing the above paragraph > > it seems. :) > > > > Thanks, > > > > - Juri > > Thank you very much for the feedback ! No problem. I'm of course very interested in this. Could you please directly Cc me (juri.lelli@redhat.com) in next versions? Thanks, - Juri