trace.h 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /*
  3. * NVM Express target device driver tracepoints
  4. * Copyright (c) 2018 Johannes Thumshirn, SUSE Linux GmbH
  5. *
  6. * This is entirely based on drivers/nvme/host/trace.h
  7. */
  8. #undef TRACE_SYSTEM
  9. #define TRACE_SYSTEM nvmet
  10. #if !defined(_TRACE_NVMET_H) || defined(TRACE_HEADER_MULTI_READ)
  11. #define _TRACE_NVMET_H
  12. #include <linux/nvme.h>
  13. #include <linux/tracepoint.h>
  14. #include <linux/trace_seq.h>
  15. #include "nvmet.h"
  16. const char *nvmet_trace_parse_admin_cmd(struct trace_seq *p, u8 opcode,
  17. u8 *cdw10);
  18. const char *nvmet_trace_parse_nvm_cmd(struct trace_seq *p, u8 opcode,
  19. u8 *cdw10);
  20. const char *nvmet_trace_parse_fabrics_cmd(struct trace_seq *p, u8 fctype,
  21. u8 *spc);
  22. #define parse_nvme_cmd(qid, opcode, fctype, cdw10) \
  23. ((opcode) == nvme_fabrics_command ? \
  24. nvmet_trace_parse_fabrics_cmd(p, fctype, cdw10) : \
  25. (qid ? \
  26. nvmet_trace_parse_nvm_cmd(p, opcode, cdw10) : \
  27. nvmet_trace_parse_admin_cmd(p, opcode, cdw10)))
  28. const char *nvmet_trace_ctrl_name(struct trace_seq *p, struct nvmet_ctrl *ctrl);
  29. #define __print_ctrl_name(ctrl) \
  30. nvmet_trace_ctrl_name(p, ctrl)
  31. const char *nvmet_trace_disk_name(struct trace_seq *p, char *name);
  32. #define __print_disk_name(name) \
  33. nvmet_trace_disk_name(p, name)
  34. #ifndef TRACE_HEADER_MULTI_READ
  35. static inline struct nvmet_ctrl *nvmet_req_to_ctrl(struct nvmet_req *req)
  36. {
  37. return req->sq->ctrl;
  38. }
  39. static inline void __assign_req_name(char *name, struct nvmet_req *req)
  40. {
  41. if (!req->ns) {
  42. memset(name, 0, DISK_NAME_LEN);
  43. return;
  44. }
  45. strncpy(name, req->ns->device_path,
  46. min_t(size_t, DISK_NAME_LEN, strlen(req->ns->device_path)));
  47. }
  48. #endif
  49. TRACE_EVENT(nvmet_req_init,
  50. TP_PROTO(struct nvmet_req *req, struct nvme_command *cmd),
  51. TP_ARGS(req, cmd),
  52. TP_STRUCT__entry(
  53. __field(struct nvme_command *, cmd)
  54. __field(struct nvmet_ctrl *, ctrl)
  55. __array(char, disk, DISK_NAME_LEN)
  56. __field(int, qid)
  57. __field(u16, cid)
  58. __field(u8, opcode)
  59. __field(u8, fctype)
  60. __field(u8, flags)
  61. __field(u32, nsid)
  62. __field(u64, metadata)
  63. __array(u8, cdw10, 24)
  64. ),
  65. TP_fast_assign(
  66. __entry->cmd = cmd;
  67. __entry->ctrl = nvmet_req_to_ctrl(req);
  68. __assign_req_name(__entry->disk, req);
  69. __entry->qid = req->sq->qid;
  70. __entry->cid = cmd->common.command_id;
  71. __entry->opcode = cmd->common.opcode;
  72. __entry->fctype = cmd->fabrics.fctype;
  73. __entry->flags = cmd->common.flags;
  74. __entry->nsid = le32_to_cpu(cmd->common.nsid);
  75. __entry->metadata = le64_to_cpu(cmd->common.metadata);
  76. memcpy(__entry->cdw10, &cmd->common.cdw10,
  77. sizeof(__entry->cdw10));
  78. ),
  79. TP_printk("nvmet%s: %sqid=%d, cmdid=%u, nsid=%u, flags=%#x, "
  80. "meta=%#llx, cmd=(%s, %s)",
  81. __print_ctrl_name(__entry->ctrl),
  82. __print_disk_name(__entry->disk),
  83. __entry->qid, __entry->cid, __entry->nsid,
  84. __entry->flags, __entry->metadata,
  85. show_opcode_name(__entry->qid, __entry->opcode,
  86. __entry->fctype),
  87. parse_nvme_cmd(__entry->qid, __entry->opcode,
  88. __entry->fctype, __entry->cdw10))
  89. );
  90. TRACE_EVENT(nvmet_req_complete,
  91. TP_PROTO(struct nvmet_req *req),
  92. TP_ARGS(req),
  93. TP_STRUCT__entry(
  94. __field(struct nvmet_ctrl *, ctrl)
  95. __array(char, disk, DISK_NAME_LEN)
  96. __field(int, qid)
  97. __field(int, cid)
  98. __field(u64, result)
  99. __field(u16, status)
  100. ),
  101. TP_fast_assign(
  102. __entry->ctrl = nvmet_req_to_ctrl(req);
  103. __entry->qid = req->cq->qid;
  104. __entry->cid = req->cqe->command_id;
  105. __entry->result = le64_to_cpu(req->cqe->result.u64);
  106. __entry->status = le16_to_cpu(req->cqe->status) >> 1;
  107. __assign_req_name(__entry->disk, req);
  108. ),
  109. TP_printk("nvmet%s: %sqid=%d, cmdid=%u, res=%#llx, status=%#x",
  110. __print_ctrl_name(__entry->ctrl),
  111. __print_disk_name(__entry->disk),
  112. __entry->qid, __entry->cid, __entry->result, __entry->status)
  113. );
  114. #define aer_name(aer) { aer, #aer }
  115. TRACE_EVENT(nvmet_async_event,
  116. TP_PROTO(struct nvmet_ctrl *ctrl, __le32 result),
  117. TP_ARGS(ctrl, result),
  118. TP_STRUCT__entry(
  119. __field(int, ctrl_id)
  120. __field(u32, result)
  121. ),
  122. TP_fast_assign(
  123. __entry->ctrl_id = ctrl->cntlid;
  124. __entry->result = (le32_to_cpu(result) & 0xff00) >> 8;
  125. ),
  126. TP_printk("nvmet%d: NVME_AEN=%#08x [%s]",
  127. __entry->ctrl_id, __entry->result,
  128. __print_symbolic(__entry->result,
  129. aer_name(NVME_AER_NOTICE_NS_CHANGED),
  130. aer_name(NVME_AER_NOTICE_ANA),
  131. aer_name(NVME_AER_NOTICE_FW_ACT_STARTING),
  132. aer_name(NVME_AER_NOTICE_DISC_CHANGED),
  133. aer_name(NVME_AER_ERROR),
  134. aer_name(NVME_AER_SMART),
  135. aer_name(NVME_AER_CSS),
  136. aer_name(NVME_AER_VS))
  137. )
  138. );
  139. #undef aer_name
  140. #endif /* _TRACE_NVMET_H */
  141. #undef TRACE_INCLUDE_PATH
  142. #define TRACE_INCLUDE_PATH .
  143. #undef TRACE_INCLUDE_FILE
  144. #define TRACE_INCLUDE_FILE trace
  145. /* This part must be outside protection */
  146. #include <trace/define_trace.h>