Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit d3ab6957 authored by Subash Abhinov Kasiviswanathan's avatar Subash Abhinov Kasiviswanathan
Browse files

rmnet: Add rmnet_shs freq traces



Add rmnet traces to be used in rmnet_shs's freq
boost feature.

CRs-Fixed: 2437410
Change-Id: I44f42006a40b47ff7b083035732b47a1a78ece8c
Acked-by: default avatarRaul Martinez <mraul@qti.qualcomm.com>
Signed-off-by: default avatarSubash Abhinov Kasiviswanathan <subashab@codeaurora.org>
parent 005f8763
Loading
Loading
Loading
Loading
+3 −0
Original line number Original line Diff line number Diff line
@@ -46,6 +46,9 @@ EXPORT_TRACEPOINT_SYMBOL(rmnet_perf_err);
EXPORT_TRACEPOINT_SYMBOL(rmnet_low);
EXPORT_TRACEPOINT_SYMBOL(rmnet_low);
EXPORT_TRACEPOINT_SYMBOL(rmnet_high);
EXPORT_TRACEPOINT_SYMBOL(rmnet_high);
EXPORT_TRACEPOINT_SYMBOL(rmnet_err);
EXPORT_TRACEPOINT_SYMBOL(rmnet_err);
EXPORT_TRACEPOINT_SYMBOL(rmnet_freq_update);
EXPORT_TRACEPOINT_SYMBOL(rmnet_freq_reset);
EXPORT_TRACEPOINT_SYMBOL(rmnet_freq_boost);


/* Helper Functions */
/* Helper Functions */


+103 −324
Original line number Original line Diff line number Diff line
@@ -24,8 +24,8 @@
/*****************************************************************************/
/*****************************************************************************/
/* Trace events for rmnet module */
/* Trace events for rmnet module */
/*****************************************************************************/
/*****************************************************************************/
TRACE_EVENT
DECLARE_EVENT_CLASS
	(rmnet_low,
	(rmnet_mod_template,


	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),
@@ -61,415 +61,194 @@ TP_printk("fun:%u ev:%u u1:%u u2:%u ul1:%llu ul2:%llu p1:0x%pK p2:0x%pK",
	  __entry->ptr1, __entry->ptr2)
	  __entry->ptr1, __entry->ptr2)
)
)


TRACE_EVENT
DEFINE_EVENT
	(rmnet_high,
	(rmnet_mod_template, rmnet_low,


	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),


	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2),
	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2)


	 TP_STRUCT__entry(
);
		__field(u8, func)
		__field(u8, evt)
		__field(u32, uint1)
		__field(u32, uint2)
		__field(u64, ulong1)
		__field(u64, ulong2)
		__field(void *, ptr1)
		__field(void *, ptr2)
	 ),


	 TP_fast_assign(
DEFINE_EVENT
		__entry->func = func;
	(rmnet_mod_template, rmnet_high,
		__entry->evt = evt;
		__entry->uint1 = uint1;
		__entry->uint2 = uint2;
		__entry->ulong1 = ulong1;
		__entry->ulong2 = ulong2;
		__entry->ptr1 = ptr1;
		__entry->ptr2 = ptr2;
	 ),


TP_printk("fun:%u ev:%u u1:%u u2:%u ul1:%llu ul2:%llu p1:0x%pK p2:0x%pK",
	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
	  __entry->func, __entry->evt,
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),
	  __entry->uint1, __entry->uint2,

	  __entry->ulong1, __entry->ulong2,
	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2)
	  __entry->ptr1, __entry->ptr2)

)
);

DEFINE_EVENT
	(rmnet_mod_template, rmnet_err,


TRACE_EVENT
	(rmnet_err,
	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),
	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2),
	 TP_STRUCT__entry(
		__field(u8, func)
		__field(u8, evt)
		__field(u32, uint1)
		__field(u32, uint2)
		__field(u64, ulong1)
		__field(u64, ulong2)
		__field(void *, ptr1)
		__field(void *, ptr2)
	 ),


	 TP_fast_assign(
	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2)
		__entry->func = func;
		__entry->evt = evt;
		__entry->uint1 = uint1;
		__entry->uint2 = uint2;
		__entry->ulong1 = ulong1;
		__entry->ulong2 = ulong2;
		__entry->ptr1 = ptr1;
		__entry->ptr2 = ptr2;
	 ),


