[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <20250714-jag-cdq-v1-6-01e027d256d5@kernel.org>
Date: Mon, 14 Jul 2025 11:15:37 +0200
From: Joel Granados <joel.granados@...nel.org>
To: Keith Busch <kbusch@...nel.org>, Jens Axboe <axboe@...nel.dk>,
Christoph Hellwig <hch@....de>, Sagi Grimberg <sagi@...mberg.me>
Cc: Klaus Jensen <k.jensen@...sung.com>, linux-nvme@...ts.infradead.org,
linux-kernel@...r.kernel.org, Joel Granados <joel.granados@...nel.org>
Subject: [PATCH RFC 6/8] nvme: Add a release ops to cdq file ops
When user space calls close on the file descriptor or crashes,
nvme_cdq_fops_release will ensure everything related to the CDQ is
properly released.
Signed-off-by: Joel Granados <joel.granados@...nel.org>
---
drivers/nvme/host/core.c | 8 ++++++++
1 file changed, 8 insertions(+)
diff --git a/drivers/nvme/host/core.c b/drivers/nvme/host/core.c
index 427e482530bdb5c7124d1230f35693ba756ce4d9..4745b961c6b874375ff4399c104f312b5ac608b8 100644
--- a/drivers/nvme/host/core.c
+++ b/drivers/nvme/host/core.c
@@ -1313,10 +1313,18 @@ static ssize_t nvme_cdq_fops_read(struct file *filep, char __user *buf,
return nvme_cdq_traverse(cdq, nbytes, buf);
}
+static int nvme_cdq_fops_release(struct inode *inode, struct file *filep)
+{
+ struct cdq_nvme_queue *cdq = filep->private_data;
+
+ return nvme_cdq_delete(cdq->ctrl, cdq->cdq_id);
+}
+
static const struct file_operations cdq_fops = {
.owner = THIS_MODULE,
.open = nonseekable_open,
.read = nvme_cdq_fops_read,
+ .release = nvme_cdq_fops_release,
};
static int nvme_cdq_fd(struct cdq_nvme_queue *cdq, int *fdno)
--
2.47.2
Powered by blists - more mailing lists