xfs: Check for extent overflow when swapping extents
Removing an initial range of source/donor file's extent and adding a new extent (from donor/source file) in its place will cause extent count to increase by 1. Reviewed-by: Darrick J. Wong <darrick.wong@oracle.com> Reviewed-by: Allison Henderson <allison.henderson@oracle.com> Signed-off-by: Chandan Babu R <chandanrlinux@gmail.com> Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
This commit is contained in:
parent
ee898d78c3
commit
bcc561f21f
|
@ -88,6 +88,13 @@ struct xfs_ifork {
|
|||
*/
|
||||
#define XFS_IEXT_REFLINK_END_COW_CNT (2)
|
||||
|
||||
/*
|
||||
* Removing an initial range of source/donor file's extent and adding a new
|
||||
* extent (from donor/source file) in its place will cause extent count to
|
||||
* increase by 1.
|
||||
*/
|
||||
#define XFS_IEXT_SWAP_RMAP_CNT (1)
|
||||
|
||||
/*
|
||||
* Fork handling.
|
||||
*/
|
||||
|
|
|
@ -1399,6 +1399,22 @@ xfs_swap_extent_rmap(
|
|||
irec.br_blockcount);
|
||||
trace_xfs_swap_extent_rmap_remap_piece(tip, &uirec);
|
||||
|
||||
if (xfs_bmap_is_real_extent(&uirec)) {
|
||||
error = xfs_iext_count_may_overflow(ip,
|
||||
XFS_DATA_FORK,
|
||||
XFS_IEXT_SWAP_RMAP_CNT);
|
||||
if (error)
|
||||
goto out;
|
||||
}
|
||||
|
||||
if (xfs_bmap_is_real_extent(&irec)) {
|
||||
error = xfs_iext_count_may_overflow(tip,
|
||||
XFS_DATA_FORK,
|
||||
XFS_IEXT_SWAP_RMAP_CNT);
|
||||
if (error)
|
||||
goto out;
|
||||
}
|
||||
|
||||
/* Remove the mapping from the donor file. */
|
||||
xfs_bmap_unmap_extent(tp, tip, &uirec);
|
||||
|
||||
|
|
Loading…
Reference in New Issue