On Fri, Feb 09, 2018 at 09:44:58PM -0500, Steven Rostedt wrote: > On Sat, 10 Feb 2018 09:37:04 +0800 > changbin...@intel.com wrote: > > > From: Changbin Du <changbin...@intel.com> > > > > The type of state is signed int, convert it to unsigned int looks weird. > > (-1 become 4294967295) > > 932.123 power:cpu_idle:state=1 cpu_id=0) > > 932.125 power:cpu_idle:state=4294967295 cpu_id=0) > > 932.132 power:cpu_idle:state=1 cpu_id=0) > > 932.133 power:cpu_idle:state=4294967295 cpu_id=0) > > > > Similarly for cpu_frequency as "state=%lu cpu_id=%lu". User need to read > > the code to understand what 'state' means. > > > > No functional change in this patch. > > That's not true. You split a class into two TRACE_EVENTS. Each > TRACE_EVENT adds approximately 5k of code and data. A DEFINE_EVENT() > adds around 300 bytes. There's better ways to do this, > > Please don't add this patch. > > -- Steve
Steve, How abount DEFINE_EVENT_PRINT as below? diff --git a/include/trace/events/power.h b/include/trace/events/power.h index 908977d..e71ce98 100644 --- a/include/trace/events/power.h +++ b/include/trace/events/power.h @@ -14,12 +14,12 @@ DECLARE_EVENT_CLASS(cpu, - TP_PROTO(unsigned int state, unsigned int cpu_id), + TP_PROTO(int state, unsigned int cpu_id), TP_ARGS(state, cpu_id), TP_STRUCT__entry( - __field( u32, state ) + __field( s32, state ) __field( u32, cpu_id ) ), @@ -28,13 +28,12 @@ DECLARE_EVENT_CLASS(cpu, __entry->cpu_id = cpu_id; ), - TP_printk("state=%lu cpu_id=%lu", (unsigned long)__entry->state, - (unsigned long)__entry->cpu_id) + TP_printk("state=%d cpu_id=%u", __entry->state, __entry->cpu_id) ); DEFINE_EVENT(cpu, cpu_idle, - TP_PROTO(unsigned int state, unsigned int cpu_id), + TP_PROTO(int state, unsigned int cpu_id), TP_ARGS(state, cpu_id) ); @@ -141,11 +140,13 @@ TRACE_EVENT(pstate_sample, { PM_EVENT_RESTORE, "restore" }, \ { PM_EVENT_RECOVER, "recover" }) -DEFINE_EVENT(cpu, cpu_frequency, +DEFINE_EVENT_PRINT(cpu, cpu_frequency, - TP_PROTO(unsigned int frequency, unsigned int cpu_id), + TP_PROTO(int state, unsigned int cpu_id), - TP_ARGS(frequency, cpu_id) + TP_ARGS(state, cpu_id), + + TP_printk("frequency=%u cpu_id=%lu", __entry->state, __entry->cpu_id) );