diff options
author | Dave Chinner <dchinner@redhat.com> | 2023-06-05 04:05:27 +1000 |
---|---|---|
committer | Dave Chinner <david@fromorbit.com> | 2023-06-05 04:05:27 +1000 |
commit | 89a4bf0dc3857569a77061d3d5ea2ac85f7e13c6 (patch) | |
tree | 3b7c593d83006e270db119dc0b4ffc261c284f19 /fs/pnode.h | |
parent | 9561de3a55bed6bdd44a12820ba81ec416e705a7 (diff) |
xfs: buffer pins need to hold a buffer reference
When a buffer is unpinned by xfs_buf_item_unpin(), we need to access
the buffer after we've dropped the buffer log item reference count.
This opens a window where we can have two racing unpins for the
buffer item (e.g. shutdown checkpoint context callback processing
racing with journal IO iclog completion processing) and both attempt
to access the buffer after dropping the BLI reference count. If we
are unlucky, the "BLI freed" context wins the race and frees the
buffer before the "BLI still active" case checks the buffer pin
count.
This results in a use after free that can only be triggered
in active filesystem shutdown situations.
To fix this, we need to ensure that buffer existence extends beyond
the BLI reference count checks and until the unpin processing is
complete. This implies that a buffer pin operation must also take a
buffer reference to ensure that the buffer cannot be freed until the
buffer unpin processing is complete.
Reported-by: yangerkun <yangerkun@huawei.com>
Signed-off-by: Dave Chinner <dchinner@redhat.com>
Reviewed-by: Darrick J. Wong <djwong@kernel.org>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Dave Chinner <david@fromorbit.com>
Diffstat (limited to 'fs/pnode.h')
0 files changed, 0 insertions, 0 deletions