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