]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
mm/damon/sysfs: cleanup attrs subdirs on context dir setup failure
authorSeongJae Park <sj@kernel.org>
Thu, 25 Dec 2025 02:30:35 +0000 (18:30 -0800)
committerAndrew Morton <akpm@linux-foundation.org>
Thu, 15 Jan 2026 06:16:23 +0000 (22:16 -0800)
When a context DAMON sysfs directory setup is failed after setup of attrs/
directory, subdirectories of attrs/ directory are not cleaned up.  As a
result, DAMON sysfs interface is nearly broken until the system reboots,
and the memory for the unremoved directory is leaked.

Cleanup the directories under such failures.

Link: https://lkml.kernel.org/r/20251225023043.18579-3-sj@kernel.org
Fixes: c951cd3b8901 ("mm/damon: implement a minimal stub for sysfs-based DAMON interface")
Signed-off-by: SeongJae Park <sj@kernel.org>
Cc: chongjiapeng <jiapeng.chong@linux.alibaba.com>
Cc: <stable@vger.kernel.org> # 5.18.x
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
mm/damon/sysfs.c

index a669de0687706259b9cf7a49657ad79859a912d0..95fd9375a7d84110b25b5f52ec723b827e6d11c8 100644 (file)
@@ -950,7 +950,7 @@ static int damon_sysfs_context_add_dirs(struct damon_sysfs_context *context)
 
        err = damon_sysfs_context_set_targets(context);
        if (err)
-               goto put_attrs_out;
+               goto rmdir_put_attrs_out;
 
        err = damon_sysfs_context_set_schemes(context);
        if (err)
@@ -960,7 +960,8 @@ static int damon_sysfs_context_add_dirs(struct damon_sysfs_context *context)
 put_targets_attrs_out:
        kobject_put(&context->targets->kobj);
        context->targets = NULL;
-put_attrs_out:
+rmdir_put_attrs_out:
+       damon_sysfs_attrs_rm_dirs(context->attrs);
        kobject_put(&context->attrs->kobj);
        context->attrs = NULL;
        return err;