]> git.ipfire.org Git - thirdparty/kernel/linux.git/commit
xfs: fix UAF in xchk_btree_check_block_owner
authorDarrick J. Wong <djwong@kernel.org>
Fri, 23 Jan 2026 17:27:39 +0000 (09:27 -0800)
committerDarrick J. Wong <djwong@kernel.org>
Sat, 24 Jan 2026 16:46:41 +0000 (08:46 -0800)
commit1c253e11225bc5167217897885b85093e17c2217
treec81db369e80dd9778bba4d0092c963cf43bda813
parentca27313fb3f23e4ac18532ede4ec1c7cc5814c4a
xfs: fix UAF in xchk_btree_check_block_owner

We cannot dereference bs->cur when trying to determine if bs->cur
aliases bs->sc->sa.{bno,rmap}_cur after the latter has been freed.
Fix this by sampling before type before any freeing could happen.
The correct temporal ordering was broken when we removed xfs_btnum_t.

Cc: r772577952@gmail.com
Cc: <stable@vger.kernel.org> # v6.9
Fixes: ec793e690f801d ("xfs: remove xfs_btnum_t")
Signed-off-by: "Darrick J. Wong" <djwong@kernel.org>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Tested-by: Jiaming Zhang <r772577952@gmail.com>
fs/xfs/scrub/btree.c