[PATCH RFC] nvmet: fix tmpfs-based backstores support
Chaitanya Kulkarni
chaitanyak at nvidia.com
Wed Nov 17 17:59:29 PST 2021
On 11/17/21 07:24, Maurizio Lombardi wrote:
> External email: Use caution opening links or attachments
>
>
> commit 50a909db36f2 ("nvmet: use IOCB_NOWAIT for file-ns buffered I/O")
> optimized the read command behaviour when buffered file-ns
s/behaviour/behavior
> configurations are used.
> It issues the read commands with the IOCB_NOWAIT flag set to try
> to access the data from the cache.
>
> However, the patch was buggy because both read and write commands are
> issued with IOCB_NOWAIT, this broke tmpfs-based backstores because tmpfs
> doesn't accept write commands with IOCB_NOWAIT.
>
> Fix this bug by restricting IOCB_NOWAIT to read commands only.
>
> Fixes: 50a909db36f2 ("nvmet: use IOCB_NOWAIT for file-ns buffered I/O")
>
> Signed-off-by: Maurizio Lombardi <mlombard at redhat.com>
We will need blktests for this.
Also, can you share performance numbers with this patch and
the errors that you are getting without this patch ?
> ---
> drivers/nvme/target/io-cmd-file.c | 1 +
> 1 file changed, 1 insertion(+)
>
> diff --git a/drivers/nvme/target/io-cmd-file.c b/drivers/nvme/target/io-cmd-file.c
> index 6aa30f30b572..1d9b41190583 100644
> --- a/drivers/nvme/target/io-cmd-file.c
> +++ b/drivers/nvme/target/io-cmd-file.c
> @@ -266,6 +266,7 @@ static void nvmet_file_execute_rw(struct nvmet_req *req)
>
> if (req->ns->buffered_io) {
> if (likely(!req->f.mpool_alloc) &&
> + req->cmd->rw.opcode == nvme_cmd_read &&
> nvmet_file_execute_io(req, IOCB_NOWAIT))
> return;
> nvmet_file_submit_buffered_io(req);
> --
> 2.27.0
>
More information about the Linux-nvme
mailing list