| /* SPDX-License-Identifier: GPL-2.0 */ | 
 | #undef TRACE_SYSTEM | 
 | #define TRACE_SYSTEM spmi | 
 |  | 
 | #if !defined(_TRACE_SPMI_H) || defined(TRACE_HEADER_MULTI_READ) | 
 | #define _TRACE_SPMI_H | 
 |  | 
 | #include <linux/spmi.h> | 
 | #include <linux/tracepoint.h> | 
 |  | 
 | /* | 
 |  * drivers/spmi/spmi.c | 
 |  */ | 
 |  | 
 | TRACE_EVENT(spmi_write_begin, | 
 | 	TP_PROTO(u8 opcode, u8 sid, u16 addr, u8 len, const u8 *buf), | 
 | 	TP_ARGS(opcode, sid, addr, len, buf), | 
 |  | 
 | 	TP_STRUCT__entry( | 
 | 		__field		( u8,         opcode    ) | 
 | 		__field		( u8,         sid       ) | 
 | 		__field		( u16,        addr      ) | 
 | 		__field		( u8,         len       ) | 
 | 		__dynamic_array	( u8,   buf,  len       ) | 
 | 	), | 
 |  | 
 | 	TP_fast_assign( | 
 | 		__entry->opcode = opcode; | 
 | 		__entry->sid    = sid; | 
 | 		__entry->addr   = addr; | 
 | 		__entry->len    = len; | 
 | 		memcpy(__get_dynamic_array(buf), buf, len); | 
 | 	), | 
 |  | 
 | 	TP_printk("opc=%d sid=%02d addr=0x%04x len=%d buf=0x[%*phD]", | 
 | 		  (int)__entry->opcode, (int)__entry->sid, | 
 | 		  (int)__entry->addr, (int)__entry->len, | 
 | 		  (int)__entry->len, __get_dynamic_array(buf)) | 
 | ); | 
 |  | 
 | TRACE_EVENT(spmi_write_end, | 
 | 	TP_PROTO(u8 opcode, u8 sid, u16 addr, int ret), | 
 | 	TP_ARGS(opcode, sid, addr, ret), | 
 |  | 
 | 	TP_STRUCT__entry( | 
 | 		__field		( u8,         opcode    ) | 
 | 		__field		( u8,         sid       ) | 
 | 		__field		( u16,        addr      ) | 
 | 		__field		( int,        ret       ) | 
 | 	), | 
 |  | 
 | 	TP_fast_assign( | 
 | 		__entry->opcode = opcode; | 
 | 		__entry->sid    = sid; | 
 | 		__entry->addr   = addr; | 
 | 		__entry->ret    = ret; | 
 | 	), | 
 |  | 
 | 	TP_printk("opc=%d sid=%02d addr=0x%04x ret=%d", | 
 | 		  (int)__entry->opcode, (int)__entry->sid, | 
 | 		  (int)__entry->addr, __entry->ret) | 
 | ); | 
 |  | 
 | TRACE_EVENT(spmi_read_begin, | 
 | 	TP_PROTO(u8 opcode, u8 sid, u16 addr), | 
 | 	TP_ARGS(opcode, sid, addr), | 
 |  | 
 | 	TP_STRUCT__entry( | 
 | 		__field		( u8,         opcode    ) | 
 | 		__field		( u8,         sid       ) | 
 | 		__field		( u16,        addr      ) | 
 | 	), | 
 |  | 
 | 	TP_fast_assign( | 
 | 		__entry->opcode = opcode; | 
 | 		__entry->sid    = sid; | 
 | 		__entry->addr   = addr; | 
 | 	), | 
 |  | 
 | 	TP_printk("opc=%d sid=%02d addr=0x%04x", | 
 | 		  (int)__entry->opcode, (int)__entry->sid, | 
 | 		  (int)__entry->addr) | 
 | ); | 
 |  | 
 | TRACE_EVENT(spmi_read_end, | 
 | 	TP_PROTO(u8 opcode, u8 sid, u16 addr, int ret, u8 len, const u8 *buf), | 
 | 	TP_ARGS(opcode, sid, addr, ret, len, buf), | 
 |  | 
 | 	TP_STRUCT__entry( | 
 | 		__field		( u8,         opcode    ) | 
 | 		__field		( u8,         sid       ) | 
 | 		__field		( u16,        addr      ) | 
 | 		__field		( int,        ret       ) | 
 | 		__field		( u8,         len       ) | 
 | 		__dynamic_array	( u8,   buf,  len       ) | 
 | 	), | 
 |  | 
 | 	TP_fast_assign( | 
 | 		__entry->opcode = opcode; | 
 | 		__entry->sid    = sid; | 
 | 		__entry->addr   = addr; | 
 | 		__entry->ret    = ret; | 
 | 		__entry->len    = len; | 
 | 		memcpy(__get_dynamic_array(buf), buf, len); | 
 | 	), | 
 |  | 
 | 	TP_printk("opc=%d sid=%02d addr=0x%04x ret=%d len=%02d buf=0x[%*phD]", | 
 | 		  (int)__entry->opcode, (int)__entry->sid, | 
 | 		  (int)__entry->addr, __entry->ret, (int)__entry->len, | 
 | 		  (int)__entry->len, __get_dynamic_array(buf)) | 
 | ); | 
 |  | 
 | TRACE_EVENT(spmi_cmd, | 
 | 	TP_PROTO(u8 opcode, u8 sid, int ret), | 
 | 	TP_ARGS(opcode, sid, ret), | 
 |  | 
 | 	TP_STRUCT__entry( | 
 | 		__field		( u8,         opcode    ) | 
 | 		__field		( u8,         sid       ) | 
 | 		__field		( int,        ret       ) | 
 | 	), | 
 |  | 
 | 	TP_fast_assign( | 
 | 		__entry->opcode = opcode; | 
 | 		__entry->sid    = sid; | 
 | 		__entry->ret    = ret; | 
 | 	), | 
 |  | 
 | 	TP_printk("opc=%d sid=%02d ret=%d", (int)__entry->opcode, | 
 | 		  (int)__entry->sid, ret) | 
 | ); | 
 |  | 
 | #endif /* _TRACE_SPMI_H */ | 
 |  | 
 | /* This part must be outside protection */ | 
 | #include <trace/define_trace.h> |