trace.h 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. /*
  2. * NVM Express device driver tracepoints
  3. * Copyright (c) 2018 Johannes Thumshirn, SUSE Linux GmbH
  4. *
  5. * This program is free software; you can redistribute it and/or modify it
  6. * under the terms and conditions of the GNU General Public License,
  7. * version 2, as published by the Free Software Foundation.
  8. *
  9. * This program is distributed in the hope it will be useful, but WITHOUT
  10. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  11. * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  12. * more details.
  13. */
  14. #undef TRACE_SYSTEM
  15. #define TRACE_SYSTEM nvme
  16. #if !defined(_TRACE_NVME_H) || defined(TRACE_HEADER_MULTI_READ)
  17. #define _TRACE_NVME_H
  18. #include <linux/nvme.h>
  19. #include <linux/tracepoint.h>
  20. #include <linux/trace_seq.h>
  21. #include "nvme.h"
  22. #define nvme_admin_opcode_name(opcode) { opcode, #opcode }
  23. #define show_admin_opcode_name(val) \
  24. __print_symbolic(val, \
  25. nvme_admin_opcode_name(nvme_admin_delete_sq), \
  26. nvme_admin_opcode_name(nvme_admin_create_sq), \
  27. nvme_admin_opcode_name(nvme_admin_get_log_page), \
  28. nvme_admin_opcode_name(nvme_admin_delete_cq), \
  29. nvme_admin_opcode_name(nvme_admin_create_cq), \
  30. nvme_admin_opcode_name(nvme_admin_identify), \
  31. nvme_admin_opcode_name(nvme_admin_abort_cmd), \
  32. nvme_admin_opcode_name(nvme_admin_set_features), \
  33. nvme_admin_opcode_name(nvme_admin_get_features), \
  34. nvme_admin_opcode_name(nvme_admin_async_event), \
  35. nvme_admin_opcode_name(nvme_admin_ns_mgmt), \
  36. nvme_admin_opcode_name(nvme_admin_activate_fw), \
  37. nvme_admin_opcode_name(nvme_admin_download_fw), \
  38. nvme_admin_opcode_name(nvme_admin_ns_attach), \
  39. nvme_admin_opcode_name(nvme_admin_keep_alive), \
  40. nvme_admin_opcode_name(nvme_admin_directive_send), \
  41. nvme_admin_opcode_name(nvme_admin_directive_recv), \
  42. nvme_admin_opcode_name(nvme_admin_dbbuf), \
  43. nvme_admin_opcode_name(nvme_admin_format_nvm), \
  44. nvme_admin_opcode_name(nvme_admin_security_send), \
  45. nvme_admin_opcode_name(nvme_admin_security_recv), \
  46. nvme_admin_opcode_name(nvme_admin_sanitize_nvm))
  47. const char *nvme_trace_parse_admin_cmd(struct trace_seq *p, u8 opcode,
  48. u8 *cdw10);
  49. #define __parse_nvme_admin_cmd(opcode, cdw10) \
  50. nvme_trace_parse_admin_cmd(p, opcode, cdw10)
  51. #define nvme_opcode_name(opcode) { opcode, #opcode }
  52. #define show_opcode_name(val) \
  53. __print_symbolic(val, \
  54. nvme_opcode_name(nvme_cmd_flush), \
  55. nvme_opcode_name(nvme_cmd_write), \
  56. nvme_opcode_name(nvme_cmd_read), \
  57. nvme_opcode_name(nvme_cmd_write_uncor), \
  58. nvme_opcode_name(nvme_cmd_compare), \
  59. nvme_opcode_name(nvme_cmd_write_zeroes), \
  60. nvme_opcode_name(nvme_cmd_dsm), \
  61. nvme_opcode_name(nvme_cmd_resv_register), \
  62. nvme_opcode_name(nvme_cmd_resv_report), \
  63. nvme_opcode_name(nvme_cmd_resv_acquire), \
  64. nvme_opcode_name(nvme_cmd_resv_release))
  65. const char *nvme_trace_parse_nvm_cmd(struct trace_seq *p, u8 opcode,
  66. u8 *cdw10);
  67. #define __parse_nvme_cmd(opcode, cdw10) \
  68. nvme_trace_parse_nvm_cmd(p, opcode, cdw10)
  69. TRACE_EVENT(nvme_setup_admin_cmd,
  70. TP_PROTO(struct nvme_command *cmd),
  71. TP_ARGS(cmd),
  72. TP_STRUCT__entry(
  73. __field(u8, opcode)
  74. __field(u8, flags)
  75. __field(u16, cid)
  76. __field(u64, metadata)
  77. __array(u8, cdw10, 24)
  78. ),
  79. TP_fast_assign(
  80. __entry->opcode = cmd->common.opcode;
  81. __entry->flags = cmd->common.flags;
  82. __entry->cid = cmd->common.command_id;
  83. __entry->metadata = le64_to_cpu(cmd->common.metadata);
  84. memcpy(__entry->cdw10, cmd->common.cdw10,
  85. sizeof(__entry->cdw10));
  86. ),
  87. TP_printk(" cmdid=%u, flags=0x%x, meta=0x%llx, cmd=(%s %s)",
  88. __entry->cid, __entry->flags, __entry->metadata,
  89. show_admin_opcode_name(__entry->opcode),
  90. __parse_nvme_admin_cmd(__entry->opcode, __entry->cdw10))
  91. );
  92. TRACE_EVENT(nvme_setup_nvm_cmd,
  93. TP_PROTO(int qid, struct nvme_command *cmd),
  94. TP_ARGS(qid, cmd),
  95. TP_STRUCT__entry(
  96. __field(int, qid)
  97. __field(u8, opcode)
  98. __field(u8, flags)
  99. __field(u16, cid)
  100. __field(u32, nsid)
  101. __field(u64, metadata)
  102. __array(u8, cdw10, 24)
  103. ),
  104. TP_fast_assign(
  105. __entry->qid = qid;
  106. __entry->opcode = cmd->common.opcode;
  107. __entry->flags = cmd->common.flags;
  108. __entry->cid = cmd->common.command_id;
  109. __entry->nsid = le32_to_cpu(cmd->common.nsid);
  110. __entry->metadata = le64_to_cpu(cmd->common.metadata);
  111. memcpy(__entry->cdw10, cmd->common.cdw10,
  112. sizeof(__entry->cdw10));
  113. ),
  114. TP_printk("qid=%d, nsid=%u, cmdid=%u, flags=0x%x, meta=0x%llx, cmd=(%s %s)",
  115. __entry->qid, __entry->nsid, __entry->cid,
  116. __entry->flags, __entry->metadata,
  117. show_opcode_name(__entry->opcode),
  118. __parse_nvme_cmd(__entry->opcode, __entry->cdw10))
  119. );
  120. TRACE_EVENT(nvme_complete_rq,
  121. TP_PROTO(struct request *req),
  122. TP_ARGS(req),
  123. TP_STRUCT__entry(
  124. __field(int, qid)
  125. __field(int, cid)
  126. __field(u64, result)
  127. __field(u8, retries)
  128. __field(u8, flags)
  129. __field(u16, status)
  130. ),
  131. TP_fast_assign(
  132. __entry->qid = req->q->id;
  133. __entry->cid = req->tag;
  134. __entry->result = le64_to_cpu(nvme_req(req)->result.u64);
  135. __entry->retries = nvme_req(req)->retries;
  136. __entry->flags = nvme_req(req)->flags;
  137. __entry->status = nvme_req(req)->status;
  138. ),
  139. TP_printk("cmdid=%u, qid=%d, res=%llu, retries=%u, flags=0x%x, status=%u",
  140. __entry->cid, __entry->qid, __entry->result,
  141. __entry->retries, __entry->flags, __entry->status)
  142. );
  143. #endif /* _TRACE_NVME_H */
  144. #undef TRACE_INCLUDE_PATH
  145. #define TRACE_INCLUDE_PATH .
  146. #undef TRACE_INCLUDE_FILE
  147. #define TRACE_INCLUDE_FILE trace
  148. /* This part must be outside protection */
  149. #include <trace/define_trace.h>