summaryrefslogtreecommitdiffstats
path: root/fs/affs/affs.h
diff options
context:
space:
mode:
authorCyrill Gorcunov <gorcunov@gmail.com>2017-02-27 23:27:40 +0100
committerLinus Torvalds <torvalds@linux-foundation.org>2017-02-28 03:43:45 +0100
commitc857ab640c0cddf451cf743f1b70f9ad7f103090 (patch)
treea0ef949cbc801e03f37f62181d04e4c5b7326e2a /fs/affs/affs.h
parentinclude/linux/pid.h: use for_each_thread() in do_each_pid_thread() (diff)
downloadlinux-c857ab640c0cddf451cf743f1b70f9ad7f103090.tar.xz
linux-c857ab640c0cddf451cf743f1b70f9ad7f103090.zip
fs,eventpoll: don't test for bitfield with stack value
In case if epoll_ctl is called with operation EPOLL_CTL_DEL then @epds.events variable allocated on stack may contain random bits which we test then for EPOLLEXCLUSIVE. Since currently the test look like if (epds.events & EPOLLEXCLUSIVE) { if (op == EPOLL_CTL_MOD) goto error_tgt_fput; if (op == EPOLL_CTL_ADD && (is_file_epoll(tf.file) || (epds.events & ~EPOLLEXCLUSIVE_OK_BITS))) goto error_tgt_fput; } Nothing serious will happen even if epds.events has this bit set, still better to be on safe side and make sure that we're to test this bit at all. Link: http://lkml.kernel.org/r/20170214154935.GG1850@uranus.lan Signed-off-by: Cyrill Gorcunov <gorcunov@gmail.com> Cc: Al Viro <viro@zeniv.linux.org.uk> Cc: Andrey Vagin <avagin@virtuozzo.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'fs/affs/affs.h')
0 files changed, 0 insertions, 0 deletions