summaryrefslogtreecommitdiffstats
path: root/drivers/nvme
diff options
context:
space:
mode:
authorChaitanya Kulkarni <chaitanya.kulkarni@wdc.com>2021-02-09 21:47:53 -0800
committerChristoph Hellwig <hch@lst.de>2021-02-10 16:38:04 +0100
commitaa0aff604a60627b9f6c51c99dd5f63634322668 (patch)
tree2f0a3b7f36c827d63fc8f2e12aa3333808a0fb28 /drivers/nvme
parent40244ad36bcfb796a6bb9e95bdcbf8ddf3134509 (diff)
downloadlinux-aa0aff604a60627b9f6c51c99dd5f63634322668.tar.gz
linux-aa0aff604a60627b9f6c51c99dd5f63634322668.tar.bz2
linux-aa0aff604a60627b9f6c51c99dd5f63634322668.zip
nvmet: return uniform error for invalid ns
For nvmet_find_namespace() error case we have inconsistent error code mapping in the function nvmet_get_smart_log_nsid() and nvmet_set_feat_write_protect(). There is no point in retrying for the invalid namesapce from the host side. Set the error code to the NVME_SC_INVALID_NS | NVME_SC_DNR which matches what we have in nvmet_execute_identify_desclist(). Signed-off-by: Chaitanya Kulkarni <chaitanya.kulkarni@wdc.com> Signed-off-by: Christoph Hellwig <hch@lst.de>
Diffstat (limited to 'drivers/nvme')
-rw-r--r--drivers/nvme/target/admin-cmd.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/nvme/target/admin-cmd.c b/drivers/nvme/target/admin-cmd.c
index 5070ea5cf260..e938064254a5 100644
--- a/drivers/nvme/target/admin-cmd.c
+++ b/drivers/nvme/target/admin-cmd.c
@@ -82,7 +82,7 @@ static u16 nvmet_get_smart_log_nsid(struct nvmet_req *req,
pr_err("Could not find namespace id : %d\n",
le32_to_cpu(req->cmd->get_log_page.nsid));
req->error_loc = offsetof(struct nvme_rw_command, nsid);
- return NVME_SC_INVALID_NS;
+ return NVME_SC_INVALID_NS | NVME_SC_DNR;
}
/* we don't have the right data for file backed ns */
@@ -697,7 +697,7 @@ static u16 nvmet_set_feat_write_protect(struct nvmet_req *req)
req->ns = nvmet_find_namespace(req->sq->ctrl, req->cmd->rw.nsid);
if (unlikely(!req->ns)) {
req->error_loc = offsetof(struct nvme_common_command, nsid);
- return status;
+ return status = NVME_SC_INVALID_NS | NVME_SC_DNR;
}
mutex_lock(&subsys->lock);