TP_printk("fun:%u ev:%u u1:%u u2:%u ul1:%llu ul2:%llu p1:0x%pK p2:0x%pK",
);
	  __entry->func, __entry->evt,
	  __entry->uint1, __entry->uint2,
	  __entry->ulong1, __entry->ulong2,
	  __entry->ptr1, __entry->ptr2)
)


/*****************************************************************************/
/*****************************************************************************/
/* Trace events for rmnet_perf module */
/* Trace events for rmnet_perf module */
/*****************************************************************************/
/*****************************************************************************/
TRACE_EVENT
DEFINE_EVENT
	(rmnet_perf_low,
	(rmnet_mod_template, rmnet_perf_low,


	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),


	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2),
	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2)


	 TP_STRUCT__entry(
);
		__field(u8, func)
		__field(u8, evt)
		__field(u32, uint1)
		__field(u32, uint2)
		__field(u64, ulong1)
		__field(u64, ulong2)
		__field(void *, ptr1)
		__field(void *, ptr2)
	 ),


	 TP_fast_assign(
DEFINE_EVENT
		__entry->func = func;
	(rmnet_mod_template, rmnet_perf_high,
		__entry->evt = evt;
		__entry->uint1 = uint1;
		__entry->uint2 = uint2;
		__entry->ulong1 = ulong1;
		__entry->ulong2 = ulong2;
		__entry->ptr1 = ptr1;
		__entry->ptr2 = ptr2;
	 ),

TP_printk("fun:%u ev:%u u1:%u u2:%u ul1:%llu ul2:%llu p1:0x%pK p2:0x%pK",
	  __entry->func, __entry->evt,
	  __entry->uint1, __entry->uint2,
	  __entry->ulong1, __entry->ulong2,
	  __entry->ptr1, __entry->ptr2)
)

TRACE_EVENT
	(rmnet_perf_high,


	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),


	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2),
	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2)


	 TP_STRUCT__entry(
);
		__field(u8, func)
		__field(u8, evt)
		__field(u32, uint1)
		__field(u32, uint2)
		__field(u64, ulong1)
		__field(u64, ulong2)
		__field(void *, ptr1)
		__field(void *, ptr2)
	 ),


	 TP_fast_assign(
DEFINE_EVENT
		__entry->func = func;
	(rmnet_mod_template, rmnet_perf_err,
		__entry->evt = evt;
		__entry->uint1 = uint1;
		__entry->uint2 = uint2;
		__entry->ulong1 = ulong1;
		__entry->ulong2 = ulong2;
		__entry->ptr1 = ptr1;
		__entry->ptr2 = ptr2;
	 ),

TP_printk("fun:%u ev:%u u1:%u u2:%u ul1:%llu ul2:%llu p1:0x%pK p2:0x%pK",
	  __entry->func, __entry->evt,
	  __entry->uint1, __entry->uint2,
	  __entry->ulong1, __entry->ulong2,
	  __entry->ptr1, __entry->ptr2)
)

TRACE_EVENT
	(rmnet_perf_err,


	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),


	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2),
	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2)

	 TP_STRUCT__entry(
		__field(u8, func)
		__field(u8, evt)
		__field(u32, uint1)
		__field(u32, uint2)
		__field(u64, ulong1)
		__field(u64, ulong2)
		__field(void *, ptr1)
		__field(void *, ptr2)
	 ),


	 TP_fast_assign(
);
		__entry->func = func;
		__entry->evt = evt;
		__entry->uint1 = uint1;
		__entry->uint2 = uint2;
		__entry->ulong1 = ulong1;
		__entry->ulong2 = ulong2;
		__entry->ptr1 = ptr1;
		__entry->ptr2 = ptr2;
	 ),


