fuse: optimize fallocate on permanent failure
authorMiklos Szeredi <mszeredi@suse.cz>
Thu, 26 Apr 2012 08:56:36 +0000 (10:56 +0200)
committerMiklos Szeredi <mszeredi@suse.cz>
Thu, 26 Apr 2012 08:56:36 +0000 (10:56 +0200)
If userspace filesystem doesn't support fallocate, remember this and don't send
request next time.

Signed-off-by: Miklos Szeredi <mszeredi@suse.cz>
fs/fuse/file.c
fs/fuse/fuse_i.h

index e3fee88..bbfd571 100644 (file)
@@ -2185,6 +2185,9 @@ long fuse_file_fallocate(struct file *file, int mode, loff_t offset,
        };
        int err;
 
+       if (fc->no_fallocate)
+               return -EOPNOTSUPP;
+
        req = fuse_get_req(fc);
        if (IS_ERR(req))
                return PTR_ERR(req);
@@ -2196,6 +2199,10 @@ long fuse_file_fallocate(struct file *file, int mode, loff_t offset,
        req->in.args[0].value = &inarg;
        fuse_request_send(fc, req);
        err = req->out.h.error;
+       if (err == -ENOSYS) {
+               fc->no_fallocate = 1;
+               err = -EOPNOTSUPP;
+       }
        fuse_put_request(fc, req);
 
        return err;
index 572cefc..f38fb79 100644 (file)
@@ -478,6 +478,9 @@ struct fuse_conn {
        /** Are BSD file locking primitives not implemented by fs? */
        unsigned no_flock:1;
 
+       /** Is fallocate not implemented by fs? */
+       unsigned no_fallocate:1;
+
        /** The number of requests waiting for completion */
        atomic_t num_waiting;