]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
fuse: re-lock request before returning from fuse_ref_folio()
authorJoanne Koong <joannelkoong@gmail.com>
Tue, 19 May 2026 05:28:07 +0000 (22:28 -0700)
committerMiklos Szeredi <mszeredi@redhat.com>
Tue, 9 Jun 2026 14:11:02 +0000 (16:11 +0200)
fuse_ref_folio() unlocks the request but does not re-lock it before
returning. fuse_chan_abort() can end the request and the async end
callback (eg fuse_writepage_free()) can free the args while the
subsequent copy chain logic after fuse_ref_folio() accesses them,
leading to use-after-free issues.

Fix this by locking the request in fuse_ref_folio() before returning.

Fixes: c3021629a0d8 ("fuse: support splice() reading from fuse device")
Cc: stable@vger.kernel.org
Signed-off-by: Joanne Koong <joannelkoong@gmail.com>
Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>
fs/fuse/dev.c

index 86b62a1d37466526ed0a4dfb93d1819b93a9f9a0..b527d90ef74bacdc0630d3ecea6854db5e6ae58e 100644 (file)
@@ -1106,7 +1106,7 @@ static int fuse_ref_folio(struct fuse_copy_state *cs, struct folio *folio,
        cs->nr_segs++;
        cs->len = 0;
 
-       return 0;
+       return lock_request(cs->req);
 }
 
 /*