trace.h 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  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. #define nvme_opcode_name(opcode) { opcode, #opcode }
  48. #define show_nvm_opcode_name(val) \
  49. __print_symbolic(val, \
  50. nvme_opcode_name(nvme_cmd_flush), \
  51. nvme_opcode_name(nvme_cmd_write), \
  52. nvme_opcode_name(nvme_cmd_read), \
  53. nvme_opcode_name(nvme_cmd_write_uncor), \
  54. nvme_opcode_name(nvme_cmd_compare), \
  55. nvme_opcode_name(nvme_cmd_write_zeroes), \
  56. nvme_opcode_name(nvme_cmd_dsm), \
  57. nvme_opcode_name(nvme_cmd_resv_register), \
  58. nvme_opcode_name(nvme_cmd_resv_report), \
  59. nvme_opcode_name(nvme_cmd_resv_acquire), \
  60. nvme_opcode_name(nvme_cmd_resv_release))
  61. #define show_opcode_name(qid, opcode) \
  62. (qid ? show_nvm_opcode_name(opcode) : show_admin_opcode_name(opcode))
  63. const char *nvme_trace_parse_admin_cmd(struct trace_seq *p, u8 opcode,
  64. u8 *cdw10);
  65. const char *nvme_trace_parse_nvm_cmd(struct trace_seq *p, u8 opcode,
  66. u8 *cdw10);
  67. #define parse_nvme_cmd(qid, opcode, cdw10) \
  68. (qid ? \
  69. nvme_trace_parse_nvm_cmd(p, opcode, cdw10) : \
  70. nvme_trace_parse_admin_cmd(p, opcode, cdw10))
  71. const char *nvme_trace_disk_name(struct trace_seq *p, char *name);
  72. #define __print_disk_name(name) \
  73. nvme_trace_disk_name(p, name)
  74. #ifndef TRACE_HEADER_MULTI_READ
  75. static inline void __assign_disk_name(char *name, struct gendisk *disk)
  76. {
  77. if (disk)
  78. memcpy(name, disk->disk_name, DISK_NAME_LEN);
  79. else
  80. memset(name, 0, DISK_NAME_LEN);
  81. }
  82. #endif
  83. TRACE_EVENT(nvme_setup_cmd,
  84. TP_PROTO(struct request *req, struct nvme_command *cmd),
  85. TP_ARGS(req, cmd),
  86. TP_STRUCT__entry(
  87. __array(char, disk, DISK_NAME_LEN)
  88. __field(int, ctrl_id)
  89. __field(int, qid)
  90. __field(u8, opcode)
  91. __field(u8, flags)
  92. __field(u16, cid)
  93. __field(u32, nsid)
  94. __field(u64, metadata)
  95. __array(u8, cdw10, 24)
  96. ),
  97. TP_fast_assign(
  98. __entry->ctrl_id = nvme_req(req)->ctrl->instance;
  99. __entry->qid = nvme_req_qid(req);
  100. __entry->opcode = cmd->common.opcode;
  101. __entry->flags = cmd->common.flags;
  102. __entry->cid = cmd->common.command_id;
  103. __entry->nsid = le32_to_cpu(cmd->common.nsid);
  104. __entry->metadata = le64_to_cpu(cmd->common.metadata);
  105. __assign_disk_name(__entry->disk, req->rq_disk);
  106. memcpy(__entry->cdw10, cmd->common.cdw10,
  107. sizeof(__entry->cdw10));
  108. ),
  109. TP_printk("nvme%d: %sqid=%d, cmdid=%u, nsid=%u, flags=0x%x, meta=0x%llx, cmd=(%s %s)",
  110. __entry->ctrl_id, __print_disk_name(__entry->disk),
  111. __entry->qid, __entry->cid, __entry->nsid,
  112. __entry->flags, __entry->metadata,
  113. show_opcode_name(__entry->qid, __entry->opcode),
  114. parse_nvme_cmd(__entry->qid, __entry->opcode, __entry->cdw10))
  115. );
  116. TRACE_EVENT(nvme_complete_rq,
  117. TP_PROTO(struct request *req),
  118. TP_ARGS(req),
  119. TP_STRUCT__entry(
  120. __array(char, disk, DISK_NAME_LEN)
  121. __field(int, ctrl_id)
  122. __field(int, qid)
  123. __field(int, cid)
  124. __field(u64, result)
  125. __field(u8, retries)
  126. __field(u8, flags)
  127. __field(u16, status)
  128. ),
  129. TP_fast_assign(
  130. __entry->ctrl_id = nvme_req(req)->ctrl->instance;
  131. __entry->qid = nvme_req_qid(req);
  132. __entry->cid = req->tag;
  133. __entry->result = le64_to_cpu(nvme_req(req)->result.u64);
  134. __entry->retries = nvme_req(req)->retries;
  135. __entry->flags = nvme_req(req)->flags;
  136. __entry->status = nvme_req(req)->status;
  137. __assign_disk_name(__entry->disk, req->rq_disk);
  138. ),
  139. TP_printk("nvme%d: %sqid=%d, cmdid=%u, res=%llu, retries=%u, flags=0x%x, status=%u",
  140. __entry->ctrl_id, __print_disk_name(__entry->disk),
  141. __entry->qid, __entry->cid, __entry->result,
  142. __entry->retries, __entry->flags, __entry->status)
  143. );
  144. #endif /* _TRACE_NVME_H */
  145. #undef TRACE_INCLUDE_PATH
  146. #define TRACE_INCLUDE_PATH .
  147. #undef TRACE_INCLUDE_FILE
  148. #define TRACE_INCLUDE_FILE trace
  149. /* This part must be outside protection */
  150. #include <trace/define_trace.h>