From: Csaba Henk Date: Fri, 27 Nov 2009 14:00:14 +0000 (+0530) Subject: fuse: reject O_DIRECT flag also in fuse_create X-Git-Tag: v2.6.31.7~69 X-Git-Url: https://git.fsl.cs.sunysb.edu/?a=commitdiff_plain;h=b79250a273007d1d7f3884c4bc50860c7910b347;p=unionfs-2.6.39.y.git fuse: reject O_DIRECT flag also in fuse_create commit 1b7323965a8c6eee9dc4e345a7ae4bff1dc93149 upstream. The comment in fuse_open about O_DIRECT: "VFS checks this, but only _after_ ->open()" also holds for fuse_create, however, the same kind of check was missing there. As an impact of this bug, open(newfile, O_RDWR|O_CREAT|O_DIRECT) fails, but a stub newfile will remain if the fuse server handled the implied FUSE_CREATE request appropriately. Other impact: in the above situation ima_file_free() will complain to open/free imbalance if CONFIG_IMA is set. Signed-off-by: Csaba Henk Signed-off-by: Miklos Szeredi Cc: Harshavardhana Signed-off-by: Greg Kroah-Hartman --- diff --git a/fs/fuse/dir.c b/fs/fuse/dir.c index e703654e7f4..d0dcaef04e4 100644 --- a/fs/fuse/dir.c +++ b/fs/fuse/dir.c @@ -385,6 +385,9 @@ static int fuse_create_open(struct inode *dir, struct dentry *entry, int mode, if (fc->no_create) return -ENOSYS; + if (flags & O_DIRECT) + return -EINVAL; + forget_req = fuse_get_req(fc); if (IS_ERR(forget_req)) return PTR_ERR(forget_req);