spi-mem.h 2.9 KB

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