]> git.proxmox.com Git - mirror_ubuntu-focal-kernel.git/commit
xfs: don't ever return a stale pointer from __xfs_dir3_free_read
authorDarrick J. Wong <darrick.wong@oracle.com>
Wed, 11 Mar 2020 17:37:55 +0000 (10:37 -0700)
committerStefan Bader <stefan.bader@canonical.com>
Mon, 9 Nov 2020 13:47:37 +0000 (14:47 +0100)
commitc6a3e496783855e752778eb46cf41250ff6c99c3
tree0ccf72276e6f49230d2d8e984a401601adb3c101
parenta2a55d3ae4d70e4fd4577338a32fcbdc43d851f3
xfs: don't ever return a stale pointer from __xfs_dir3_free_read

BugLink: https://bugs.launchpad.net/bugs/1900624
[ Upstream commit 1cb5deb5bc095c070c09a4540c45f9c9ba24be43 ]

If we decide that a directory free block is corrupt, we must take care
not to leak a buffer pointer to the caller.  After xfs_trans_brelse
returns, the buffer can be freed or reused, which means that we have to
set *bpp back to NULL.

Callers are supposed to notice the nonzero return value and not use the
buffer pointer, but we should code more defensively, even if all current
callers handle this situation correctly.

Fixes: de14c5f541e7 ("xfs: verify free block header fields")
Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
Reviewed-by: Dave Chinner <dchinner@redhat.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
Signed-off-by: Kamal Mostafa <kamal@canonical.com>
Signed-off-by: Ian May <ian.may@canonical.com>
fs/xfs/libxfs/xfs_dir2_node.c