diff mbox series

inotify: Fix fsnotify_mark refcount leak in inotify_update_existing_watch()

Message ID 1551489452-30199-1-git-send-email-zhangxiaoxu5@huawei.com (mailing list archive)
State New, archived
Headers show
Series inotify: Fix fsnotify_mark refcount leak in inotify_update_existing_watch() | expand

Commit Message

Zhang Xiaoxu March 2, 2019, 1:17 a.m. UTC
Commit 4d97f7d53da7dc83 ("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: 4d97f7d53da7dc83 ("inotify: Add flag IN_MASK_CREATE for inotify_add_watch()")
Signed-off-by: ZhangXiaoxu <zhangxiaoxu5@huawei.com>
---
 fs/notify/inotify/inotify_user.c | 7 +++++--
 1 file changed, 5 insertions(+), 2 deletions(-)

Comments

Zhang Xiaoxu March 4, 2019, 1:10 a.m. UTC | #1
ping.

On 3/2/2019 9:17 AM, ZhangXiaoxu wrote:
> Commit 4d97f7d53da7dc83 ("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: 4d97f7d53da7dc83 ("inotify: Add flag IN_MASK_CREATE for inotify_add_watch()")
> Signed-off-by: ZhangXiaoxu <zhangxiaoxu5@huawei.com>
> ---
>   fs/notify/inotify/inotify_user.c | 7 +++++--
>   1 file changed, 5 insertions(+), 2 deletions(-)
> 
> diff --git a/fs/notify/inotify/inotify_user.c b/fs/notify/inotify/inotify_user.c
> index 798f125..3b7b8e9 100644
> --- a/fs/notify/inotify/inotify_user.c
> +++ b/fs/notify/inotify/inotify_user.c
> @@ -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);
>   
> @@ -548,6 +550,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);
>   
>
Zhang Xiaoxu March 11, 2019, 7:48 a.m. UTC | #2
ping.

On 3/4/2019 9:10 AM, zhangxiaoxu (A) wrote:
> ping.
> 
> On 3/2/2019 9:17 AM, ZhangXiaoxu wrote:
>> Commit 4d97f7d53da7dc83 ("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: 4d97f7d53da7dc83 ("inotify: Add flag IN_MASK_CREATE for inotify_add_watch()")
>> Signed-off-by: ZhangXiaoxu <zhangxiaoxu5@huawei.com>
>> ---
>>   fs/notify/inotify/inotify_user.c | 7 +++++--
>>   1 file changed, 5 insertions(+), 2 deletions(-)
>>
>> diff --git a/fs/notify/inotify/inotify_user.c b/fs/notify/inotify/inotify_user.c
>> index 798f125..3b7b8e9 100644
>> --- a/fs/notify/inotify/inotify_user.c
>> +++ b/fs/notify/inotify/inotify_user.c
>> @@ -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);
>> @@ -548,6 +550,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);
>>
Amir Goldstein March 11, 2019, 8:36 a.m. UTC | #3
On Mon, Mar 11, 2019 at 9:49 AM zhangxiaoxu (A) <zhangxiaoxu5@huawei.com> wrote:
>
> ping.

Fix looks good.
Maintainer looks on vacation ;-)

Thanks,
Amir.

>
> On 3/4/2019 9:10 AM, zhangxiaoxu (A) wrote:
> > ping.
> >
> > On 3/2/2019 9:17 AM, ZhangXiaoxu wrote:
> >> Commit 4d97f7d53da7dc83 ("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: 4d97f7d53da7dc83 ("inotify: Add flag IN_MASK_CREATE for inotify_add_watch()")
> >> Signed-off-by: ZhangXiaoxu <zhangxiaoxu5@huawei.com>
> >> ---
> >>   fs/notify/inotify/inotify_user.c | 7 +++++--
> >>   1 file changed, 5 insertions(+), 2 deletions(-)
> >>
> >> diff --git a/fs/notify/inotify/inotify_user.c b/fs/notify/inotify/inotify_user.c
> >> index 798f125..3b7b8e9 100644
> >> --- a/fs/notify/inotify/inotify_user.c
> >> +++ b/fs/notify/inotify/inotify_user.c
> >> @@ -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);
> >> @@ -548,6 +550,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);
> >>
>
Jan Kara March 11, 2019, 9:13 a.m. UTC | #4
On Sat 02-03-19 09:17:32, ZhangXiaoxu wrote:
> Commit 4d97f7d53da7dc83 ("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: 4d97f7d53da7dc83 ("inotify: Add flag IN_MASK_CREATE for inotify_add_watch()")
> Signed-off-by: ZhangXiaoxu <zhangxiaoxu5@huawei.com>

Thanks for the patch! I've added it to my tree.

								Honza

> ---
>  fs/notify/inotify/inotify_user.c | 7 +++++--
>  1 file changed, 5 insertions(+), 2 deletions(-)
> 
> diff --git a/fs/notify/inotify/inotify_user.c b/fs/notify/inotify/inotify_user.c
> index 798f125..3b7b8e9 100644
> --- a/fs/notify/inotify/inotify_user.c
> +++ b/fs/notify/inotify/inotify_user.c
> @@ -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);
>  
> @@ -548,6 +550,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);
>  
> -- 
> 2.7.4
>
diff mbox series

Patch

diff --git a/fs/notify/inotify/inotify_user.c b/fs/notify/inotify/inotify_user.c
index 798f125..3b7b8e9 100644
--- a/fs/notify/inotify/inotify_user.c
+++ b/fs/notify/inotify/inotify_user.c
@@ -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);
 
@@ -548,6 +550,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);