|
@@ -0,0 +1,150 @@
|
|
|
+/* I2C message transfer tracepoints
|
|
|
+ *
|
|
|
+ * Copyright (C) 2013 Red Hat, Inc. All Rights Reserved.
|
|
|
+ * Written by David Howells (dhowells@redhat.com)
|
|
|
+ *
|
|
|
+ * This program is free software; you can redistribute it and/or
|
|
|
+ * modify it under the terms of the GNU General Public Licence
|
|
|
+ * as published by the Free Software Foundation; either version
|
|
|
+ * 2 of the Licence, or (at your option) any later version.
|
|
|
+ */
|
|
|
+#undef TRACE_SYSTEM
|
|
|
+#define TRACE_SYSTEM i2c
|
|
|
+
|
|
|
+#if !defined(_TRACE_I2C_H) || defined(TRACE_HEADER_MULTI_READ)
|
|
|
+#define _TRACE_I2C_H
|
|
|
+
|
|
|
+#include <linux/i2c.h>
|
|
|
+#include <linux/tracepoint.h>
|
|
|
+
|
|
|
+/*
|
|
|
+ * drivers/i2c/i2c-core.c
|
|
|
+ */
|
|
|
+extern void i2c_transfer_trace_reg(void);
|
|
|
+extern void i2c_transfer_trace_unreg(void);
|
|
|
+
|
|
|
+/*
|
|
|
+ * __i2c_transfer() write request
|
|
|
+ */
|
|
|
+TRACE_EVENT_FN(i2c_write,
|
|
|
+ TP_PROTO(const struct i2c_adapter *adap, const struct i2c_msg *msg,
|
|
|
+ int num),
|
|
|
+ TP_ARGS(adap, msg, num),
|
|
|
+ TP_STRUCT__entry(
|
|
|
+ __field(int, adapter_nr )
|
|
|
+ __field(__u16, msg_nr )
|
|
|
+ __field(__u16, addr )
|
|
|
+ __field(__u16, flags )
|
|
|
+ __field(__u16, len )
|
|
|
+ __dynamic_array(__u8, buf, msg->len) ),
|
|
|
+ TP_fast_assign(
|
|
|
+ __entry->adapter_nr = adap->nr;
|
|
|
+ __entry->msg_nr = num;
|
|
|
+ __entry->addr = msg->addr;
|
|
|
+ __entry->flags = msg->flags;
|
|
|
+ __entry->len = msg->len;
|
|
|
+ memcpy(__get_dynamic_array(buf), msg->buf, msg->len);
|
|
|
+ ),
|
|
|
+ TP_printk("i2c-%d #%u a=%03x f=%04x l=%u [%*phD]",
|
|
|
+ __entry->adapter_nr,
|
|
|
+ __entry->msg_nr,
|
|
|
+ __entry->addr,
|
|
|
+ __entry->flags,
|
|
|
+ __entry->len,
|
|
|
+ __entry->len, __get_dynamic_array(buf)
|
|
|
+ ),
|
|
|
+ i2c_transfer_trace_reg,
|
|
|
+ i2c_transfer_trace_unreg);
|
|
|
+
|
|
|
+/*
|
|
|
+ * __i2c_transfer() read request
|
|
|
+ */
|
|
|
+TRACE_EVENT_FN(i2c_read,
|
|
|
+ TP_PROTO(const struct i2c_adapter *adap, const struct i2c_msg *msg,
|
|
|
+ int num),
|
|
|
+ TP_ARGS(adap, msg, num),
|
|
|
+ TP_STRUCT__entry(
|
|
|
+ __field(int, adapter_nr )
|
|
|
+ __field(__u16, msg_nr )
|
|
|
+ __field(__u16, addr )
|
|
|
+ __field(__u16, flags )
|
|
|
+ __field(__u16, len )
|
|
|
+ ),
|
|
|
+ TP_fast_assign(
|
|
|
+ __entry->adapter_nr = adap->nr;
|
|
|
+ __entry->msg_nr = num;
|
|
|
+ __entry->addr = msg->addr;
|
|
|
+ __entry->flags = msg->flags;
|
|
|
+ __entry->len = msg->len;
|
|
|
+ ),
|
|
|
+ TP_printk("i2c-%d #%u a=%03x f=%04x l=%u",
|
|
|
+ __entry->adapter_nr,
|
|
|
+ __entry->msg_nr,
|
|
|
+ __entry->addr,
|
|
|
+ __entry->flags,
|
|
|
+ __entry->len
|
|
|
+ ),
|
|
|
+ i2c_transfer_trace_reg,
|
|
|
+ i2c_transfer_trace_unreg);
|
|
|
+
|
|
|
+/*
|
|
|
+ * __i2c_transfer() read reply
|
|
|
+ */
|
|
|
+TRACE_EVENT_FN(i2c_reply,
|
|
|
+ TP_PROTO(const struct i2c_adapter *adap, const struct i2c_msg *msg,
|
|
|
+ int num),
|
|
|
+ TP_ARGS(adap, msg, num),
|
|
|
+ TP_STRUCT__entry(
|
|
|
+ __field(int, adapter_nr )
|
|
|
+ __field(__u16, msg_nr )
|
|
|
+ __field(__u16, addr )
|
|
|
+ __field(__u16, flags )
|
|
|
+ __field(__u16, len )
|
|
|
+ __dynamic_array(__u8, buf, msg->len) ),
|
|
|
+ TP_fast_assign(
|
|
|
+ __entry->adapter_nr = adap->nr;
|
|
|
+ __entry->msg_nr = num;
|
|
|
+ __entry->addr = msg->addr;
|
|
|
+ __entry->flags = msg->flags;
|
|
|
+ __entry->len = msg->len;
|
|
|
+ memcpy(__get_dynamic_array(buf), msg->buf, msg->len);
|
|
|
+ ),
|
|
|
+ TP_printk("i2c-%d #%u a=%03x f=%04x l=%u [%*phD]",
|
|
|
+ __entry->adapter_nr,
|
|
|
+ __entry->msg_nr,
|
|
|
+ __entry->addr,
|
|
|
+ __entry->flags,
|
|
|
+ __entry->len,
|
|
|
+ __entry->len, __get_dynamic_array(buf)
|
|
|
+ ),
|
|
|
+ i2c_transfer_trace_reg,
|
|
|
+ i2c_transfer_trace_unreg);
|
|
|
+
|
|
|
+/*
|
|
|
+ * __i2c_transfer() result
|
|
|
+ */
|
|
|
+TRACE_EVENT_FN(i2c_result,
|
|
|
+ TP_PROTO(const struct i2c_adapter *adap, int num, int ret),
|
|
|
+ TP_ARGS(adap, num, ret),
|
|
|
+ TP_STRUCT__entry(
|
|
|
+ __field(int, adapter_nr )
|
|
|
+ __field(__u16, nr_msgs )
|
|
|
+ __field(__s16, ret )
|
|
|
+ ),
|
|
|
+ TP_fast_assign(
|
|
|
+ __entry->adapter_nr = adap->nr;
|
|
|
+ __entry->nr_msgs = num;
|
|
|
+ __entry->ret = ret;
|
|
|
+ ),
|
|
|
+ TP_printk("i2c-%d n=%u ret=%d",
|
|
|
+ __entry->adapter_nr,
|
|
|
+ __entry->nr_msgs,
|
|
|
+ __entry->ret
|
|
|
+ ),
|
|
|
+ i2c_transfer_trace_reg,
|
|
|
+ i2c_transfer_trace_unreg);
|
|
|
+
|
|
|
+#endif /* _TRACE_I2C_H */
|
|
|
+
|
|
|
+/* This part must be outside protection */
|
|
|
+#include <trace/define_trace.h>
|