public inbox for linux-nvme@lists.infradead.org
 help / color / mirror / Atom feed
* [PATCHv2 1/2] nvme: introduce helper function to get ctrl state
@ 2023-11-20 17:50 Keith Busch
  2023-11-20 17:50 ` [PATCHv2 2/2] nvme: ensure reset state check ordering Keith Busch
  2023-11-20 19:05 ` [PATCHv2 1/2] nvme: introduce helper function to get ctrl state Sagi Grimberg
  0 siblings, 2 replies; 5+ messages in thread
From: Keith Busch @ 2023-11-20 17:50 UTC (permalink / raw)
  To: linux-nvme, hch, sagi; +Cc: Keith Busch

From: Keith Busch <kbusch@kernel.org>

The controller state is typically written by another CPU, so reading it
should ensure no optimizations are taken. This is a repeated pattern in
the driver, so start with adding a convenience function that returns the
controller state with READ_ONCE().

Signed-off-by: Keith Busch <kbusch@kernel.org>
---
 drivers/nvme/host/nvme.h | 5 +++++
 1 file changed, 5 insertions(+)

diff --git a/drivers/nvme/host/nvme.h b/drivers/nvme/host/nvme.h
index 39a90b7cb1254..578e6d311bc9c 100644
--- a/drivers/nvme/host/nvme.h
+++ b/drivers/nvme/host/nvme.h
@@ -387,6 +387,11 @@ struct nvme_ctrl {
 	enum nvme_dctype dctype;
 };
 
+static inline enum nvme_ctrl_state nvme_ctrl_state(struct nvme_ctrl *ctrl)
+{
+	return READ_ONCE(ctrl->state);
+}
+
 enum nvme_iopolicy {
 	NVME_IOPOLICY_NUMA,
 	NVME_IOPOLICY_RR,
-- 
2.34.1



^ permalink raw reply related	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2023-11-28 20:37 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2023-11-20 17:50 [PATCHv2 1/2] nvme: introduce helper function to get ctrl state Keith Busch
2023-11-20 17:50 ` [PATCHv2 2/2] nvme: ensure reset state check ordering Keith Busch
2023-11-20 19:07   ` Sagi Grimberg
2023-11-20 19:05 ` [PATCHv2 1/2] nvme: introduce helper function to get ctrl state Sagi Grimberg
2023-11-28 20:36   ` Keith Busch

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox