[PATCH] nvmet: add missing locks around nvmet_ns_revalidate
Niels Dossche
dossche.niels at gmail.com
Wed Mar 9 12:34:50 PST 2022
nvmet_ns_changed states via lockdep that the ns->subsys->lock must be
held. The only caller of nvmet_ns_changed which does not acquire that
lock is nvmet_ns_revalidate. The only 2 callers of nvmet_ns_revalidate
which do not acquire that lock are nvmet_execute_identify_cns_cs_ns and
nvmet_execute_identify_ns. Add a lock for around the call to
nvmet_ns_revalidate in those 2 functions.
Both of those identify functions are called from a common function
nvmet_execute_identify, which itself is called indirectly via the
req->execute function pointer.
Signed-off-by: Niels Dossche <dossche.niels at gmail.com>
---
drivers/nvme/target/admin-cmd.c | 2 ++
drivers/nvme/target/zns.c | 3 +++
2 files changed, 5 insertions(+)
diff --git a/drivers/nvme/target/admin-cmd.c b/drivers/nvme/target/admin-cmd.c
index 6fb24746de06..6d1f5e02d27b 100644
--- a/drivers/nvme/target/admin-cmd.c
+++ b/drivers/nvme/target/admin-cmd.c
@@ -511,7 +511,9 @@ static void nvmet_execute_identify_ns(struct nvmet_req *req)
goto done;
}
+ mutex_lock(&req->ns->subsys->lock);
nvmet_ns_revalidate(req->ns);
+ mutex_unlock(&req->ns->subsys->lock);
/*
* nuse = ncap = nsze isn't always true, but we have no way to find
diff --git a/drivers/nvme/target/zns.c b/drivers/nvme/target/zns.c
index 46bc30fe85d2..5182b802de27 100644
--- a/drivers/nvme/target/zns.c
+++ b/drivers/nvme/target/zns.c
@@ -123,7 +123,10 @@ void nvmet_execute_identify_cns_cs_ns(struct nvmet_req *req)
goto done;
}
+ mutex_lock(req->ns->subsys->lock);
nvmet_ns_revalidate(req->ns);
+ mutex_unlock(req->ns->subsys->lock);
+
zsze = (bdev_zone_sectors(req->ns->bdev) << 9) >>
req->ns->blksize_shift;
id_zns->lbafe[0].zsze = cpu_to_le64(zsze);
--
2.35.1
More information about the Linux-nvme
mailing list