]> git.ipfire.org Git - thirdparty/kernel/linux.git/commit
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)
commitb5befa80fdbe287a98480effed9564712924add5
treeddb0cd5dc61a13234b9c10c606506c2705af2b0f
parenta078484921052d0badd827fcc2770b5cfc1d4120
fuse: re-lock request before returning from fuse_ref_folio()

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