提交 86141440 编写于 作者: C Christoph Hellwig 提交者: Jens Axboe

nvme-pci: print the command name of aborted commands

To allow for slightly better debugging, print the command name when
aborting an command.
Signed-off-by: NChristoph Hellwig <hch@lst.de>
Reviewed-by: NKeith Busch <kbusch@kernel.org>
Reviewed-by: NSagi Grimberg <sagi@grimberg.me>
Reviewed-by: NChaitanya Kulkarni <kch@nvidia.com>
Signed-off-by: NJens Axboe <axboe@kernel.dk>
上级 33b6debd
...@@ -177,6 +177,7 @@ const unsigned char *nvme_get_opcode_str(u8 opcode) ...@@ -177,6 +177,7 @@ const unsigned char *nvme_get_opcode_str(u8 opcode)
return nvme_ops[opcode]; return nvme_ops[opcode];
return "Unknown"; return "Unknown";
} }
EXPORT_SYMBOL_GPL(nvme_get_opcode_str);
const unsigned char *nvme_get_admin_opcode_str(u8 opcode) const unsigned char *nvme_get_admin_opcode_str(u8 opcode)
{ {
......
...@@ -1434,8 +1434,10 @@ static enum blk_eh_timer_return nvme_timeout(struct request *req) ...@@ -1434,8 +1434,10 @@ static enum blk_eh_timer_return nvme_timeout(struct request *req)
cmd.abort.sqid = cpu_to_le16(nvmeq->qid); cmd.abort.sqid = cpu_to_le16(nvmeq->qid);
dev_warn(nvmeq->dev->ctrl.device, dev_warn(nvmeq->dev->ctrl.device,
"I/O %d QID %d timeout, aborting\n", "I/O %d (%s) QID %d timeout, aborting\n",
req->tag, nvmeq->qid); req->tag,
nvme_get_opcode_str(nvme_req(req)->cmd->common.opcode),
nvmeq->qid);
abort_req = blk_mq_alloc_request(dev->ctrl.admin_q, nvme_req_op(&cmd), abort_req = blk_mq_alloc_request(dev->ctrl.admin_q, nvme_req_op(&cmd),
BLK_MQ_REQ_NOWAIT); BLK_MQ_REQ_NOWAIT);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册