summaryrefslogtreecommitdiffstats
path: root/fs/unicode/utf8-norm.c
diff options
context:
space:
mode:
authorMarc Zyngier <maz@kernel.org>2020-08-19 18:12:17 +0200
committerAl Viro <viro@zeniv.linux.org.uk>2020-08-23 00:23:57 +0200
commita9ed4a6560b8562b7e2e2bed9527e88001f7b682 (patch)
tree0769da3ad923b7c84ce4eb86fd2bc3e9fde6efe6 /fs/unicode/utf8-norm.c
parentLinux 5.9-rc1 (diff)
downloadlinux-a9ed4a6560b8562b7e2e2bed9527e88001f7b682.tar.xz
linux-a9ed4a6560b8562b7e2e2bed9527e88001f7b682.zip
epoll: Keep a reference on files added to the check list
When adding a new fd to an epoll, and that this new fd is an epoll fd itself, we recursively scan the fds attached to it to detect cycles, and add non-epool files to a "check list" that gets subsequently parsed. However, this check list isn't completely safe when deletions can happen concurrently. To sidestep the issue, make sure that a struct file placed on the check list sees its f_count increased, ensuring that a concurrent deletion won't result in the file disapearing from under our feet. Cc: stable@vger.kernel.org Signed-off-by: Marc Zyngier <maz@kernel.org> Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'fs/unicode/utf8-norm.c')
0 files changed, 0 insertions, 0 deletions