TP_printk("fun:%u ev:%u u1:%u u2:%u ul1:%llu ul2:%llu p1:0x%pK p2:0x%pK",
	  __entry->func, __entry->evt,
	  __entry->uint1, __entry->uint2,
	  __entry->ulong1, __entry->ulong2,
	  __entry->ptr1, __entry->ptr2)
)
/*****************************************************************************/
/*****************************************************************************/
/* Trace events for rmnet_shs module */
/* Trace events for rmnet_shs module */
/*****************************************************************************/
/*****************************************************************************/
TRACE_EVENT
DEFINE_EVENT
	(rmnet_shs_low,
	(rmnet_mod_template, rmnet_shs_low,


	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),


	 TP_ARGS(func, evt, uint1, uint2,
	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2)
		 ulong1, ulong2, ptr1, ptr2),

	 TP_STRUCT__entry(
		__field(u8, func)
		__field(u8, evt)
		__field(u32, uint1)
		__field(u32, uint2)
		__field(u64, ulong1)
		__field(u64, ulong2)
		__field(void *, ptr1)
		__field(void *, ptr2)
	 ),

	 TP_fast_assign(
		__entry->func = func;
		__entry->evt = evt;
		__entry->uint1 = uint1;
		__entry->uint2 = uint2;
		__entry->ulong1 = ulong1;
		__entry->ulong2 = ulong2;
		__entry->ptr1 = ptr1;
		__entry->ptr2 = ptr2;
	 ),


TP_printk("fun:%u ev:%u u1:%u u2:%u ul1:%llu ul2:%llu p1:0x%pK p2:0x%pK",
);
	  __entry->func, __entry->evt,
	  __entry->uint1, __entry->uint2,
	  __entry->ulong1, __entry->ulong2,
	  __entry->ptr1, __entry->ptr2)
)


TRACE_EVENT
DEFINE_EVENT
	(rmnet_shs_high,
	(rmnet_mod_template, rmnet_shs_high,


	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),


	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2),
	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2)


	 TP_STRUCT__entry(
);
		__field(u8, func)
		__field(u8, evt)
		__field(u32, uint1)
		__field(u32, uint2)
		__field(u64, ulong1)
		__field(u64, ulong2)
		__field(void *, ptr1)
		__field(void *, ptr2)
	 ),


	 TP_fast_assign(
DEFINE_EVENT
		__entry->func = func;
	(rmnet_mod_template, rmnet_shs_err,
		__entry->evt = evt;
		__entry->uint1 = uint1;
		__entry->uint2 = uint2;
		__entry->ulong1 = ulong1;
		__entry->ulong2 = ulong2;
		__entry->ptr1 = ptr1;
		__entry->ptr2 = ptr2;
	 ),


TP_printk("fun:%u ev:%u u1:%u u2:%u ul1:%llu ul2:%llu p1:0x%pK p2:0x%pK",
	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
	  __entry->func, __entry->evt,
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),
	  __entry->uint1, __entry->uint2,
	  __entry->ulong1, __entry->ulong2,
	  __entry->ptr1, __entry->ptr2)
)


TRACE_EVENT
	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2)
	(rmnet_shs_err,

);

DEFINE_EVENT
	(rmnet_mod_template, rmnet_shs_wq_low,


	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),


	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2),
	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2)


	 TP_STRUCT__entry(
);
		__field(u8, func)
		__field(u8, evt)
		__field(u32, uint1)
		__field(u32, uint2)
		__field(u64, ulong1)
		__field(u64, ulong2)
		__field(void *, ptr1)
		__field(void *, ptr2)
	 ),


	 TP_fast_assign(
DEFINE_EVENT
		__entry->func = func;
	(rmnet_mod_template, rmnet_shs_wq_high,
		__entry->evt = evt;
		__entry->uint1 = uint1;
		__entry->uint2 = uint2;
		__entry->ulong1 = ulong1;
		__entry->ulong2 = ulong2;
		__entry->ptr1 = ptr1;
		__entry->ptr2 = ptr2;
	 ),


TP_printk("fun:%u ev:%u u1:%u u2:%u ul1:%llu ul2:%llu p1:0x%pK p2:0x%pK",
	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
	  __entry->func, __entry->evt,
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),
	  __entry->uint1, __entry->uint2,
	  __entry->ulong1, __entry->ulong2,
	  __entry->ptr1, __entry->ptr2)
)


TRACE_EVENT
	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2)
	(rmnet_shs_wq_low,

);

DEFINE_EVENT
	(rmnet_mod_template, rmnet_shs_wq_err,


	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),


	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2),
	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2)

);

