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 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)
);

TRACE_EVENT(rmnet_low,
DECLARE_EVENT_CLASS
	(rmnet_mod_template,

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

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

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

	TP_fast_assign(
		__entry->func = func;
	 TP_fast_assign(__entry->func = func;
			__entry->evt = evt;
			__entry->uint1 = uint1;
			__entry->uint2 = uint2;
@@ -70,410 +69,185 @@ TRACE_EVENT(rmnet_low,
	  __entry->uint1, __entry->uint2,
	  __entry->ulong1, __entry->ulong2,
	  __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,
		  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,
		  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;
	),
DEFINE_EVENT
	(rmnet_mod_template, rmnet_err,

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

	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, 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_EVENT(rmnet_perf_low,
DEFINE_EVENT
	(rmnet_mod_template, rmnet_perf_low,

	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
		  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(
		__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_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, 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,
		  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,
		  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_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, 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_EVENT(rmnet_shs_low,
DEFINE_EVENT
	(rmnet_mod_template, rmnet_shs_low,

	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
		  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)
	),
DEFINE_EVENT
	(rmnet_mod_template, rmnet_shs_high,

	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_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
		  u64 ulong1, u64 ulong2, void *ptr1, void *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)
	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2)
);

TRACE_EVENT(rmnet_shs_high,
DEFINE_EVENT
	(rmnet_mod_template, rmnet_shs_err,

	 TP_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
		  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)
	),
DEFINE_EVENT
	(rmnet_mod_template, rmnet_shs_wq_low,

	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_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
		  u64 ulong1, u64 ulong2, void *ptr1, void *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)
	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, 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,
		  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)
	),
DEFINE_EVENT
	(rmnet_mod_template, rmnet_shs_wq_err,

	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_PROTO(u8 func, u8 evt, u32 uint1, u32 uint2,
		  u64 ulong1, u64 ulong2, void *ptr1, void *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)
	 TP_ARGS(func, evt, uint1, uint2, ulong1, ulong2, ptr1, ptr2)
);

TRACE_EVENT(rmnet_shs_wq_low,
DECLARE_EVENT_CLASS
	(rmnet_freq_template,

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

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

	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_STRUCT__entry(__field(u8, core)
			  __field(u32, newfreq)
	 ),

	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_fast_assign(__entry->core = core;
			__entry->newfreq = newfreq;
	 ),

	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)
TP_printk("freq policy core:%u freq floor :%u",
	  __entry->core, __entry->newfreq)

);

TRACE_EVENT(rmnet_shs_wq_high,
DEFINE_EVENT
	(rmnet_freq_template, rmnet_freq_boost,

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

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

	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)
	),
DEFINE_EVENT
	(rmnet_freq_template, rmnet_freq_reset,

	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_PROTO(u8 core, u32 newfreq),

	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)
	 TP_ARGS(core, newfreq)
);

TRACE_EVENT(rmnet_shs_wq_err,
TRACE_EVENT
	(rmnet_freq_update,

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

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

	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_STRUCT__entry(__field(u8, core)
			  __field(u32, lowfreq)
			  __field(u32, highfreq)
	 ),

	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_fast_assign(__entry->core = core;
			__entry->lowfreq = lowfreq;
			__entry->highfreq = highfreq;

	 ),

	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)
TP_printk("freq policy update core:%u policy freq floor :%u freq ceil :%u",
	  __entry->core, __entry->lowfreq, __entry->highfreq)
);

#endif /* _TRACE_RMNET_H */

#include <trace/define_trace.h>