xref: /linux/include/trace/events/spi-mem.h (revision cc4adab164b772a34b3340d644b7c4728498581e)
1*77a58ba7SSean Anderson /* SPDX-License-Identifier: GPL-2.0 */
2*77a58ba7SSean Anderson #undef TRACE_SYSTEM
3*77a58ba7SSean Anderson #define TRACE_SYSTEM spi-mem
4*77a58ba7SSean Anderson 
5*77a58ba7SSean Anderson #undef TRACE_SYSTEM_VAR
6*77a58ba7SSean Anderson #define TRACE_SYSTEM_VAR spi_mem
7*77a58ba7SSean Anderson 
8*77a58ba7SSean Anderson #if !defined(_TRACE_SPI_MEM_H) || defined(TRACE_HEADER_MULTI_READ)
9*77a58ba7SSean Anderson #define _TRACE_SPI_MEM_H
10*77a58ba7SSean Anderson 
11*77a58ba7SSean Anderson #include <linux/tracepoint.h>
12*77a58ba7SSean Anderson #include <linux/spi/spi-mem.h>
13*77a58ba7SSean Anderson 
14*77a58ba7SSean Anderson #define decode_dtr(dtr) \
15*77a58ba7SSean Anderson 	__print_symbolic(dtr, \
16*77a58ba7SSean Anderson 		{ 0, "S" }, \
17*77a58ba7SSean Anderson 		{ 1, "D" })
18*77a58ba7SSean Anderson 
19*77a58ba7SSean Anderson TRACE_EVENT(spi_mem_start_op,
20*77a58ba7SSean Anderson 	TP_PROTO(struct spi_mem *mem, const struct spi_mem_op *op),
21*77a58ba7SSean Anderson 	TP_ARGS(mem, op),
22*77a58ba7SSean Anderson 
23*77a58ba7SSean Anderson 	TP_STRUCT__entry(
24*77a58ba7SSean Anderson 		__string(name, mem->name)
25*77a58ba7SSean Anderson 		__dynamic_array(u8, op, 1 + op->addr.nbytes + op->dummy.nbytes)
26*77a58ba7SSean Anderson 		__dynamic_array(u8, data, op->data.dir == SPI_MEM_DATA_OUT ?
27*77a58ba7SSean Anderson 					  min(op->data.nbytes, 64) : 0)
28*77a58ba7SSean Anderson 		__field(u32, data_len)
29*77a58ba7SSean Anderson 		__field(u32, max_freq)
30*77a58ba7SSean Anderson 		__field(u8, cmd_buswidth)
31*77a58ba7SSean Anderson 		__field(bool, cmd_dtr)
32*77a58ba7SSean Anderson 		__field(u8, addr_buswidth)
33*77a58ba7SSean Anderson 		__field(bool, addr_dtr)
34*77a58ba7SSean Anderson 		__field(u8, dummy_nbytes)
35*77a58ba7SSean Anderson 		__field(u8, data_buswidth)
36*77a58ba7SSean Anderson 		__field(bool, data_dtr)
37*77a58ba7SSean Anderson 	),
38*77a58ba7SSean Anderson 
39*77a58ba7SSean Anderson 	TP_fast_assign(
40*77a58ba7SSean Anderson 		int i;
41*77a58ba7SSean Anderson 
42*77a58ba7SSean Anderson 		__assign_str(name);
43*77a58ba7SSean Anderson 		__entry->max_freq = op->max_freq ?: mem->spi->max_speed_hz;
44*77a58ba7SSean Anderson 
45*77a58ba7SSean Anderson 		__entry->cmd_buswidth = op->cmd.buswidth;
46*77a58ba7SSean Anderson 		__entry->cmd_dtr = op->cmd.dtr;
47*77a58ba7SSean Anderson 		*((u8 *)__get_dynamic_array(op)) = op->cmd.opcode;
48*77a58ba7SSean Anderson 
49*77a58ba7SSean Anderson 		__entry->addr_buswidth = op->addr.buswidth;
50*77a58ba7SSean Anderson 		__entry->addr_dtr = op->addr.dtr;
51*77a58ba7SSean Anderson 		for (i = 0; i < op->addr.nbytes; i++)
52*77a58ba7SSean Anderson 			((u8 *)__get_dynamic_array(op))[i + 1] =
53*77a58ba7SSean Anderson 				op->addr.val >> (8 * (op->addr.nbytes - i - 1));
54*77a58ba7SSean Anderson 
55*77a58ba7SSean Anderson 		memset(((u8 *)__get_dynamic_array(op)) + op->addr.nbytes + 1,
56*77a58ba7SSean Anderson 		       0xff, op->dummy.nbytes);
57*77a58ba7SSean Anderson 
58*77a58ba7SSean Anderson 		__entry->data_len = op->data.nbytes;
59*77a58ba7SSean Anderson 		__entry->data_buswidth = op->data.buswidth;
60*77a58ba7SSean Anderson 		__entry->data_dtr = op->data.dtr;
61*77a58ba7SSean Anderson 		if (op->data.dir == SPI_MEM_DATA_OUT)
62*77a58ba7SSean Anderson 			memcpy(__get_dynamic_array(data), op->data.buf.out,
63*77a58ba7SSean Anderson 			       __get_dynamic_array_len(data));
64*77a58ba7SSean Anderson 	),
65*77a58ba7SSean Anderson 
66*77a58ba7SSean Anderson 	TP_printk("%s %u%s-%u%s-%u%s @%u Hz op=[%*phD] len=%u tx=[%*phD]",
67*77a58ba7SSean Anderson 		__get_str(name),
68*77a58ba7SSean Anderson 		__entry->cmd_buswidth, decode_dtr(__entry->cmd_dtr),
69*77a58ba7SSean Anderson 		__entry->addr_buswidth, decode_dtr(__entry->addr_dtr),
70*77a58ba7SSean Anderson 		__entry->data_buswidth, decode_dtr(__entry->data_dtr),
71*77a58ba7SSean Anderson 		__entry->max_freq,
72*77a58ba7SSean Anderson 		__get_dynamic_array_len(op), __get_dynamic_array(op),
73*77a58ba7SSean Anderson 		__entry->data_len,
74*77a58ba7SSean Anderson 		__get_dynamic_array_len(data), __get_dynamic_array(data))
75*77a58ba7SSean Anderson );
76*77a58ba7SSean Anderson 
77*77a58ba7SSean Anderson TRACE_EVENT(spi_mem_stop_op,
78*77a58ba7SSean Anderson 	TP_PROTO(struct spi_mem *mem, const struct spi_mem_op *op),
79*77a58ba7SSean Anderson 	TP_ARGS(mem, op),
80*77a58ba7SSean Anderson 
81*77a58ba7SSean Anderson 	TP_STRUCT__entry(
82*77a58ba7SSean Anderson 		__string(name, mem->name)
83*77a58ba7SSean Anderson 		__dynamic_array(u8, data, op->data.dir == SPI_MEM_DATA_IN ?
84*77a58ba7SSean Anderson 					  min(op->data.nbytes, 64) : 0)
85*77a58ba7SSean Anderson 		__field(u32, data_len)
86*77a58ba7SSean Anderson 	),
87*77a58ba7SSean Anderson 
88*77a58ba7SSean Anderson 	TP_fast_assign(
89*77a58ba7SSean Anderson 		__assign_str(name);
90*77a58ba7SSean Anderson 		__entry->data_len = op->data.nbytes;
91*77a58ba7SSean Anderson 		if (op->data.dir == SPI_MEM_DATA_IN)
92*77a58ba7SSean Anderson 			memcpy(__get_dynamic_array(data), op->data.buf.in,
93*77a58ba7SSean Anderson 			       __get_dynamic_array_len(data));
94*77a58ba7SSean Anderson 	),
95*77a58ba7SSean Anderson 
96*77a58ba7SSean Anderson 	TP_printk("%s len=%u rx=[%*phD]",
97*77a58ba7SSean Anderson 		__get_str(name),
98*77a58ba7SSean Anderson 		__entry->data_len,
99*77a58ba7SSean Anderson 		__get_dynamic_array_len(data), __get_dynamic_array(data))
100*77a58ba7SSean Anderson );
101*77a58ba7SSean Anderson 
102*77a58ba7SSean Anderson 
103*77a58ba7SSean Anderson #endif /* _TRACE_SPI_MEM_H */
104*77a58ba7SSean Anderson 
105*77a58ba7SSean Anderson /* This part must be outside protection */
106*77a58ba7SSean Anderson #include <trace/define_trace.h>
107