]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
gfs2: Fix slab-use-after-free in qd_put
authorAndreas Gruenbacher <agruenba@redhat.com>
Sun, 14 Dec 2025 16:47:34 +0000 (16:47 +0000)
committerAndreas Gruenbacher <agruenba@redhat.com>
Mon, 26 Jan 2026 13:28:18 +0000 (14:28 +0100)
Commit a475c5dd16e5 ("gfs2: Free quota data objects synchronously")
started freeing quota data objects during filesystem shutdown instead of
putting them back onto the LRU list, but it failed to remove these
objects from the LRU list, causing LRU list corruption.  This caused
use-after-free when the shrinker (gfs2_qd_shrink_scan) tried to access
already-freed objects on the LRU list.

Fix this by removing qd objects from the LRU list before freeing them in
qd_put().

Initial fix from Deepanshu Kartikey <kartikey406@gmail.com>.

Fixes: a475c5dd16e5 ("gfs2: Free quota data objects synchronously")
Reported-by: syzbot+046b605f01802054bff0@syzkaller.appspotmail.com
Closes: https://syzkaller.appspot.com/bug?extid=046b605f01802054bff0
Signed-off-by: Andreas Gruenbacher <agruenba@redhat.com>
fs/gfs2/quota.c

index 21dfe1e48da6e16df8eac517ab814436fe66a71c..1c3455093ae8c2fcdcfac7ee08c7e94a5e40e287 100644 (file)
@@ -334,6 +334,7 @@ static void qd_put(struct gfs2_quota_data *qd)
                lockref_mark_dead(&qd->qd_lockref);
                spin_unlock(&qd->qd_lockref.lock);
 
+               list_lru_del_obj(&gfs2_qd_lru, &qd->qd_lru);
                gfs2_qd_dispose(qd);
                return;
        }