|
@@ -0,0 +1,64 @@
|
|
|
+#undef TRACE_SYSTEM
|
|
|
+#define TRACE_SYSTEM asoc
|
|
|
+
|
|
|
+#if !defined(_TRACE_ASOC_H) || defined(TRACE_HEADER_MULTI_READ)
|
|
|
+#define _TRACE_ASOC_H
|
|
|
+
|
|
|
+#include <linux/ktime.h>
|
|
|
+#include <linux/tracepoint.h>
|
|
|
+
|
|
|
+struct snd_soc_codec;
|
|
|
+
|
|
|
+/*
|
|
|
+ * Log register events
|
|
|
+ */
|
|
|
+DECLARE_EVENT_CLASS(snd_soc_reg,
|
|
|
+
|
|
|
+ TP_PROTO(struct snd_soc_codec *codec, unsigned int reg,
|
|
|
+ unsigned int val),
|
|
|
+
|
|
|
+ TP_ARGS(codec, reg, val),
|
|
|
+
|
|
|
+ TP_STRUCT__entry(
|
|
|
+ __string( name, codec->name )
|
|
|
+ __field( int, id )
|
|
|
+ __field( unsigned int, reg )
|
|
|
+ __field( unsigned int, val )
|
|
|
+ ),
|
|
|
+
|
|
|
+ TP_fast_assign(
|
|
|
+ __assign_str(name, codec->name);
|
|
|
+ __entry->id = codec->id;
|
|
|
+ __entry->reg = reg;
|
|
|
+ __entry->val = val;
|
|
|
+ ),
|
|
|
+
|
|
|
+ TP_printk("codec=%s.%d reg=%x val=%x", __get_str(name),
|
|
|
+ (int)__entry->id, (unsigned int)__entry->reg,
|
|
|
+ (unsigned int)__entry->val)
|
|
|
+);
|
|
|
+
|
|
|
+DEFINE_EVENT(snd_soc_reg, snd_soc_reg_write,
|
|
|
+
|
|
|
+ TP_PROTO(struct snd_soc_codec *codec, unsigned int reg,
|
|
|
+ unsigned int val),
|
|
|
+
|
|
|
+ TP_ARGS(codec, reg, val)
|
|
|
+
|
|
|
+);
|
|
|
+
|
|
|
+DEFINE_EVENT(snd_soc_reg, snd_soc_reg_read,
|
|
|
+
|
|
|
+ TP_PROTO(struct snd_soc_codec *codec, unsigned int reg,
|
|
|
+ unsigned int val),
|
|
|
+
|
|
|
+ TP_ARGS(codec, reg, val)
|
|
|
+
|
|
|
+);
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+#endif /* _TRACE_ASOC_H */
|
|
|
+
|
|
|
+/* This part must be outside protection */
|
|
|
+#include <trace/define_trace.h>
|