DECLARE_EVENT_CLASS
	(rmnet_freq_template,

	 TP_PROTO(u8 core, u32 newfreq),

	 TP_ARGS(core, newfreq),


	 TP_STRUCT__entry(
	 TP_STRUCT__entry(
		__field(u8, func)
		__field(u8, core)
		__field(u8, evt)
		__field(u32, newfreq)
		__field(u32, uint1)
		__field(u32, uint2)
		__field(u64, ulong1)
		__field(u64, ulong2)
		__field(void *, ptr1)
		__field(void *, ptr2)
	 ),
	 ),


	 TP_fast_assign(
	 TP_fast_assign(
		__entry->func = func;
		__entry->core = core;
		__entry->evt = evt;
		__entry->newfreq = newfreq;
		__entry->uint1 = uint1;

		__entry->uint2 = uint2;
		__entry->ulong1 = ulong1;
		__entry->ulong2 = ulong2;
		__entry->ptr1 = ptr1;
		__entry->ptr2 = ptr2;
	 ),
	 ),


TP_printk("fun:%u ev:%u u1:%u u2:%u ul1:%llu ul2:%llu p1:0x%pK p2:0x%pK",
TP_printk("freq policy core:%u freq floor :%u",
	  __entry->func, __entry->evt,
	  __entry->core, __entry->newfreq)
	  __entry->uint1, __entry->uint2,
	  __entry->ulong1, __entry->ulong2,
	  __entry->ptr1, __entry->ptr2)
)


TRACE_EVENT
);
	(rmnet_shs_wq_high,


	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
DEFINE_EVENT
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),
	(rmnet_freq_template, rmnet_freq_boost,


	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2),
	 TP_PROTO(u8 core, u32 newfreq),


	 TP_STRUCT__entry(
	 TP_ARGS(core, newfreq)
		__field(u8, func)
);
		__field(u8, evt)
		__field(u32, uint1)
		__field(u32, uint2)
		__field(u64, ulong1)
		__field(u64, ulong2)
		__field(void *, ptr1)
		__field(void *, ptr2)
	 ),


	 TP_fast_assign(
DEFINE_EVENT
		__entry->func = func;
	(rmnet_freq_template, rmnet_freq_reset,
		__entry->evt = evt;
		__entry->uint1 = uint1;
		__entry->uint2 = uint2;
		__entry->ulong1 = ulong1;
		__entry->ulong2 = ulong2;
		__entry->ptr1 = ptr1;
		__entry->ptr2 = ptr2;
	 ),


TP_printk("fun:%u ev:%u u1:%u u2:%u ul1:%llu ul2:%llu p1:0x%pK p2:0x%pK",
	 TP_PROTO(u8 core, u32 newfreq),
	  __entry->func, __entry->evt,

	  __entry->uint1, __entry->uint2,
	 TP_ARGS(core, newfreq)
	  __entry->ulong1, __entry->ulong2,
);
	  __entry->ptr1, __entry->ptr2)
)


TRACE_EVENT
TRACE_EVENT
	(rmnet_shs_wq_err,
	(rmnet_freq_update,


	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
	 TP_PROTO(u8 core, u32 lowfreq, u32 highfreq),
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),


	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2),
	 TP_ARGS(core, lowfreq, highfreq),


	 TP_STRUCT__entry(
	 TP_STRUCT__entry(
		__field(u8, func)
		__field(u8, core)
		__field(u8, evt)
		__field(u32, lowfreq)
		__field(u32, uint1)
		__field(u32, highfreq)
		__field(u32, uint2)
		__field(u64, ulong1)
		__field(u64, ulong2)
		__field(void *, ptr1)
		__field(void *, ptr2)
	 ),
	 ),


	 TP_fast_assign(
	 TP_fast_assign(
		__entry->func = func;
		__entry->core = core;
		__entry->evt = evt;
		__entry->lowfreq = lowfreq;
		__entry->uint1 = uint1;
		__entry->highfreq = highfreq;
		__entry->uint2 = uint2;

		__entry->ulong1 = ulong1;
		__entry->ulong2 = ulong2;
		__entry->ptr1 = ptr1;
		__entry->ptr2 = ptr2;
	 ),
	 ),


TP_printk("fun:%u ev:%u u1:%u u2:%u ul1:%llu ul2:%llu p1:0x%pK p2:0x%pK",
TP_printk("freq policy update core:%u policy freq floor :%u freq ceil :%u",
	  __entry->func, __entry->evt,
	  __entry->core, __entry->lowfreq, __entry->highfreq)
	  __entry->uint1, __entry->uint2,
);
	  __entry->ulong1, __entry->ulong2,
	  __entry->ptr1, __entry->ptr2)
)
#endif /* _RMNET_TRACE_H_ */
#endif /* _RMNET_TRACE_H_ */


/* This part must be outside protection */
/* This part must be outside protection */