Backport from ml:

commit de15522646b9822d82b613d84cfeb4482370db3d
Author: Miklos Szeredi <[email protected]>
Date:   Wed Jul 1 16:25:57 2015 +0200

    fuse: check conn_error earlier

    fc->conn_error is set once in FUSE_INIT reply and never cleared.  Check it
    in request allocation, there's no sense in doing all the preparation if
    sending will surely fail.

    Signed-off-by: Miklos Szeredi <[email protected]>
    Reviewed-by: Ashish Samant <[email protected]>

Signed-off-by: Maxim Patlasov <[email protected]>
---
 fs/fuse/dev.c |    6 ++++--
 1 file changed, 4 insertions(+), 2 deletions(-)

diff --git a/fs/fuse/dev.c b/fs/fuse/dev.c
index 1dd88a9..c14e102 100644
--- a/fs/fuse/dev.c
+++ b/fs/fuse/dev.c
@@ -142,6 +142,10 @@ static struct fuse_req *__fuse_get_req(struct fuse_conn 
*fc, unsigned npages,
        if (!fc->connected)
                goto out;
 
+       err = -ECONNREFUSED;
+       if (fc->conn_error)
+               goto out;
+
        req = fuse_request_alloc(npages);
        err = -ENOMEM;
        if (!req) {
@@ -480,8 +484,6 @@ static void __fuse_request_send(struct fuse_conn *fc, 
struct fuse_req *req,
        spin_lock(&fc->lock);
        if (!fc->connected)
                req->out.h.error = -ENOTCONN;
-       else if (fc->conn_error)
-               req->out.h.error = -ECONNREFUSED;
        else if (ff && test_bit(FUSE_S_FAIL_IMMEDIATELY, &ff->ff_state))
                req->out.h.error = -EIO;
        else {

_______________________________________________
Devel mailing list
[email protected]
https://lists.openvz.org/mailman/listinfo/devel

Reply via email to