Skip to content
Snippets Groups Projects
Commit 23717b34 authored by ZhangXiaoxu's avatar ZhangXiaoxu Committed by 谢秀奇
Browse files

inotify: Fix fsnotify_mark refcount leak in inotify_update_existing_watch()

euler inclusion
category: bugfix
bugzilla: 10982
CVE: NA
--------------------------------------------------

commit 4d97f7d5 ("inotify: Add flag IN_MASK_CREATE for
inotify_add_watch()") forgot to call fsnotify_put_mark() with
IN_MASK_CREATE after fsnotify_find_mark()

Fixes: 4d97f7d5 ("inotify: Add flag IN_MASK_CREATE for inotify_add_watch()")
Link: https://www.spinics.net/lists/linux-fsdevel/msg140540.html



Reported-by: default avatarHulk Robot <hulkci@huawei.com>
Signed-off-by: default avatarZhangXiaoxu <zhangxiaoxu5@huawei.com>
Reviewed-by: default avatarMiao Xie <miaoxie@huawei.com>
Signed-off-by: default avatarYang Yingliang <yangyingliang@huawei.com>
parent c6f71dda
Branches
Tags
No related merge requests found
......@@ -519,8 +519,10 @@ static int inotify_update_existing_watch(struct fsnotify_group *group,
fsn_mark = fsnotify_find_mark(&inode->i_fsnotify_marks, group);
if (!fsn_mark)
return -ENOENT;
else if (create)
return -EEXIST;
else if (create) {
ret = -EEXIST;
goto out;
}
i_mark = container_of(fsn_mark, struct inotify_inode_mark, fsn_mark);
......@@ -547,7 +549,7 @@ static int inotify_update_existing_watch(struct fsnotify_group *group,
/* return the wd */
ret = i_mark->wd;
out:
/* match the get from fsnotify_find_mark() */
fsnotify_put_mark(fsn_mark);
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment