18c2ecf20Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */ 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * NVM Express device driver tracepoints 48c2ecf20Sopenharmony_ci * Copyright (c) 2018 Johannes Thumshirn, SUSE Linux GmbH 58c2ecf20Sopenharmony_ci */ 68c2ecf20Sopenharmony_ci 78c2ecf20Sopenharmony_ci#undef TRACE_SYSTEM 88c2ecf20Sopenharmony_ci#define TRACE_SYSTEM nvme 98c2ecf20Sopenharmony_ci 108c2ecf20Sopenharmony_ci#if !defined(_TRACE_NVME_H) || defined(TRACE_HEADER_MULTI_READ) 118c2ecf20Sopenharmony_ci#define _TRACE_NVME_H 128c2ecf20Sopenharmony_ci 138c2ecf20Sopenharmony_ci#include <linux/nvme.h> 148c2ecf20Sopenharmony_ci#include <linux/tracepoint.h> 158c2ecf20Sopenharmony_ci#include <linux/trace_seq.h> 168c2ecf20Sopenharmony_ci 178c2ecf20Sopenharmony_ci#include "nvme.h" 188c2ecf20Sopenharmony_ci 198c2ecf20Sopenharmony_ciconst char *nvme_trace_parse_admin_cmd(struct trace_seq *p, u8 opcode, 208c2ecf20Sopenharmony_ci u8 *cdw10); 218c2ecf20Sopenharmony_ciconst char *nvme_trace_parse_nvm_cmd(struct trace_seq *p, u8 opcode, 228c2ecf20Sopenharmony_ci u8 *cdw10); 238c2ecf20Sopenharmony_ciconst char *nvme_trace_parse_fabrics_cmd(struct trace_seq *p, u8 fctype, 248c2ecf20Sopenharmony_ci u8 *spc); 258c2ecf20Sopenharmony_ci 268c2ecf20Sopenharmony_ci#define parse_nvme_cmd(qid, opcode, fctype, cdw10) \ 278c2ecf20Sopenharmony_ci ((opcode) == nvme_fabrics_command ? \ 288c2ecf20Sopenharmony_ci nvme_trace_parse_fabrics_cmd(p, fctype, cdw10) : \ 298c2ecf20Sopenharmony_ci ((qid) ? \ 308c2ecf20Sopenharmony_ci nvme_trace_parse_nvm_cmd(p, opcode, cdw10) : \ 318c2ecf20Sopenharmony_ci nvme_trace_parse_admin_cmd(p, opcode, cdw10))) 328c2ecf20Sopenharmony_ci 338c2ecf20Sopenharmony_ciconst char *nvme_trace_disk_name(struct trace_seq *p, char *name); 348c2ecf20Sopenharmony_ci#define __print_disk_name(name) \ 358c2ecf20Sopenharmony_ci nvme_trace_disk_name(p, name) 368c2ecf20Sopenharmony_ci 378c2ecf20Sopenharmony_ci#ifndef TRACE_HEADER_MULTI_READ 388c2ecf20Sopenharmony_cistatic inline void __assign_disk_name(char *name, struct gendisk *disk) 398c2ecf20Sopenharmony_ci{ 408c2ecf20Sopenharmony_ci if (disk) 418c2ecf20Sopenharmony_ci memcpy(name, disk->disk_name, DISK_NAME_LEN); 428c2ecf20Sopenharmony_ci else 438c2ecf20Sopenharmony_ci memset(name, 0, DISK_NAME_LEN); 448c2ecf20Sopenharmony_ci} 458c2ecf20Sopenharmony_ci#endif 468c2ecf20Sopenharmony_ci 478c2ecf20Sopenharmony_ciTRACE_EVENT(nvme_setup_cmd, 488c2ecf20Sopenharmony_ci TP_PROTO(struct request *req, struct nvme_command *cmd), 498c2ecf20Sopenharmony_ci TP_ARGS(req, cmd), 508c2ecf20Sopenharmony_ci TP_STRUCT__entry( 518c2ecf20Sopenharmony_ci __array(char, disk, DISK_NAME_LEN) 528c2ecf20Sopenharmony_ci __field(int, ctrl_id) 538c2ecf20Sopenharmony_ci __field(int, qid) 548c2ecf20Sopenharmony_ci __field(u8, opcode) 558c2ecf20Sopenharmony_ci __field(u8, flags) 568c2ecf20Sopenharmony_ci __field(u8, fctype) 578c2ecf20Sopenharmony_ci __field(u16, cid) 588c2ecf20Sopenharmony_ci __field(u32, nsid) 598c2ecf20Sopenharmony_ci __field(bool, metadata) 608c2ecf20Sopenharmony_ci __array(u8, cdw10, 24) 618c2ecf20Sopenharmony_ci ), 628c2ecf20Sopenharmony_ci TP_fast_assign( 638c2ecf20Sopenharmony_ci __entry->ctrl_id = nvme_req(req)->ctrl->instance; 648c2ecf20Sopenharmony_ci __entry->qid = nvme_req_qid(req); 658c2ecf20Sopenharmony_ci __entry->opcode = cmd->common.opcode; 668c2ecf20Sopenharmony_ci __entry->flags = cmd->common.flags; 678c2ecf20Sopenharmony_ci __entry->cid = cmd->common.command_id; 688c2ecf20Sopenharmony_ci __entry->nsid = le32_to_cpu(cmd->common.nsid); 698c2ecf20Sopenharmony_ci __entry->metadata = !!blk_integrity_rq(req); 708c2ecf20Sopenharmony_ci __entry->fctype = cmd->fabrics.fctype; 718c2ecf20Sopenharmony_ci __assign_disk_name(__entry->disk, req->rq_disk); 728c2ecf20Sopenharmony_ci memcpy(__entry->cdw10, &cmd->common.cdw10, 738c2ecf20Sopenharmony_ci sizeof(__entry->cdw10)); 748c2ecf20Sopenharmony_ci ), 758c2ecf20Sopenharmony_ci TP_printk("nvme%d: %sqid=%d, cmdid=%u, nsid=%u, flags=0x%x, meta=0x%x, cmd=(%s %s)", 768c2ecf20Sopenharmony_ci __entry->ctrl_id, __print_disk_name(__entry->disk), 778c2ecf20Sopenharmony_ci __entry->qid, __entry->cid, __entry->nsid, 788c2ecf20Sopenharmony_ci __entry->flags, __entry->metadata, 798c2ecf20Sopenharmony_ci show_opcode_name(__entry->qid, __entry->opcode, 808c2ecf20Sopenharmony_ci __entry->fctype), 818c2ecf20Sopenharmony_ci parse_nvme_cmd(__entry->qid, __entry->opcode, 828c2ecf20Sopenharmony_ci __entry->fctype, __entry->cdw10)) 838c2ecf20Sopenharmony_ci); 848c2ecf20Sopenharmony_ci 858c2ecf20Sopenharmony_ciTRACE_EVENT(nvme_complete_rq, 868c2ecf20Sopenharmony_ci TP_PROTO(struct request *req), 878c2ecf20Sopenharmony_ci TP_ARGS(req), 888c2ecf20Sopenharmony_ci TP_STRUCT__entry( 898c2ecf20Sopenharmony_ci __array(char, disk, DISK_NAME_LEN) 908c2ecf20Sopenharmony_ci __field(int, ctrl_id) 918c2ecf20Sopenharmony_ci __field(int, qid) 928c2ecf20Sopenharmony_ci __field(int, cid) 938c2ecf20Sopenharmony_ci __field(u64, result) 948c2ecf20Sopenharmony_ci __field(u8, retries) 958c2ecf20Sopenharmony_ci __field(u8, flags) 968c2ecf20Sopenharmony_ci __field(u16, status) 978c2ecf20Sopenharmony_ci ), 988c2ecf20Sopenharmony_ci TP_fast_assign( 998c2ecf20Sopenharmony_ci __entry->ctrl_id = nvme_req(req)->ctrl->instance; 1008c2ecf20Sopenharmony_ci __entry->qid = nvme_req_qid(req); 1018c2ecf20Sopenharmony_ci __entry->cid = req->tag; 1028c2ecf20Sopenharmony_ci __entry->result = le64_to_cpu(nvme_req(req)->result.u64); 1038c2ecf20Sopenharmony_ci __entry->retries = nvme_req(req)->retries; 1048c2ecf20Sopenharmony_ci __entry->flags = nvme_req(req)->flags; 1058c2ecf20Sopenharmony_ci __entry->status = nvme_req(req)->status; 1068c2ecf20Sopenharmony_ci __assign_disk_name(__entry->disk, req->rq_disk); 1078c2ecf20Sopenharmony_ci ), 1088c2ecf20Sopenharmony_ci TP_printk("nvme%d: %sqid=%d, cmdid=%u, res=%#llx, retries=%u, flags=0x%x, status=%#x", 1098c2ecf20Sopenharmony_ci __entry->ctrl_id, __print_disk_name(__entry->disk), 1108c2ecf20Sopenharmony_ci __entry->qid, __entry->cid, __entry->result, 1118c2ecf20Sopenharmony_ci __entry->retries, __entry->flags, __entry->status) 1128c2ecf20Sopenharmony_ci 1138c2ecf20Sopenharmony_ci); 1148c2ecf20Sopenharmony_ci 1158c2ecf20Sopenharmony_ci#define aer_name(aer) { aer, #aer } 1168c2ecf20Sopenharmony_ci 1178c2ecf20Sopenharmony_ciTRACE_EVENT(nvme_async_event, 1188c2ecf20Sopenharmony_ci TP_PROTO(struct nvme_ctrl *ctrl, u32 result), 1198c2ecf20Sopenharmony_ci TP_ARGS(ctrl, result), 1208c2ecf20Sopenharmony_ci TP_STRUCT__entry( 1218c2ecf20Sopenharmony_ci __field(int, ctrl_id) 1228c2ecf20Sopenharmony_ci __field(u32, result) 1238c2ecf20Sopenharmony_ci ), 1248c2ecf20Sopenharmony_ci TP_fast_assign( 1258c2ecf20Sopenharmony_ci __entry->ctrl_id = ctrl->instance; 1268c2ecf20Sopenharmony_ci __entry->result = result; 1278c2ecf20Sopenharmony_ci ), 1288c2ecf20Sopenharmony_ci TP_printk("nvme%d: NVME_AEN=%#08x [%s]", 1298c2ecf20Sopenharmony_ci __entry->ctrl_id, __entry->result, 1308c2ecf20Sopenharmony_ci __print_symbolic(__entry->result & 0x7, 1318c2ecf20Sopenharmony_ci aer_name(NVME_AER_ERROR), 1328c2ecf20Sopenharmony_ci aer_name(NVME_AER_SMART), 1338c2ecf20Sopenharmony_ci aer_name(NVME_AER_NOTICE), 1348c2ecf20Sopenharmony_ci aer_name(NVME_AER_CSS), 1358c2ecf20Sopenharmony_ci aer_name(NVME_AER_VS)) 1368c2ecf20Sopenharmony_ci ) 1378c2ecf20Sopenharmony_ci); 1388c2ecf20Sopenharmony_ci 1398c2ecf20Sopenharmony_ci#undef aer_name 1408c2ecf20Sopenharmony_ci 1418c2ecf20Sopenharmony_ciTRACE_EVENT(nvme_sq, 1428c2ecf20Sopenharmony_ci TP_PROTO(struct request *req, __le16 sq_head, int sq_tail), 1438c2ecf20Sopenharmony_ci TP_ARGS(req, sq_head, sq_tail), 1448c2ecf20Sopenharmony_ci TP_STRUCT__entry( 1458c2ecf20Sopenharmony_ci __field(int, ctrl_id) 1468c2ecf20Sopenharmony_ci __array(char, disk, DISK_NAME_LEN) 1478c2ecf20Sopenharmony_ci __field(int, qid) 1488c2ecf20Sopenharmony_ci __field(u16, sq_head) 1498c2ecf20Sopenharmony_ci __field(u16, sq_tail) 1508c2ecf20Sopenharmony_ci ), 1518c2ecf20Sopenharmony_ci TP_fast_assign( 1528c2ecf20Sopenharmony_ci __entry->ctrl_id = nvme_req(req)->ctrl->instance; 1538c2ecf20Sopenharmony_ci __assign_disk_name(__entry->disk, req->rq_disk); 1548c2ecf20Sopenharmony_ci __entry->qid = nvme_req_qid(req); 1558c2ecf20Sopenharmony_ci __entry->sq_head = le16_to_cpu(sq_head); 1568c2ecf20Sopenharmony_ci __entry->sq_tail = sq_tail; 1578c2ecf20Sopenharmony_ci ), 1588c2ecf20Sopenharmony_ci TP_printk("nvme%d: %sqid=%d, head=%u, tail=%u", 1598c2ecf20Sopenharmony_ci __entry->ctrl_id, __print_disk_name(__entry->disk), 1608c2ecf20Sopenharmony_ci __entry->qid, __entry->sq_head, __entry->sq_tail 1618c2ecf20Sopenharmony_ci ) 1628c2ecf20Sopenharmony_ci); 1638c2ecf20Sopenharmony_ci 1648c2ecf20Sopenharmony_ci#endif /* _TRACE_NVME_H */ 1658c2ecf20Sopenharmony_ci 1668c2ecf20Sopenharmony_ci#undef TRACE_INCLUDE_PATH 1678c2ecf20Sopenharmony_ci#define TRACE_INCLUDE_PATH . 1688c2ecf20Sopenharmony_ci#undef TRACE_INCLUDE_FILE 1698c2ecf20Sopenharmony_ci#define TRACE_INCLUDE_FILE trace 1708c2ecf20Sopenharmony_ci 1718c2ecf20Sopenharmony_ci/* This part must be outside protection */ 1728c2ecf20Sopenharmony_ci#include <trace/define_trace.h> 173