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

Commit 0d9c51a4 authored by Subash Abhinov Kasiviswanathan's avatar Subash Abhinov Kasiviswanathan Committed by Gerrit - the friendly Code Review server
Browse files

rmnet: Add rmnet_shs freq traces



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

Refactor existing rmnet_traces to use event class.

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 e59d2258
Loading
Loading
Loading
Loading
+137 −363
Original line number Original line Diff line number Diff line
@@ -36,15 +36,15 @@ TRACE_EVENT(rmnet_xmit_skb,
	TP_printk("dev_name=%s len=%u", __get_str(dev_name), __entry->len)
	TP_printk("dev_name=%s len=%u", __get_str(dev_name), __entry->len)
);
);


TRACE_EVENT(rmnet_low,
DECLARE_EVENT_CLASS
	(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),


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


	TP_STRUCT__entry(
	 TP_STRUCT__entry(__field(u8, func)
		__field(u8, func)
			  __field(u8, evt)
			  __field(u8, evt)
			  __field(u32, uint1)
			  __field(u32, uint1)
			  __field(u32, uint2)
			  __field(u32, uint2)
@@ -54,8 +54,7 @@ TRACE_EVENT(rmnet_low,
			  __field(void *, ptr2)
			  __field(void *, ptr2)
	 ),
	 ),


	TP_fast_assign(
	 TP_fast_assign(__entry->func = func;
		__entry->func = func;
			__entry->evt = evt;
			__entry->evt = evt;
			__entry->uint1 = uint1;
			__entry->uint1 = uint1;
			__entry->uint2 = uint2;
			__entry->uint2 = uint2;
@@ -70,410 +69,185 @@ TRACE_EVENT(rmnet_low,
	  __entry->uint1, __entry->uint2,
	  __entry->uint1, __entry->uint2,
	  __entry->ulong1, __entry->ulong2,
	  __entry->ulong1, __entry->ulong2,
	  __entry->ptr1, __entry->ptr2)
	  __entry->ptr1, __entry->ptr2)
);
)


TRACE_EVENT(rmnet_high,
DEFINE_EVENT
	(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(
		__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(rmnet_err,
DEFINE_EVENT
	(rmnet_mod_template, rmnet_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_err,
		__entry->evt = evt;

		__entry->uint1 = uint1;
	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
		__entry->uint2 = uint2;
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),
		__entry->ulong1 = ulong1;

		__entry->ulong2 = ulong2;
	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2)
		__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(rmnet_perf_low,
DEFINE_EVENT
	(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(
		__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(rmnet_perf_high,
DEFINE_EVENT
	(rmnet_mod_template, 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(
		__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(rmnet_perf_err,
DEFINE_EVENT
	(rmnet_mod_template, 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(rmnet_shs_low,
DEFINE_EVENT
	(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, ulong1, ulong2, ptr1, ptr2),
	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2)
);


	TP_STRUCT__entry(
DEFINE_EVENT
		__field(u8, func)
	(rmnet_mod_template, rmnet_shs_high,
		__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_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
		__entry->func = func;
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),
		__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_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2)
		  __entry->func, __entry->evt,
		  __entry->uint1, __entry->uint2,
		  __entry->ulong1, __entry->ulong2,
		  __entry->ptr1, __entry->ptr2)
);
);


TRACE_EVENT(rmnet_shs_high,
DEFINE_EVENT
	(rmnet_mod_template, rmnet_shs_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(
DEFINE_EVENT
		__field(u8, func)
	(rmnet_mod_template, rmnet_shs_wq_low,
		__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_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
		__entry->func = func;
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),
		__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_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2)
		  __entry->func, __entry->evt,
		  __entry->uint1, __entry->uint2,
		  __entry->ulong1, __entry->ulong2,
		  __entry->ptr1, __entry->ptr2)
);
);


TRACE_EVENT(rmnet_shs_err,
DEFINE_EVENT
	(rmnet_mod_template, rmnet_shs_wq_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(
DEFINE_EVENT
		__field(u8, func)
	(rmnet_mod_template, rmnet_shs_wq_err,
		__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_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
		__entry->func = func;
		  u64 ulong1, u64 ulong2, void *ptr1, void *ptr2),
		__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_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2)
		  __entry->func, __entry->evt,
		  __entry->uint1, __entry->uint2,
		  __entry->ulong1, __entry->ulong2,
		  __entry->ptr1, __entry->ptr2)
);
);


TRACE_EVENT(rmnet_shs_wq_low,
DECLARE_EVENT_CLASS
	(rmnet_freq_template,


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


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


	TP_STRUCT__entry(
	 TP_STRUCT__entry(__field(u8, core)
		__field(u8, func)
			  __field(u32, newfreq)
		__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_fast_assign(__entry->core = core;
		__entry->func = func;
			__entry->newfreq = newfreq;
		__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_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,
DEFINE_EVENT
	(rmnet_freq_template, rmnet_freq_boost,


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


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


	TP_STRUCT__entry(
DEFINE_EVENT
		__field(u8, func)
	(rmnet_freq_template, rmnet_freq_reset,
		__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_PROTO(u8 core, u32 newfreq),
		__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",
	 TP_ARGS(core, newfreq)
		  __entry->func, __entry->evt,
		  __entry->uint1, __entry->uint2,
		  __entry->ulong1, __entry->ulong2,
		  __entry->ptr1, __entry->ptr2)
);
);


TRACE_EVENT(rmnet_shs_wq_err,
TRACE_EVENT
	(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, core)
		__field(u8, func)
			  __field(u32, lowfreq)
		__field(u8, evt)
			  __field(u32, highfreq)
		__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->core = core;
		__entry->func = func;
			__entry->lowfreq = lowfreq;
		__entry->evt = evt;
			__entry->highfreq = highfreq;
		__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 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 /* _TRACE_RMNET_H */
#endif /* _TRACE_RMNET_H */


#include <trace/define_trace.h>
#include <trace/define_trace.h>