]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
fix a leak in fcntl_dirnotify()
authorAl Viro <viro@zeniv.linux.org.uk>
Sat, 12 Jul 2025 17:18:43 +0000 (18:18 +0100)
committerChristian Brauner <brauner@kernel.org>
Mon, 14 Jul 2025 08:13:31 +0000 (10:13 +0200)
[into #fixes, unless somebody objects]

Lifetime of new_dn_mark is controlled by that of its ->fsn_mark,
pointed to by new_fsn_mark.  Unfortunately, a failure exit had
been inserted between the allocation of new_dn_mark and the
call of fsnotify_init_mark(), ending up with a leak.

Fixes: 1934b212615d "file: reclaim 24 bytes from f_owner"
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Link: https://lore.kernel.org/20250712171843.GB1880847@ZenIV
Signed-off-by: Christian Brauner <brauner@kernel.org>
fs/notify/dnotify/dnotify.c

index c4cdaf5fa7eda6054468a458b69905ad8d322544..9fb73bafd41d28cdb64110c3d3252a215f4f0a93 100644 (file)
@@ -308,6 +308,10 @@ int fcntl_dirnotify(int fd, struct file *filp, unsigned int arg)
                goto out_err;
        }
 
+       error = file_f_owner_allocate(filp);
+       if (error)
+               goto out_err;
+
        /* new fsnotify mark, we expect most fcntl calls to add a new mark */
        new_dn_mark = kmem_cache_alloc(dnotify_mark_cache, GFP_KERNEL);
        if (!new_dn_mark) {
@@ -315,10 +319,6 @@ int fcntl_dirnotify(int fd, struct file *filp, unsigned int arg)
                goto out_err;
        }
 
-       error = file_f_owner_allocate(filp);
-       if (error)
-               goto out_err;
-
        /* set up the new_fsn_mark and new_dn_mark */
        new_fsn_mark = &new_dn_mark->fsn_mark;
        fsnotify_init_mark(new_fsn_mark, dnotify_group);