Commit 7050c488 authored by Eric Paris's avatar Eric Paris

inotify: do not reuse watch descriptors

Prior to 2.6.31 inotify would not reuse watch descriptors until all of
them had been used at least once.  After the rewrite inotify would reuse
watch descriptors.  The selinux utility 'restorecond' was found to have
problems when watch descriptors were reused.  This patch reverts to the
pre inotify rewrite behavior to not reuse watch descriptors.
Signed-off-by: default avatarEric Paris <eparis@redhat.com>
parent 6f3a539e
...@@ -358,7 +358,7 @@ static int inotify_find_inode(const char __user *dirname, struct path *path, uns ...@@ -358,7 +358,7 @@ static int inotify_find_inode(const char __user *dirname, struct path *path, uns
} }
static int inotify_add_to_idr(struct idr *idr, spinlock_t *idr_lock, static int inotify_add_to_idr(struct idr *idr, spinlock_t *idr_lock,
int last_wd, int *last_wd,
struct inotify_inode_mark_entry *ientry) struct inotify_inode_mark_entry *ientry)
{ {
int ret; int ret;
...@@ -368,11 +368,13 @@ static int inotify_add_to_idr(struct idr *idr, spinlock_t *idr_lock, ...@@ -368,11 +368,13 @@ static int inotify_add_to_idr(struct idr *idr, spinlock_t *idr_lock,
return -ENOMEM; return -ENOMEM;
spin_lock(idr_lock); spin_lock(idr_lock);
ret = idr_get_new_above(idr, ientry, last_wd + 1, ret = idr_get_new_above(idr, ientry, *last_wd + 1,
&ientry->wd); &ientry->wd);
/* we added the mark to the idr, take a reference */ /* we added the mark to the idr, take a reference */
if (!ret) if (!ret) {
fsnotify_get_mark(&ientry->fsn_entry); fsnotify_get_mark(&ientry->fsn_entry);
*last_wd = ientry->wd;
}
spin_unlock(idr_lock); spin_unlock(idr_lock);
} while (ret == -EAGAIN); } while (ret == -EAGAIN);
...@@ -647,7 +649,7 @@ static int inotify_new_watch(struct fsnotify_group *group, ...@@ -647,7 +649,7 @@ static int inotify_new_watch(struct fsnotify_group *group,
if (atomic_read(&group->inotify_data.user->inotify_watches) >= inotify_max_user_watches) if (atomic_read(&group->inotify_data.user->inotify_watches) >= inotify_max_user_watches)
goto out_err; goto out_err;
ret = inotify_add_to_idr(idr, idr_lock, group->inotify_data.last_wd, ret = inotify_add_to_idr(idr, idr_lock, &group->inotify_data.last_wd,
tmp_ientry); tmp_ientry);
if (ret) if (ret)
goto out_err; goto out_err;
...@@ -660,9 +662,6 @@ static int inotify_new_watch(struct fsnotify_group *group, ...@@ -660,9 +662,6 @@ static int inotify_new_watch(struct fsnotify_group *group,
goto out_err; goto out_err;
} }
/* update the idr hint, who cares about races, it's just a hint */
group->inotify_data.last_wd = tmp_ientry->wd;
/* increment the number of watches the user has */ /* increment the number of watches the user has */
atomic_inc(&group->inotify_data.user->inotify_watches); atomic_inc(&group->inotify_data.user->inotify_watches);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment