diff options
Diffstat (limited to 'fs')
-rw-r--r-- | fs/fuse/file.c | 7 | ||||
-rw-r--r-- | fs/fuse/fuse_i.h | 3 |
2 files changed, 10 insertions, 0 deletions
diff --git a/fs/fuse/file.c b/fs/fuse/file.c index e3fee88831d4..bbfd571b37e1 100644 --- a/fs/fuse/file.c +++ b/fs/fuse/file.c | |||
@@ -2185,6 +2185,9 @@ long fuse_file_fallocate(struct file *file, int mode, loff_t offset, | |||
2185 | }; | 2185 | }; |
2186 | int err; | 2186 | int err; |
2187 | 2187 | ||
2188 | if (fc->no_fallocate) | ||
2189 | return -EOPNOTSUPP; | ||
2190 | |||
2188 | req = fuse_get_req(fc); | 2191 | req = fuse_get_req(fc); |
2189 | if (IS_ERR(req)) | 2192 | if (IS_ERR(req)) |
2190 | return PTR_ERR(req); | 2193 | return PTR_ERR(req); |
@@ -2196,6 +2199,10 @@ long fuse_file_fallocate(struct file *file, int mode, loff_t offset, | |||
2196 | req->in.args[0].value = &inarg; | 2199 | req->in.args[0].value = &inarg; |
2197 | fuse_request_send(fc, req); | 2200 | fuse_request_send(fc, req); |
2198 | err = req->out.h.error; | 2201 | err = req->out.h.error; |
2202 | if (err == -ENOSYS) { | ||
2203 | fc->no_fallocate = 1; | ||
2204 | err = -EOPNOTSUPP; | ||
2205 | } | ||
2199 | fuse_put_request(fc, req); | 2206 | fuse_put_request(fc, req); |
2200 | 2207 | ||
2201 | return err; | 2208 | return err; |
diff --git a/fs/fuse/fuse_i.h b/fs/fuse/fuse_i.h index 572cefc78012..f38fb795f03c 100644 --- a/fs/fuse/fuse_i.h +++ b/fs/fuse/fuse_i.h | |||
@@ -478,6 +478,9 @@ struct fuse_conn { | |||
478 | /** Are BSD file locking primitives not implemented by fs? */ | 478 | /** Are BSD file locking primitives not implemented by fs? */ |
479 | unsigned no_flock:1; | 479 | unsigned no_flock:1; |
480 | 480 | ||
481 | /** Is fallocate not implemented by fs? */ | ||
482 | unsigned no_fallocate:1; | ||
483 | |||
481 | /** The number of requests waiting for completion */ | 484 | /** The number of requests waiting for completion */ |
482 | atomic_t num_waiting; | 485 | atomic_t num_waiting; |
483 | 486 | ||