Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp5159346imm; Tue, 19 Jun 2018 06:07:23 -0700 (PDT) X-Google-Smtp-Source: ADUXVKLXliXrLMfZ8scBU+uxXHsz4I0I+aVe+sF89Qjia75WgD9vxJWFw6VOJ6KHebXprAOCkh2Q X-Received: by 2002:a63:a557:: with SMTP id r23-v6mr14910669pgu.336.1529413642959; Tue, 19 Jun 2018 06:07:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1529413642; cv=none; d=google.com; s=arc-20160816; b=oasoWyeG7fDBySNiZ5lJJ7gba2qSRuh8v+AvSOeKSFz028OOOJeEahRFn/WwUfFgnR 95Ampcetu97O4p7B1VMsZS6t3A4Krp/c3LX/Y00SasM4ex8df72wZH4A5WxfjPeH0QuO DanH3Ecmz4eoMDJEzEwOwDVZr39XOjgz4YRAMVy+Z4J6T8gtKQlXjOP/2ch3o3GDvNTP X8+MnC+I9Ni1w5azSJxtZ+dhlEA4hgQXN0PB8AY1Q94r+VaYYToCsyNYzTOfwQ4D2JvL UxwDBrP/9CgbPEf3awZ5sNVKWaF/FK486d1q3U3vKsonMWi3oEUzrhBnT6RX9ne9B8iS aCSw== 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-transfer-encoding:content-disposition:mime-version :references:message-id:subject:cc:to:from:date :arc-authentication-results; bh=o45LOAo7dkpDot0R8NSWDmw+HZmHjmoi6ZhNWSfVPrI=; b=kLD8ok1Xugi6fj96x35m/RVK+UzOqihLMs/f5j5KevsJ6iv+8lTe2p2rBw0/ue7Lm8 V1XOFirK/mI+Z2h9u8v0S2wqxMoyWEScWWxXVCbcnh/jB8soAby+RPR7VXGYToPBjm7z wJ8c71Uweu8wUjL7Z41FUnTidYs4MNCOTNJsaI8bbeUkjNH61K570YoNaa+uxoANEtFD 2p70+kN5+of40T67MpmEZv+f3G2gpk6PVMH7CLJcogvsWp/dSGyLt/VAIzWZk8XFJ2D9 x3B+NNc9NwZ0tXKDGjQbZx5YM/zdiynGP+gojs2UBEV+BObnM/KPdmbxqByssI/FyP6p Sxcw== 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 f34-v6si16706566ple.52.2018.06.19.06.07.08; Tue, 19 Jun 2018 06:07:22 -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; 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 S966457AbeFSNG2 (ORCPT + 99 others); Tue, 19 Jun 2018 09:06:28 -0400 Received: from usa-sjc-mx-foss1.foss.arm.com ([217.140.101.70]:49866 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S965740AbeFSNG0 (ORCPT ); Tue, 19 Jun 2018 09:06:26 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 1402A80D; Tue, 19 Jun 2018 06:06:26 -0700 (PDT) Received: from e108498-lin.cambridge.arm.com (e108498-lin.cambridge.arm.com [10.1.211.46]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 1E0783F557; Tue, 19 Jun 2018 06:06:21 -0700 (PDT) Date: Tue, 19 Jun 2018 14:06:20 +0100 From: Quentin Perret To: Peter Zijlstra Cc: rjw@rjwysocki.net, gregkh@linuxfoundation.org, linux-kernel@vger.kernel.org, linux-pm@vger.kernel.org, mingo@redhat.com, dietmar.eggemann@arm.com, morten.rasmussen@arm.com, chris.redpath@arm.com, patrick.bellasi@arm.com, valentin.schneider@arm.com, vincent.guittot@linaro.org, thara.gopinath@linaro.org, viresh.kumar@linaro.org, tkjos@google.com, joelaf@google.com, smuckle@google.com, adharmap@quicinc.com, skannan@quicinc.com, pkondeti@codeaurora.org, juri.lelli@redhat.com, edubezval@gmail.com, srinivas.pandruvada@linux.intel.com, currojerez@riseup.net, javi.merino@kernel.org Subject: Re: [RFC PATCH v3 04/10] PM / EM: Expose the Energy Model in sysfs Message-ID: <20180619130620.GZ17720@e108498-lin.cambridge.arm.com> References: <20180521142505.6522-1-quentin.perret@arm.com> <20180521142505.6522-5-quentin.perret@arm.com> <20180619121643.GR2458@hirez.programming.kicks-ass.net> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <20180619121643.GR2458@hirez.programming.kicks-ass.net> User-Agent: Mutt/1.8.3 (2017-05-23) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tuesday 19 Jun 2018 at 14:16:43 (+0200), Peter Zijlstra wrote: > On Mon, May 21, 2018 at 03:24:59PM +0100, Quentin Perret wrote: > > This exposes the Energy Model (read-only) of all frequency domains in > > sysfs for convenience. To do so, a parent kobject is added to the CPU > > subsystem under the umbrella of which a kobject for each frequency > > domain is attached. > > > > The resulting hierarchy is as follows for a platform with two frequency > > domains for example: > > > > /sys/devices/system/cpu/energy_model > > ├── fd0 > > │   ├── capacity > > │   ├── cpus > > │   ├── frequency > > │   └── power > > └── fd4 > > ├── capacity > > ├── cpus > > ├── frequency > > └── power > > > > Given that each FD can have multiple {freq,power} tuples and sysfs has a > one value per file policy, how does this work? This is meant to look a little bit like the sysfs entries of CPUFreq policies, so you get something like this: $ cat /sys/devices/system/cpu/energy_model/fd0/capacity 133 250 351 428 462 $ cat /sys/devices/system/cpu/energy_model/fd0/frequency 533000 999000 1402000 1709000 1844000 $ cat /sys/devices/system/cpu/energy_model/fd0/power 28 70 124 187 245 $ cat /sys/devices/system/cpu/energy_model/fd0/cpus 0-3 For example, CPUFreq exposes available governors and frequencies as: $ cat /sys/devices/system/cpu/cpufreq/policy0/scaling_available_governors conservative ondemand userspace powersave performance schedutil $ cat /sys/devices/system/cpu/cpufreq/policy0/scaling_available_frequencies 533000 999000 1402000 1709000 1844000