diff options
Diffstat (limited to 'fs/xfs/libxfs/xfs_alloc.c')
| -rw-r--r-- | fs/xfs/libxfs/xfs_alloc.c | 15 | 
1 files changed, 5 insertions, 10 deletions
| diff --git a/fs/xfs/libxfs/xfs_alloc.c b/fs/xfs/libxfs/xfs_alloc.c index 203f16c48c19..ea9ac2ad9d36 100644 --- a/fs/xfs/libxfs/xfs_alloc.c +++ b/fs/xfs/libxfs/xfs_alloc.c @@ -3596,7 +3596,8 @@ xfs_free_extent_fix_freelist(  int  __xfs_free_extent(  	struct xfs_trans		*tp, -	xfs_fsblock_t			bno, +	struct xfs_perag		*pag, +	xfs_agblock_t			agbno,  	xfs_extlen_t			len,  	const struct xfs_owner_info	*oinfo,  	enum xfs_ag_resv_type		type, @@ -3604,12 +3605,9 @@ __xfs_free_extent(  {  	struct xfs_mount		*mp = tp->t_mountp;  	struct xfs_buf			*agbp; -	xfs_agnumber_t			agno = XFS_FSB_TO_AGNO(mp, bno); -	xfs_agblock_t			agbno = XFS_FSB_TO_AGBNO(mp, bno);  	struct xfs_agf			*agf;  	int				error;  	unsigned int			busy_flags = 0; -	struct xfs_perag		*pag;  	ASSERT(len != 0);  	ASSERT(type != XFS_AG_RESV_AGFL); @@ -3618,10 +3616,9 @@ __xfs_free_extent(  			XFS_ERRTAG_FREE_EXTENT))  		return -EIO; -	pag = xfs_perag_get(mp, agno);  	error = xfs_free_extent_fix_freelist(tp, pag, &agbp);  	if (error) -		goto err; +		return error;  	agf = agbp->b_addr;  	if (XFS_IS_CORRUPT(mp, agbno >= mp->m_sb.sb_agblocks)) { @@ -3635,20 +3632,18 @@ __xfs_free_extent(  		goto err_release;  	} -	error = xfs_free_ag_extent(tp, agbp, agno, agbno, len, oinfo, type); +	error = xfs_free_ag_extent(tp, agbp, pag->pag_agno, agbno, len, oinfo, +			type);  	if (error)  		goto err_release;  	if (skip_discard)  		busy_flags |= XFS_EXTENT_BUSY_SKIP_DISCARD;  	xfs_extent_busy_insert(tp, pag, agbno, len, busy_flags); -	xfs_perag_put(pag);  	return 0;  err_release:  	xfs_trans_brelse(tp, agbp); -err: -	xfs_perag_put(pag);  	return error;  } | 
