提交 813d08cb 编写于 作者: B Brian Foster 提交者: Darrick J. Wong

xfs: use ->t_dfops for recovery of [b|c]ui log items

Log recovery passes down a central dfops structure to recovery
handlers for bui and cui log items. Each of these handlers allocates
and commits a transaction and defers any remaining operations to be
completed by the main recovery sequence.

Since dfops outlives the transaction in this context, set and clear
->t_dfops appropriately such that the *_finish_item() paths and
below (i.e., xfs_bmapi*()) can expect to find the dfops in the
transaction without it being committed with the dfops attached. This
is required because transaction commit expects that an associated
dfops is finished and in this context the dfops may be populated at
commit time.
Signed-off-by: NBrian Foster <bfoster@redhat.com>
Reviewed-by: NChristoph Hellwig <hch@lst.de>
Reviewed-by: NDarrick J. Wong <darrick.wong@oracle.com>
Signed-off-by: NDarrick J. Wong <darrick.wong@oracle.com>
上级 c9cfdb38
...@@ -441,6 +441,7 @@ xfs_bui_recover( ...@@ -441,6 +441,7 @@ xfs_bui_recover(
XFS_EXTENTADD_SPACE_RES(mp, XFS_DATA_FORK), 0, 0, &tp); XFS_EXTENTADD_SPACE_RES(mp, XFS_DATA_FORK), 0, 0, &tp);
if (error) if (error)
return error; return error;
tp->t_dfops = dfops;
budp = xfs_trans_get_bud(tp, buip); budp = xfs_trans_get_bud(tp, buip);
/* Grab the inode. */ /* Grab the inode. */
...@@ -487,6 +488,12 @@ xfs_bui_recover( ...@@ -487,6 +488,12 @@ xfs_bui_recover(
} }
set_bit(XFS_BUI_RECOVERED, &buip->bui_flags); set_bit(XFS_BUI_RECOVERED, &buip->bui_flags);
/*
* Recovery finishes all deferred ops once intent processing is
* complete. Reset the trans reference because commit expects a finished
* dfops or none at all.
*/
tp->t_dfops = NULL;
error = xfs_trans_commit(tp); error = xfs_trans_commit(tp);
xfs_iunlock(ip, XFS_ILOCK_EXCL); xfs_iunlock(ip, XFS_ILOCK_EXCL);
IRELE(ip); IRELE(ip);
...@@ -494,6 +501,7 @@ xfs_bui_recover( ...@@ -494,6 +501,7 @@ xfs_bui_recover(
return error; return error;
err_inode: err_inode:
tp->t_dfops = NULL;
xfs_trans_cancel(tp); xfs_trans_cancel(tp);
if (ip) { if (ip) {
xfs_iunlock(ip, XFS_ILOCK_EXCL); xfs_iunlock(ip, XFS_ILOCK_EXCL);
......
...@@ -452,6 +452,7 @@ xfs_cui_recover( ...@@ -452,6 +452,7 @@ xfs_cui_recover(
mp->m_refc_maxlevels * 2, 0, XFS_TRANS_RESERVE, &tp); mp->m_refc_maxlevels * 2, 0, XFS_TRANS_RESERVE, &tp);
if (error) if (error)
return error; return error;
tp->t_dfops = dfops;
cudp = xfs_trans_get_cud(tp, cuip); cudp = xfs_trans_get_cud(tp, cuip);
for (i = 0; i < cuip->cui_format.cui_nextents; i++) { for (i = 0; i < cuip->cui_format.cui_nextents; i++) {
...@@ -514,11 +515,18 @@ xfs_cui_recover( ...@@ -514,11 +515,18 @@ xfs_cui_recover(
xfs_refcount_finish_one_cleanup(tp, rcur, error); xfs_refcount_finish_one_cleanup(tp, rcur, error);
set_bit(XFS_CUI_RECOVERED, &cuip->cui_flags); set_bit(XFS_CUI_RECOVERED, &cuip->cui_flags);
/*
* Recovery finishes all deferred ops once intent processing is
* complete. Reset the trans reference because commit expects a finished
* dfops or none at all.
*/
tp->t_dfops = NULL;
error = xfs_trans_commit(tp); error = xfs_trans_commit(tp);
return error; return error;
abort_error: abort_error:
xfs_refcount_finish_one_cleanup(tp, rcur, error); xfs_refcount_finish_one_cleanup(tp, rcur, error);
tp->t_dfops = NULL;
xfs_trans_cancel(tp); xfs_trans_cancel(tp);
return error; return error;
} }
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册