Commit 384ff09b authored by Darrick J. Wong's avatar Darrick J. Wong

xfs: don't release log intent items when recovery fails

Nowadays, log recovery will call ->release on the recovered intent items
if recovery fails.  Therefore, it's redundant to release them from
inside the ->recover functions when they're about to return an error.
Signed-off-by: default avatarDarrick J. Wong <darrick.wong@oracle.com>
Reviewed-by: default avatarChristoph Hellwig <hch@lst.de>
Reviewed-by: default avatarDave Chinner <dchinner@redhat.com>
parent 2dbf872c
...@@ -444,10 +444,8 @@ xfs_bui_item_recover( ...@@ -444,10 +444,8 @@ xfs_bui_item_recover(
int error = 0; int error = 0;
/* Only one mapping operation per BUI... */ /* Only one mapping operation per BUI... */
if (buip->bui_format.bui_nextents != XFS_BUI_MAX_FAST_EXTENTS) { if (buip->bui_format.bui_nextents != XFS_BUI_MAX_FAST_EXTENTS)
xfs_bui_release(buip);
return -EFSCORRUPTED; return -EFSCORRUPTED;
}
/* /*
* First check the validity of the extent described by the * First check the validity of the extent described by the
...@@ -473,14 +471,8 @@ xfs_bui_item_recover( ...@@ -473,14 +471,8 @@ xfs_bui_item_recover(
startblock_fsb >= mp->m_sb.sb_dblocks || startblock_fsb >= mp->m_sb.sb_dblocks ||
bmap->me_len >= mp->m_sb.sb_agblocks || bmap->me_len >= mp->m_sb.sb_agblocks ||
inode_fsb >= mp->m_sb.sb_dblocks || inode_fsb >= mp->m_sb.sb_dblocks ||
(bmap->me_flags & ~XFS_BMAP_EXTENT_FLAGS)) { (bmap->me_flags & ~XFS_BMAP_EXTENT_FLAGS))
/*
* This will pull the BUI from the AIL and
* free the memory associated with it.
*/
xfs_bui_release(buip);
return -EFSCORRUPTED; return -EFSCORRUPTED;
}
error = xfs_trans_alloc(mp, &M_RES(mp)->tr_itruncate, error = xfs_trans_alloc(mp, &M_RES(mp)->tr_itruncate,
XFS_EXTENTADD_SPACE_RES(mp, XFS_DATA_FORK), 0, 0, &tp); XFS_EXTENTADD_SPACE_RES(mp, XFS_DATA_FORK), 0, 0, &tp);
......
...@@ -608,14 +608,8 @@ xfs_efi_item_recover( ...@@ -608,14 +608,8 @@ xfs_efi_item_recover(
if (startblock_fsb == 0 || if (startblock_fsb == 0 ||
extp->ext_len == 0 || extp->ext_len == 0 ||
startblock_fsb >= mp->m_sb.sb_dblocks || startblock_fsb >= mp->m_sb.sb_dblocks ||
extp->ext_len >= mp->m_sb.sb_agblocks) { extp->ext_len >= mp->m_sb.sb_agblocks)
/*
* This will pull the EFI from the AIL and
* free the memory associated with it.
*/
xfs_efi_release(efip);
return -EFSCORRUPTED; return -EFSCORRUPTED;
}
} }
error = xfs_trans_alloc(mp, &M_RES(mp)->tr_itruncate, 0, 0, 0, &tp); error = xfs_trans_alloc(mp, &M_RES(mp)->tr_itruncate, 0, 0, 0, &tp);
......
...@@ -467,14 +467,8 @@ xfs_cui_item_recover( ...@@ -467,14 +467,8 @@ xfs_cui_item_recover(
refc->pe_len == 0 || refc->pe_len == 0 ||
startblock_fsb >= mp->m_sb.sb_dblocks || startblock_fsb >= mp->m_sb.sb_dblocks ||
refc->pe_len >= mp->m_sb.sb_agblocks || refc->pe_len >= mp->m_sb.sb_agblocks ||
(refc->pe_flags & ~XFS_REFCOUNT_EXTENT_FLAGS)) { (refc->pe_flags & ~XFS_REFCOUNT_EXTENT_FLAGS))
/*
* This will pull the CUI from the AIL and
* free the memory associated with it.
*/
xfs_cui_release(cuip);
return -EFSCORRUPTED; return -EFSCORRUPTED;
}
} }
/* /*
......
...@@ -511,14 +511,8 @@ xfs_rui_item_recover( ...@@ -511,14 +511,8 @@ xfs_rui_item_recover(
rmap->me_len == 0 || rmap->me_len == 0 ||
startblock_fsb >= mp->m_sb.sb_dblocks || startblock_fsb >= mp->m_sb.sb_dblocks ||
rmap->me_len >= mp->m_sb.sb_agblocks || rmap->me_len >= mp->m_sb.sb_agblocks ||
(rmap->me_flags & ~XFS_RMAP_EXTENT_FLAGS)) { (rmap->me_flags & ~XFS_RMAP_EXTENT_FLAGS))
/*
* This will pull the RUI from the AIL and
* free the memory associated with it.
*/
xfs_rui_release(ruip);
return -EFSCORRUPTED; return -EFSCORRUPTED;
}
} }
error = xfs_trans_alloc(mp, &M_RES(mp)->tr_itruncate, error = xfs_trans_alloc(mp, &M_RES(mp)->tr_itruncate,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment