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