Commit 2106e1f4 authored by Peter-Jan Gootzen's avatar Peter-Jan Gootzen Committed by Michael S. Tsirkin

virtio-fs: let -ENOMEM bubble up or burst gently

Currently, when the enqueueing of a request or forget operation fails
with -ENOMEM, the enqueueing is retried after a timeout. This patch
removes this behavior and treats -ENOMEM in these scenarios like any
other error. By bubbling up the error to user space in the case of a
request, and by dropping the operation in case of a forget. This
behavior matches that of the FUSE layer above, and also simplifies the
error handling. The latter will come in handy for upcoming patches that
optimize the retrying of operations in case of -ENOSPC.
Signed-off-by: default avatarPeter-Jan Gootzen <pgootzen@nvidia.com>
Reviewed-by: default avatarMax Gurtovoy <mgurtovoy@nvidia.com>
Reviewed-by: default avatarYoray Zack <yorayz@nvidia.com>
Message-Id: <20240517190435.152096-2-pgootzen@nvidia.com>
Signed-off-by: default avatarMichael S. Tsirkin <mst@redhat.com>
Reviewed-by: default avatarStefan Hajnoczi <stefanha@redhat.com>
parent e7909ad6
...@@ -447,7 +447,7 @@ static void virtio_fs_request_dispatch_work(struct work_struct *work) ...@@ -447,7 +447,7 @@ static void virtio_fs_request_dispatch_work(struct work_struct *work)
ret = virtio_fs_enqueue_req(fsvq, req, true); ret = virtio_fs_enqueue_req(fsvq, req, true);
if (ret < 0) { if (ret < 0) {
if (ret == -ENOMEM || ret == -ENOSPC) { if (ret == -ENOSPC) {
spin_lock(&fsvq->lock); spin_lock(&fsvq->lock);
list_add_tail(&req->list, &fsvq->queued_reqs); list_add_tail(&req->list, &fsvq->queued_reqs);
schedule_delayed_work(&fsvq->dispatch_work, schedule_delayed_work(&fsvq->dispatch_work,
...@@ -494,7 +494,7 @@ static int send_forget_request(struct virtio_fs_vq *fsvq, ...@@ -494,7 +494,7 @@ static int send_forget_request(struct virtio_fs_vq *fsvq,
ret = virtqueue_add_outbuf(vq, &sg, 1, forget, GFP_ATOMIC); ret = virtqueue_add_outbuf(vq, &sg, 1, forget, GFP_ATOMIC);
if (ret < 0) { if (ret < 0) {
if (ret == -ENOMEM || ret == -ENOSPC) { if (ret == -ENOSPC) {
pr_debug("virtio-fs: Could not queue FORGET: err=%d. Will try later\n", pr_debug("virtio-fs: Could not queue FORGET: err=%d. Will try later\n",
ret); ret);
list_add_tail(&forget->list, &fsvq->queued_reqs); list_add_tail(&forget->list, &fsvq->queued_reqs);
...@@ -1367,7 +1367,7 @@ __releases(fiq->lock) ...@@ -1367,7 +1367,7 @@ __releases(fiq->lock)
fsvq = &fs->vqs[queue_id]; fsvq = &fs->vqs[queue_id];
ret = virtio_fs_enqueue_req(fsvq, req, false); ret = virtio_fs_enqueue_req(fsvq, req, false);
if (ret < 0) { if (ret < 0) {
if (ret == -ENOMEM || ret == -ENOSPC) { if (ret == -ENOSPC) {
/* /*
* Virtqueue full. Retry submission from worker * Virtqueue full. Retry submission from worker
* context as we might be holding fc->bg_lock. * context as we might be holding fc->bg_lock.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment