|
@@ -5,6 +5,7 @@
|
|
|
#define _TRACE_POWER_H
|
|
|
|
|
|
#include <linux/ktime.h>
|
|
|
+#include <linux/pm_qos.h>
|
|
|
#include <linux/tracepoint.h>
|
|
|
|
|
|
DECLARE_EVENT_CLASS(cpu,
|
|
@@ -177,6 +178,178 @@ DEFINE_EVENT(power_domain, power_domain_target,
|
|
|
|
|
|
TP_ARGS(name, state, cpu_id)
|
|
|
);
|
|
|
+
|
|
|
+/*
|
|
|
+ * The pm qos events are used for pm qos update
|
|
|
+ */
|
|
|
+DECLARE_EVENT_CLASS(pm_qos_request,
|
|
|
+
|
|
|
+ TP_PROTO(int pm_qos_class, s32 value),
|
|
|
+
|
|
|
+ TP_ARGS(pm_qos_class, value),
|
|
|
+
|
|
|
+ TP_STRUCT__entry(
|
|
|
+ __field( int, pm_qos_class )
|
|
|
+ __field( s32, value )
|
|
|
+ ),
|
|
|
+
|
|
|
+ TP_fast_assign(
|
|
|
+ __entry->pm_qos_class = pm_qos_class;
|
|
|
+ __entry->value = value;
|
|
|
+ ),
|
|
|
+
|
|
|
+ TP_printk("pm_qos_class=%s value=%d",
|
|
|
+ __print_symbolic(__entry->pm_qos_class,
|
|
|
+ { PM_QOS_CPU_DMA_LATENCY, "CPU_DMA_LATENCY" },
|
|
|
+ { PM_QOS_NETWORK_LATENCY, "NETWORK_LATENCY" },
|
|
|
+ { PM_QOS_NETWORK_THROUGHPUT, "NETWORK_THROUGHPUT" }),
|
|
|
+ __entry->value)
|
|
|
+);
|
|
|
+
|
|
|
+DEFINE_EVENT(pm_qos_request, pm_qos_add_request,
|
|
|
+
|
|
|
+ TP_PROTO(int pm_qos_class, s32 value),
|
|
|
+
|
|
|
+ TP_ARGS(pm_qos_class, value)
|
|
|
+);
|
|
|
+
|
|
|
+DEFINE_EVENT(pm_qos_request, pm_qos_update_request,
|
|
|
+
|
|
|
+ TP_PROTO(int pm_qos_class, s32 value),
|
|
|
+
|
|
|
+ TP_ARGS(pm_qos_class, value)
|
|
|
+);
|
|
|
+
|
|
|
+DEFINE_EVENT(pm_qos_request, pm_qos_remove_request,
|
|
|
+
|
|
|
+ TP_PROTO(int pm_qos_class, s32 value),
|
|
|
+
|
|
|
+ TP_ARGS(pm_qos_class, value)
|
|
|
+);
|
|
|
+
|
|
|
+TRACE_EVENT(pm_qos_update_request_timeout,
|
|
|
+
|
|
|
+ TP_PROTO(int pm_qos_class, s32 value, unsigned long timeout_us),
|
|
|
+
|
|
|
+ TP_ARGS(pm_qos_class, value, timeout_us),
|
|
|
+
|
|
|
+ TP_STRUCT__entry(
|
|
|
+ __field( int, pm_qos_class )
|
|
|
+ __field( s32, value )
|
|
|
+ __field( unsigned long, timeout_us )
|
|
|
+ ),
|
|
|
+
|
|
|
+ TP_fast_assign(
|
|
|
+ __entry->pm_qos_class = pm_qos_class;
|
|
|
+ __entry->value = value;
|
|
|
+ __entry->timeout_us = timeout_us;
|
|
|
+ ),
|
|
|
+
|
|
|
+ TP_printk("pm_qos_class=%s value=%d, timeout_us=%ld",
|
|
|
+ __print_symbolic(__entry->pm_qos_class,
|
|
|
+ { PM_QOS_CPU_DMA_LATENCY, "CPU_DMA_LATENCY" },
|
|
|
+ { PM_QOS_NETWORK_LATENCY, "NETWORK_LATENCY" },
|
|
|
+ { PM_QOS_NETWORK_THROUGHPUT, "NETWORK_THROUGHPUT" }),
|
|
|
+ __entry->value, __entry->timeout_us)
|
|
|
+);
|
|
|
+
|
|
|
+DECLARE_EVENT_CLASS(pm_qos_update,
|
|
|
+
|
|
|
+ TP_PROTO(enum pm_qos_req_action action, int prev_value, int curr_value),
|
|
|
+
|
|
|
+ TP_ARGS(action, prev_value, curr_value),
|
|
|
+
|
|
|
+ TP_STRUCT__entry(
|
|
|
+ __field( enum pm_qos_req_action, action )
|
|
|
+ __field( int, prev_value )
|
|
|
+ __field( int, curr_value )
|
|
|
+ ),
|
|
|
+
|
|
|
+ TP_fast_assign(
|
|
|
+ __entry->action = action;
|
|
|
+ __entry->prev_value = prev_value;
|
|
|
+ __entry->curr_value = curr_value;
|
|
|
+ ),
|
|
|
+
|
|
|
+ TP_printk("action=%s prev_value=%d curr_value=%d",
|
|
|
+ __print_symbolic(__entry->action,
|
|
|
+ { PM_QOS_ADD_REQ, "ADD_REQ" },
|
|
|
+ { PM_QOS_UPDATE_REQ, "UPDATE_REQ" },
|
|
|
+ { PM_QOS_REMOVE_REQ, "REMOVE_REQ" }),
|
|
|
+ __entry->prev_value, __entry->curr_value)
|
|
|
+);
|
|
|
+
|
|
|
+DEFINE_EVENT(pm_qos_update, pm_qos_update_target,
|
|
|
+
|
|
|
+ TP_PROTO(enum pm_qos_req_action action, int prev_value, int curr_value),
|
|
|
+
|
|
|
+ TP_ARGS(action, prev_value, curr_value)
|
|
|
+);
|
|
|
+
|
|
|
+DEFINE_EVENT_PRINT(pm_qos_update, pm_qos_update_flags,
|
|
|
+
|
|
|
+ TP_PROTO(enum pm_qos_req_action action, int prev_value, int curr_value),
|
|
|
+
|
|
|
+ TP_ARGS(action, prev_value, curr_value),
|
|
|
+
|
|
|
+ TP_printk("action=%s prev_value=0x%x curr_value=0x%x",
|
|
|
+ __print_symbolic(__entry->action,
|
|
|
+ { PM_QOS_ADD_REQ, "ADD_REQ" },
|
|
|
+ { PM_QOS_UPDATE_REQ, "UPDATE_REQ" },
|
|
|
+ { PM_QOS_REMOVE_REQ, "REMOVE_REQ" }),
|
|
|
+ __entry->prev_value, __entry->curr_value)
|
|
|
+);
|
|
|
+
|
|
|
+DECLARE_EVENT_CLASS(dev_pm_qos_request,
|
|
|
+
|
|
|
+ TP_PROTO(const char *name, enum dev_pm_qos_req_type type,
|
|
|
+ s32 new_value),
|
|
|
+
|
|
|
+ TP_ARGS(name, type, new_value),
|
|
|
+
|
|
|
+ TP_STRUCT__entry(
|
|
|
+ __string( name, name )
|
|
|
+ __field( enum dev_pm_qos_req_type, type )
|
|
|
+ __field( s32, new_value )
|
|
|
+ ),
|
|
|
+
|
|
|
+ TP_fast_assign(
|
|
|
+ __assign_str(name, name);
|
|
|
+ __entry->type = type;
|
|
|
+ __entry->new_value = new_value;
|
|
|
+ ),
|
|
|
+
|
|
|
+ TP_printk("device=%s type=%s new_value=%d",
|
|
|
+ __get_str(name),
|
|
|
+ __print_symbolic(__entry->type,
|
|
|
+ { DEV_PM_QOS_LATENCY, "DEV_PM_QOS_LATENCY" },
|
|
|
+ { DEV_PM_QOS_FLAGS, "DEV_PM_QOS_FLAGS" }),
|
|
|
+ __entry->new_value)
|
|
|
+);
|
|
|
+
|
|
|
+DEFINE_EVENT(dev_pm_qos_request, dev_pm_qos_add_request,
|
|
|
+
|
|
|
+ TP_PROTO(const char *name, enum dev_pm_qos_req_type type,
|
|
|
+ s32 new_value),
|
|
|
+
|
|
|
+ TP_ARGS(name, type, new_value)
|
|
|
+);
|
|
|
+
|
|
|
+DEFINE_EVENT(dev_pm_qos_request, dev_pm_qos_update_request,
|
|
|
+
|
|
|
+ TP_PROTO(const char *name, enum dev_pm_qos_req_type type,
|
|
|
+ s32 new_value),
|
|
|
+
|
|
|
+ TP_ARGS(name, type, new_value)
|
|
|
+);
|
|
|
+
|
|
|
+DEFINE_EVENT(dev_pm_qos_request, dev_pm_qos_remove_request,
|
|
|
+
|
|
|
+ TP_PROTO(const char *name, enum dev_pm_qos_req_type type,
|
|
|
+ s32 new_value),
|
|
|
+
|
|
|
+ TP_ARGS(name, type, new_value)
|
|
|
+);
|
|
|
#endif /* _TRACE_POWER_H */
|
|
|
|
|
|
/* This part must be outside protection */
|