summaryrefslogtreecommitdiffstats
path: root/fs/affs/super.c
diff options
context:
space:
mode:
authorWill Woods <wwoods@redhat.com>2014-05-06 21:50:10 +0200
committerLinus Torvalds <torvalds@linux-foundation.org>2014-05-06 22:04:59 +0200
commit1e2ee49f7f1b79f0b14884fe6a602f0411b39552 (patch)
tree06e78cfe43e34b040d713585cca950e507d45260 /fs/affs/super.c
parentslub: use sysfs'es release mechanism for kmem_cache (diff)
downloadlinux-1e2ee49f7f1b79f0b14884fe6a602f0411b39552.tar.xz
linux-1e2ee49f7f1b79f0b14884fe6a602f0411b39552.zip
fanotify: fix -EOVERFLOW with large files on 64-bit
On 64-bit systems, O_LARGEFILE is automatically added to flags inside the open() syscall (also openat(), blkdev_open(), etc). Userspace therefore defines O_LARGEFILE to be 0 - you can use it, but it's a no-op. Everything should be O_LARGEFILE by default. But: when fanotify does create_fd() it uses dentry_open(), which skips all that. And userspace can't set O_LARGEFILE in fanotify_init() because it's defined to 0. So if fanotify gets an event regarding a large file, the read() will just fail with -EOVERFLOW. This patch adds O_LARGEFILE to fanotify_init()'s event_f_flags on 64-bit systems, using the same test as open()/openat()/etc. Addresses https://bugzilla.redhat.com/show_bug.cgi?id=696821 Signed-off-by: Will Woods <wwoods@redhat.com> Acked-by: Eric Paris <eparis@redhat.com> Reviewed-by: Jan Kara <jack@suse.cz> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'fs/affs/super.c')
0 files changed, 0 insertions, 0 deletions