diff options
author | Will Woods <wwoods@redhat.com> | 2014-05-06 21:50:10 +0200 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2014-05-06 22:04:59 +0200 |
commit | 1e2ee49f7f1b79f0b14884fe6a602f0411b39552 (patch) | |
tree | 06e78cfe43e34b040d713585cca950e507d45260 /fs/affs/super.c | |
parent | slub: use sysfs'es release mechanism for kmem_cache (diff) | |
download | linux-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