Commit b3b29cd1 authored by Kaixu Xia's avatar Kaixu Xia Committed by Darrick J. Wong

xfs: directly return if the delta equal to zero

The xfs_trans_mod_dquot() function will allocate new tp->t_dqinfo if
it is NULL and make the changes in the tp->t_dqinfo->dqs[XFS_QM_TRANS
_{USR,GRP,PRJ}]. Nowadays seems none of the callers want to join the
dquots to the transaction and push them to device when the delta is
zero. Actually, most of time the caller would check the delta and go
on only when the delta value is not zero, so we should bail out when
it is zero.
Signed-off-by: default avatarKaixu Xia <kaixuxia@tencent.com>
Reviewed-by: default avatarDarrick J. Wong <darrick.wong@oracle.com>
Reviewed-by: default avatarBrian Foster <bfoster@redhat.com>
Reviewed-by: default avatarChristoph Hellwig <hch@lst.de>
Signed-off-by: default avatarDarrick J. Wong <darrick.wong@oracle.com>
parent 04a58620
...@@ -194,6 +194,9 @@ xfs_trans_mod_dquot( ...@@ -194,6 +194,9 @@ xfs_trans_mod_dquot(
ASSERT(XFS_IS_QUOTA_RUNNING(tp->t_mountp)); ASSERT(XFS_IS_QUOTA_RUNNING(tp->t_mountp));
qtrx = NULL; qtrx = NULL;
if (!delta)
return;
if (tp->t_dqinfo == NULL) if (tp->t_dqinfo == NULL)
xfs_trans_alloc_dqinfo(tp); xfs_trans_alloc_dqinfo(tp);
/* /*
...@@ -205,10 +208,8 @@ xfs_trans_mod_dquot( ...@@ -205,10 +208,8 @@ xfs_trans_mod_dquot(
if (qtrx->qt_dquot == NULL) if (qtrx->qt_dquot == NULL)
qtrx->qt_dquot = dqp; qtrx->qt_dquot = dqp;
if (delta) { trace_xfs_trans_mod_dquot_before(qtrx);
trace_xfs_trans_mod_dquot_before(qtrx); trace_xfs_trans_mod_dquot(tp, dqp, field, delta);
trace_xfs_trans_mod_dquot(tp, dqp, field, delta);
}
switch (field) { switch (field) {
/* regular disk blk reservation */ /* regular disk blk reservation */
...@@ -261,8 +262,7 @@ xfs_trans_mod_dquot( ...@@ -261,8 +262,7 @@ xfs_trans_mod_dquot(
ASSERT(0); ASSERT(0);
} }
if (delta) trace_xfs_trans_mod_dquot_after(qtrx);
trace_xfs_trans_mod_dquot_after(qtrx);
} }
...@@ -687,14 +687,9 @@ xfs_trans_dqresv( ...@@ -687,14 +687,9 @@ xfs_trans_dqresv(
*/ */
if (tp) { if (tp) {
ASSERT(flags & XFS_QMOPT_RESBLK_MASK); ASSERT(flags & XFS_QMOPT_RESBLK_MASK);
if (nblks != 0) xfs_trans_mod_dquot(tp, dqp, flags & XFS_QMOPT_RESBLK_MASK,
xfs_trans_mod_dquot(tp, dqp, nblks);
flags & XFS_QMOPT_RESBLK_MASK, xfs_trans_mod_dquot(tp, dqp, XFS_TRANS_DQ_RES_INOS, ninos);
nblks);
if (ninos != 0)
xfs_trans_mod_dquot(tp, dqp,
XFS_TRANS_DQ_RES_INOS,
ninos);
} }
ASSERT(dqp->q_blk.reserved >= dqp->q_blk.count); ASSERT(dqp->q_blk.reserved >= dqp->q_blk.count);
ASSERT(dqp->q_rtb.reserved >= dqp->q_rtb.count); ASSERT(dqp->q_rtb.reserved >= dqp->q_rtb.count);
......
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