On Tuesday, October 26, 2010, Thomas Renninger wrote: > On Tuesday 26 October 2010 13:21:29 Ingo Molnar wrote: > > > > * Jean Pihet <jean.pihet@xxxxxxxxxxxxxx> wrote: > .. > > > >> +#ifndef _TRACE_POWER_ENUM_ > > > >> +#define _TRACE_POWER_ENUM_ > > > >> +enum { > > > >> + POWER_NONE = 0, > > > >> + POWER_CSTATE = 1, > > > >> + POWER_PSTATE = 2, > > > >> +}; > > > >> +#endif > > > > > > > > Since we are cleaning up all these events, those enum definitions dont really look > > > > logical. For example, what is 'POWER_NONE'? Can a CPU have 'no power'? > > > > > > The enum belongs to the deprecated API so I would rather not touch it. > > > Keeping the deprecated code isolated will make it easier to remove > > > later. > > > > So what will replace it? We still have a state field. > Nothing, this is part of the cleanup. > As you state above: POWER_NONE does not make sense at all. > The whole thing (type= attribute that vanishes now) is > passed to userspace, but never gets used there because the > same info is in the event name: > cpu_frequency <-> frequency_switch <-> PSTATE > cpu_idle <-> power_start/power_end <-> CSTATE > > I expect that there was an initial power_start/end which > was also used for frequency switching. > Then it got realized that _start/_end does not work out and > frequency_switch got introduced. > To stay compatible the whole power_start/end was not renamed > to cpu_idle and the type= field was kept. > > This is a guess without even looking at the git history. > Therefore my partly harsh comments about the sanity of the > current power tracing events. > > > Passing in platform specific codes is a step backwards. > > > > > >> +TRACE_EVENT(machine_suspend, > > > >> + > > > >> + TP_PROTO(unsigned int state), > > > >> + > > > >> + TP_ARGS(state), > > > >> + > > > >> + TP_STRUCT__entry( > > > >> + __field( u32, state ) > > > >> + ), > > > > > > > > Hm, this event is not used anywhere in the submitted patches. Where is the patch > > > > that adds usage, and what are the possible values for 'state'? > > > > > > This will come as a separate patch, which fits all platforms. Cf. > > > http://marc.info/?l=linux-omap&m=128620575300682&w=2. > > > The state field is of type suspend_state_t, cf. include/linux/suspend.h > > > > Ok, that's at least generic. Needs the review of Rafael, to determine > > whether this state value is all we want to know when we enter suspend. > He already gave an acked-by on this generic one here: > Re: [PATCH 3/4] perf: add calls to suspend trace point > Oh now, that was on the X86 specific part which depends on this one. > One should expect that he's fine with the generic part as well then, > but I agree that he should definitely have a look at this and sign it off. What patch exactly do you mean? I'm not quite sure from your comment above. Rafael -- To unsubscribe from this list: send the line "unsubscribe linux-trace-users" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html