Commit 2a5db859 authored by Long Li's avatar Long Li Committed by Chandan Babu R

xfs: factor out xfs_defer_pending_abort

Factor out xfs_defer_pending_abort() from xfs_defer_trans_abort(), which
not use transaction parameter, so it can be used after the transaction
life cycle.
Signed-off-by: default avatarLong Li <leo.lilong@huawei.com>
Reviewed-by: default avatarDarrick J. Wong <djwong@kernel.org>
Signed-off-by: default avatarChandan Babu R <chandanbabu@kernel.org>
parent b85ea95d
...@@ -245,21 +245,18 @@ xfs_defer_create_intents( ...@@ -245,21 +245,18 @@ xfs_defer_create_intents(
return ret; return ret;
} }
/* Abort all the intents that were committed. */
STATIC void STATIC void
xfs_defer_trans_abort( xfs_defer_pending_abort(
struct xfs_trans *tp, struct xfs_mount *mp,
struct list_head *dop_pending) struct list_head *dop_list)
{ {
struct xfs_defer_pending *dfp; struct xfs_defer_pending *dfp;
const struct xfs_defer_op_type *ops; const struct xfs_defer_op_type *ops;
trace_xfs_defer_trans_abort(tp, _RET_IP_);
/* Abort intent items that don't have a done item. */ /* Abort intent items that don't have a done item. */
list_for_each_entry(dfp, dop_pending, dfp_list) { list_for_each_entry(dfp, dop_list, dfp_list) {
ops = defer_op_types[dfp->dfp_type]; ops = defer_op_types[dfp->dfp_type];
trace_xfs_defer_pending_abort(tp->t_mountp, dfp); trace_xfs_defer_pending_abort(mp, dfp);
if (dfp->dfp_intent && !dfp->dfp_done) { if (dfp->dfp_intent && !dfp->dfp_done) {
ops->abort_intent(dfp->dfp_intent); ops->abort_intent(dfp->dfp_intent);
dfp->dfp_intent = NULL; dfp->dfp_intent = NULL;
...@@ -267,6 +264,16 @@ xfs_defer_trans_abort( ...@@ -267,6 +264,16 @@ xfs_defer_trans_abort(
} }
} }
/* Abort all the intents that were committed. */
STATIC void
xfs_defer_trans_abort(
struct xfs_trans *tp,
struct list_head *dop_pending)
{
trace_xfs_defer_trans_abort(tp, _RET_IP_);
xfs_defer_pending_abort(tp->t_mountp, dop_pending);
}
/* /*
* Capture resources that the caller said not to release ("held") when the * Capture resources that the caller said not to release ("held") when the
* transaction commits. Caller is responsible for zero-initializing @dres. * transaction commits. Caller is responsible for zero-initializing @dres.
......
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