From: Tetsuo Handa Date: Wed, 20 Jul 2022 14:47:55 +0000 (+0900) Subject: mm: shrinkers: fix double kfree on shrinker name X-Git-Tag: howlett/maple/20220722_2~149 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=cef252ca974a944db481ec9bfaed1dff672f30f5;p=users%2Fjedix%2Flinux-maple.git mm: shrinkers: fix double kfree on shrinker name syzbot is reporting double kfree() at free_prealloced_shrinker() [1], for destroy_unused_super() calls free_prealloced_shrinker() even if prealloc_shrinker() returned an error. Explicitly clear shrinker name when prealloc_shrinker() called kfree(). Link: https://syzkaller.appspot.com/bug?extid=8b481578352d4637f510 [1] Link: https://lkml.kernel.org/r/ffa62ece-6a42-2644-16cf-0d33ef32c676@I-love.SAKURA.ne.jp Fixes: e33c267ab70de424 ("mm: shrinkers: provide shrinkers with names") Reported-by: syzbot Signed-off-by: Tetsuo Handa Acked-by: Roman Gushchin Signed-off-by: Andrew Morton --- diff --git a/mm/vmscan.c b/mm/vmscan.c index f58761cea0a06..f8d97b905f210 100644 --- a/mm/vmscan.c +++ b/mm/vmscan.c @@ -704,8 +704,10 @@ int register_shrinker(struct shrinker *shrinker, const char *fmt, ...) return -ENOMEM; err = __register_shrinker(shrinker); - if (err) + if (err) { kfree_const(shrinker->name); + shrinker->name = NULL; + } return err; } #else