* Thomas Renninger <trenn@xxxxxxx> wrote: > Changes in V2: > - Introduce PWR_EVENT_EXIT instead of 0 to mark non-power state > - Use u32 instead of u64 for cpuid, state which is by far enough > > New power trace events: > power:processor_idle > power:processor_frequency > power:machine_suspend > > > C-state/idle accounting events: > power:power_start > power:power_end > are replaced with: > power:processor_idle > > and > power:power_frequency > is replaced with: > power:processor_frequency Could you please name it power:cpu_idle and power:cpu_frequency instead, for shortness? We generally use 'cpu' in the kernel and for events. > power:machine_suspend How will future PCI (or other device) power saving tracepoints be called? Might be more consistent to use: power:cpu_idle power:machine_idle power:device_idle Where machine_idle is the suspend event. > the type= field got removed from both, it was never > used and the type is differed by the event type itself. > > +#define PWR_EVENT_EXIT 0xFFFFFFFF Shouldnt this be part of the POWER_ enum? (and you can write -1 there) > +#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'? Plus: > +DECLARE_EVENT_CLASS(processor, > + > + TP_PROTO(unsigned int state, unsigned int cpu_id), > + > + TP_ARGS(state, cpu_id), > + > + TP_STRUCT__entry( > + __field( u32, state ) > + __field( u32, cpu_id ) Trace entries can carry a cpu_id of the current processor already. Can this cpu_id ever be different from that CPU id? > + ), > + > + TP_fast_assign( > + __entry->state = state; > + __entry->cpu_id = cpu_id; > + ), > + > + TP_printk("state=%lu cpu_id=%lu", (unsigned long)__entry->state, > + (unsigned long)__entry->cpu_id) > +); > + > +DEFINE_EVENT(processor, processor_idle, > + > + TP_PROTO(unsigned int state, unsigned int cpu_id), > + > + TP_ARGS(state, cpu_id) > +); > + > +#define PWR_EVENT_EXIT 0xFFFFFFFF > + > +DEFINE_EVENT(processor, processor_frequency, > + > + TP_PROTO(unsigned int frequency, unsigned int cpu_id), > + > + TP_ARGS(frequency, cpu_id) > +); So, we have a 'state' field in the class, which is used as 'state' by the power::cpu_idle event, and as 'frequency' by the power::cpu_freq event? Are there any architectures that track frequency in Hz, not in kHz? If yes, might there ever be a need for the frequency value to be larger than 4.29 GHz? If yes, then it wont fit into u32. Also, might there be a future need to express different types of frequencies? For example, should we decide to track turbo frequencies in Intel CPUs, how would that be expressed via these events? Are there any architectures and CPUs that somehow have some extra attribute to the frequency value? > +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'? Ingo _______________________________________________ linux-pm mailing list linux-pm@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linux-foundation.org/mailman/listinfo/linux-pm