linux-perf-users.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Eduardo Valentin <eduardo.valentin@nokia.com>
To: "ext jean.pihet@newoldbits.com" <jean.pihet@newoldbits.com>
Cc: mingo@elte.hu, trenn@suse.de, Len Brown <len.brown@intel.com>,
	Pavel Machek <pavel@ucw.cz>, "Rafael J. Wysocki" <rjw@sisk.pl>,
	linux-pm@lists.linux-foundation.org,
	linux-kernel@vger.kernel.org, linux-omap@vger.kernel.org,
	Arjan van de Ven <arjan@linux.intel.com>,
	linux-perf-users@vger.kernel.org, Jean Pihet <j-pihet@ti.com>
Subject: Re: [PATCH 2/2] tools, perf: Documentation for the power events API
Date: Fri, 7 Jan 2011 07:50:42 +0200	[thread overview]
Message-ID: <20110107055042.GA6137@besouro.research.nokia.com> (raw)
In-Reply-To: <1294253342-29056-3-git-send-email-j-pihet@ti.com>

Hello Jean,

On Wed, Jan 05, 2011 at 07:49:02PM +0100, ext jean.pihet@newoldbits.com wrote:
> From: Jean Pihet <j-pihet@ti.com>
> 
> Provides documentation for the following:
> - the new power trace API,
> - the old (legacy) power trace API,
> - the DEPRECATED Kconfig option usage.
> 
> Signed-off-by: Jean Pihet <j-pihet@ti.com>
> ---
>  Documentation/trace/events-power.txt |   90 ++++++++++++++++++++++++++++++++++
>  1 files changed, 90 insertions(+), 0 deletions(-)
>  create mode 100644 Documentation/trace/events-power.txt
> 
> diff --git a/Documentation/trace/events-power.txt b/Documentation/trace/events-power.txt
> new file mode 100644
> index 0000000..96d87b6
> --- /dev/null
> +++ b/Documentation/trace/events-power.txt
> @@ -0,0 +1,90 @@
> +
> +			Subsystem Trace Points: power
> +
> +The power tracing system captures events related to power transitions
> +within the kernel. Broadly speaking there are three major subheadings:
> +
> +  o Power state switch which reports events related to suspend (S-states),
> +     cpuidle (C-states) and cpufreq (P-states)
> +  o System clock related changes

What do you mean by system clock here? I see that you are covering cpu rate
changes and system clock (?) here. How about memory clock changes?
Would it make sense to have a major subheading for it? Maybe you are
targeting it be traced by means of clocks event (item 2. bellow)..

> +  o Power domains related changes and transitions
> +
> +This document describes what each of the tracepoints is and why they
> +might be useful.
> +
> +Cf. include/trace/events/power.h for the events definitions.
> +
> +1. Power state switch events
> +============================
> +
> +1.1 New trace API
> +-----------------
> +
> +A 'cpu' event class gathers the CPU-related events: cpuidle and
> +cpufreq.
> +
> +cpu_idle		"state=%lu cpu_id=%lu"
> +cpu_frequency		"state=%lu cpu_id=%lu"
> +
> +A suspend event is used to indicate the system going in and out of the
> +suspend mode:
> +
> +machine_suspend		"state=%lu"
> +
> +
> +Note: the value of '-1' or '4294967295' for state means an exit from the current state,
> +i.e. trace_cpu_idle(4, smp_processor_id()) means that the system
> +enters the idle state 4, while trace_cpu_idle(PWR_EVENT_EXIT, smp_processor_id())
> +means that the system exits the previous idle state.
> +
> +The event which has 'state=4294967295' in the trace is very important to the user
> +space tools which are using it to detect the end of the current state, and so to
> +correctly draw the states diagrams and to calculate accurate statistics etc.
> +
> +1.2 DEPRECATED trace API
> +------------------------
> +
> +A new Kconfig option CONFIG_EVENT_POWER_TRACING_DEPRECATED with the default value of
> +'y' has been created. This allows the legacy trace power API to be used conjointly
> +with the new trace API.
> +The Kconfig option, the old trace API (in include/trace/events/power.h) and the
> +old trace points will disappear in a future release (namely 2.6.41).
> +
> +power_start		"type=%lu state=%lu cpu_id=%lu"
> +power_frequency		"type=%lu state=%lu cpu_id=%lu"
> +power_end		"cpu_id=%lu"
> +
> +The 'type' parameter takes one of those macros:
> + . POWER_NONE	= 0,
> + . POWER_CSTATE	= 1,	/* C-State */
> + . POWER_PSTATE	= 2,	/* Fequency change or DVFS */
> +
> +The 'state' parameter is set depending on the type:
> + . Target C-state for type=POWER_CSTATE,
> + . Target frequency for type=POWER_PSTATE,
> +
> +power_end is used to indicate the exit of a state, corresponding to the latest
> +power_start event.
> +
> +2. Clocks events
> +================
> +The clock events are used for clock enable/disable and for
> +clock rate change.
> +
> +clock_enable		"%s state=%lu cpu_id=%lu"
> +clock_disable		"%s state=%lu cpu_id=%lu"
> +clock_set_rate		"%s state=%lu cpu_id=%lu"
> +
> +The first parameter gives the clock name (e.g. "gpio1_iclk").
> +The second parameter is '1' for enable, '0' for disable, the target
> +clock rate for set_rate.
> +
> +3. Power domains events
> +=======================
> +The power domain events are used for power domains transitions
> +
> +power_domain_target	"%s state=%lu cpu_id=%lu"
> +
> +The first parameter gives the power domain name (e.g. "mpu_pwrdm").
> +The second parameter is the power domain target state.
> +
> -- 
> 1.7.2.3
> 
> --
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> Please read the FAQ at  http://www.tux.org/lkml/

-- 
Eduardo Valentin

  reply	other threads:[~2011-01-07  5:56 UTC|newest]

Thread overview: 5+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2011-01-05 18:49 [PATCH 0/2] tools, perf: new power trace API jean.pihet
2011-01-05 18:49 ` [PATCH 1/2] perf: add calls to suspend trace point jean.pihet
2011-01-05 18:49 ` [PATCH 2/2] tools, perf: Documentation for the power events API jean.pihet
2011-01-07  5:50   ` Eduardo Valentin [this message]
2011-01-10 10:10     ` Jean Pihet

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20110107055042.GA6137@besouro.research.nokia.com \
    --to=eduardo.valentin@nokia.com \
    --cc=arjan@linux.intel.com \
    --cc=j-pihet@ti.com \
    --cc=jean.pihet@newoldbits.com \
    --cc=len.brown@intel.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-omap@vger.kernel.org \
    --cc=linux-perf-users@vger.kernel.org \
    --cc=linux-pm@lists.linux-foundation.org \
    --cc=mingo@elte.hu \
    --cc=pavel@ucw.cz \
    --cc=rjw@sisk.pl \
    --cc=trenn@suse.de \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).