diff options
Diffstat (limited to 'fs/xfs/xfs_bmap_util.c')
| -rw-r--r-- | fs/xfs/xfs_bmap_util.c | 81 | 
1 files changed, 16 insertions, 65 deletions
| diff --git a/fs/xfs/xfs_bmap_util.c b/fs/xfs/xfs_bmap_util.c index addbd74ecd8e..5d263dfdb3bc 100644 --- a/fs/xfs/xfs_bmap_util.c +++ b/fs/xfs/xfs_bmap_util.c @@ -406,10 +406,10 @@ xfs_getbmap_report_one(  	struct xfs_bmbt_irec	*got)  {  	struct kgetbmap		*p = out + bmv->bmv_entries; -	bool			shared = false, trimmed = false; +	bool			shared = false;  	int			error; -	error = xfs_reflink_trim_around_shared(ip, got, &shared, &trimmed); +	error = xfs_reflink_trim_around_shared(ip, got, &shared);  	if (error)  		return error; @@ -702,13 +702,9 @@ xfs_bmap_punch_delalloc_range(  	struct xfs_iext_cursor	icur;  	int			error = 0; -	xfs_ilock(ip, XFS_ILOCK_EXCL); -	if (!(ifp->if_flags & XFS_IFEXTENTS)) { -		error = xfs_iread_extents(NULL, ip, XFS_DATA_FORK); -		if (error) -			goto out_unlock; -	} +	ASSERT(ifp->if_flags & XFS_IFEXTENTS); +	xfs_ilock(ip, XFS_ILOCK_EXCL);  	if (!xfs_iext_lookup_extent_before(ip, ifp, &end_fsb, &icur, &got))  		goto out_unlock; @@ -1047,44 +1043,6 @@ out_trans_cancel:  }  static int -xfs_adjust_extent_unmap_boundaries( -	struct xfs_inode	*ip, -	xfs_fileoff_t		*startoffset_fsb, -	xfs_fileoff_t		*endoffset_fsb) -{ -	struct xfs_mount	*mp = ip->i_mount; -	struct xfs_bmbt_irec	imap; -	int			nimap, error; -	xfs_extlen_t		mod = 0; - -	nimap = 1; -	error = xfs_bmapi_read(ip, *startoffset_fsb, 1, &imap, &nimap, 0); -	if (error) -		return error; - -	if (nimap && imap.br_startblock != HOLESTARTBLOCK) { -		ASSERT(imap.br_startblock != DELAYSTARTBLOCK); -		div_u64_rem(imap.br_startblock, mp->m_sb.sb_rextsize, &mod); -		if (mod) -			*startoffset_fsb += mp->m_sb.sb_rextsize - mod; -	} - -	nimap = 1; -	error = xfs_bmapi_read(ip, *endoffset_fsb - 1, 1, &imap, &nimap, 0); -	if (error) -		return error; - -	if (nimap && imap.br_startblock != HOLESTARTBLOCK) { -		ASSERT(imap.br_startblock != DELAYSTARTBLOCK); -		mod++; -		if (mod && mod != mp->m_sb.sb_rextsize) -			*endoffset_fsb -= mod; -	} - -	return 0; -} - -static int  xfs_flush_unmap_range(  	struct xfs_inode	*ip,  	xfs_off_t		offset, @@ -1137,19 +1095,8 @@ xfs_free_file_space(  	endoffset_fsb = XFS_B_TO_FSBT(mp, offset + len);  	/* -	 * Need to zero the stuff we're not freeing, on disk.  If it's a RT file -	 * and we can't use unwritten extents then we actually need to ensure -	 * to zero the whole extent, otherwise we just need to take of block -	 * boundaries, and xfs_bunmapi will handle the rest. +	 * Need to zero the stuff we're not freeing, on disk.  	 */ -	if (XFS_IS_REALTIME_INODE(ip) && -	    !xfs_sb_version_hasextflgbit(&mp->m_sb)) { -		error = xfs_adjust_extent_unmap_boundaries(ip, &startoffset_fsb, -				&endoffset_fsb); -		if (error) -			return error; -	} -  	if (endoffset_fsb > startoffset_fsb) {  		while (!done) {  			error = xfs_unmap_extent(ip, startoffset_fsb, @@ -1584,7 +1531,7 @@ xfs_swap_extent_rmap(  					tirec.br_blockcount, &irec,  					&nimaps, 0);  			if (error) -				goto out_defer; +				goto out;  			ASSERT(nimaps == 1);  			ASSERT(tirec.br_startoff == irec.br_startoff);  			trace_xfs_swap_extent_rmap_remap_piece(ip, &irec); @@ -1599,22 +1546,22 @@ xfs_swap_extent_rmap(  			/* Remove the mapping from the donor file. */  			error = xfs_bmap_unmap_extent(tp, tip, &uirec);  			if (error) -				goto out_defer; +				goto out;  			/* Remove the mapping from the source file. */  			error = xfs_bmap_unmap_extent(tp, ip, &irec);  			if (error) -				goto out_defer; +				goto out;  			/* Map the donor file's blocks into the source file. */  			error = xfs_bmap_map_extent(tp, ip, &uirec);  			if (error) -				goto out_defer; +				goto out;  			/* Map the source file's blocks into the donor file. */  			error = xfs_bmap_map_extent(tp, tip, &irec);  			if (error) -				goto out_defer; +				goto out;  			error = xfs_defer_finish(tpp);  			tp = *tpp; @@ -1636,8 +1583,6 @@ xfs_swap_extent_rmap(  	tip->i_d.di_flags2 = tip_flags2;  	return 0; -out_defer: -	xfs_defer_cancel(tp);  out:  	trace_xfs_swap_extent_rmap_error(ip, error, _RET_IP_);  	tip->i_d.di_flags2 = tip_flags2; @@ -1830,6 +1775,12 @@ xfs_swap_extents(  	if (error)  		goto out_unlock; +	if (xfs_inode_has_cow_data(tip)) { +		error = xfs_reflink_cancel_cow_range(tip, 0, NULLFILEOFF, true); +		if (error) +			return error; +	} +  	/*  	 * Extent "swapping" with rmap requires a permanent reservation and  	 * a block reservation because it's really just a remap operation | 
