提交 a66c04b4 编写于 作者: J Jeff Layton 提交者: Linus Torvalds

inotify: convert inotify_add_to_idr() to use idr_alloc_cyclic()

Signed-off-by: NJeff Layton <jlayton@redhat.com>
Cc: John McCutchan <john@johnmccutchan.com>
Cc: Robert Love <rlove@rlove.org>
Cc: Eric Paris <eparis@parisplace.org>
Cc: Tejun Heo <tj@kernel.org>
Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
上级 398c33aa
...@@ -359,7 +359,6 @@ static int inotify_find_inode(const char __user *dirname, struct path *path, uns ...@@ -359,7 +359,6 @@ 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,
struct inotify_inode_mark *i_mark) struct inotify_inode_mark *i_mark)
{ {
int ret; int ret;
...@@ -367,11 +366,10 @@ static int inotify_add_to_idr(struct idr *idr, spinlock_t *idr_lock, ...@@ -367,11 +366,10 @@ static int inotify_add_to_idr(struct idr *idr, spinlock_t *idr_lock,
idr_preload(GFP_KERNEL); idr_preload(GFP_KERNEL);
spin_lock(idr_lock); spin_lock(idr_lock);
ret = idr_alloc(idr, i_mark, *last_wd + 1, 0, GFP_NOWAIT); ret = idr_alloc_cyclic(idr, i_mark, 1, 0, GFP_NOWAIT);
if (ret >= 0) { if (ret >= 0) {
/* we added the mark to the idr, take a reference */ /* we added the mark to the idr, take a reference */
i_mark->wd = ret; i_mark->wd = ret;
*last_wd = i_mark->wd;
fsnotify_get_mark(&i_mark->fsn_mark); fsnotify_get_mark(&i_mark->fsn_mark);
} }
...@@ -638,8 +636,7 @@ static int inotify_new_watch(struct fsnotify_group *group, ...@@ -638,8 +636,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, tmp_i_mark);
tmp_i_mark);
if (ret) if (ret)
goto out_err; goto out_err;
...@@ -697,7 +694,6 @@ static struct fsnotify_group *inotify_new_group(unsigned int max_events) ...@@ -697,7 +694,6 @@ static struct fsnotify_group *inotify_new_group(unsigned int max_events)
spin_lock_init(&group->inotify_data.idr_lock); spin_lock_init(&group->inotify_data.idr_lock);
idr_init(&group->inotify_data.idr); idr_init(&group->inotify_data.idr);
group->inotify_data.last_wd = 0;
group->inotify_data.user = get_current_user(); group->inotify_data.user = get_current_user();
if (atomic_inc_return(&group->inotify_data.user->inotify_devs) > if (atomic_inc_return(&group->inotify_data.user->inotify_devs) >
......
...@@ -157,7 +157,6 @@ struct fsnotify_group { ...@@ -157,7 +157,6 @@ struct fsnotify_group {
struct inotify_group_private_data { struct inotify_group_private_data {
spinlock_t idr_lock; spinlock_t idr_lock;
struct idr idr; struct idr idr;
u32 last_wd;
struct user_struct *user; struct user_struct *user;
} inotify_data; } inotify_data;
#endif #endif
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册