]> git.karo-electronics.de Git - karo-tx-linux.git/commit
inotify: fix race when adding a new watch
authorLino Sanfilippo <LinoSanfilippo@gmx.de>
Thu, 27 Jun 2013 23:50:56 +0000 (09:50 +1000)
committerStephen Rothwell <sfr@canb.auug.org.au>
Fri, 28 Jun 2013 06:37:12 +0000 (16:37 +1000)
commit80732432821e03feb9fa0ad9adbacbf6b20fae22
tree895cb6acf7d925f9f1ad78cf1ff8117a51dfb4e5
parent32a017bf8f3b64710edf1215e3eb26917d953fe7
inotify: fix race when adding a new watch

In inotify_new_watch() the number of watches for a group is compared
against the max number of allowed watches and increased afterwards.  The
check and incrementation is not done atomically, so it is possible for
multiple concurrent threads to pass the check and increment the number of
marks above the allowed max.

This patch uses an inotify groups mark_lock to ensure that both check and
incrementation are done atomic.  Furthermore we dont have to worry about
the race that allows a concurrent thread to add a watch just after
inotify_update_existing_watch() returned with -ENOENT anymore, since this
is also synchronized by the groups mark mutex now.

Signed-off-by: Lino Sanfilippo <LinoSanfilippo@gmx.de>
Cc: Eric Paris <eparis@redhat.com>
Cc: Al Viro <viro@zeniv.linux.org.uk>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
fs/notify/inotify/inotify_user.c