Commit b1037058 authored by Christoph Hellwig's avatar Christoph Hellwig Committed by Alex Elder

xfs: unlock the inode before log force in xfs_fsync

Only read the LSN we need to push to with the ilock held, and then release
it before we do the log force to improve concurrency.

This also removes the only direct caller of _xfs_trans_commit, thus
allowing it to be merged into the plain xfs_trans_commit again.
Signed-off-by: default avatarChristoph Hellwig <hch@lst.de>
Signed-off-by: default avatarAlex Elder <aelder@sgi.com>
parent 815cb216
...@@ -137,6 +137,7 @@ xfs_file_fsync( ...@@ -137,6 +137,7 @@ xfs_file_fsync(
struct xfs_trans *tp; struct xfs_trans *tp;
int error = 0; int error = 0;
int log_flushed = 0; int log_flushed = 0;
xfs_lsn_t lsn = 0;
trace_xfs_file_fsync(ip); trace_xfs_file_fsync(ip);
...@@ -214,9 +215,9 @@ xfs_file_fsync( ...@@ -214,9 +215,9 @@ xfs_file_fsync(
*/ */
xfs_trans_ijoin(tp, ip); xfs_trans_ijoin(tp, ip);
xfs_trans_log_inode(tp, ip, XFS_ILOG_CORE); xfs_trans_log_inode(tp, ip, XFS_ILOG_CORE);
xfs_trans_set_sync(tp); error = xfs_trans_commit(tp, 0);
error = _xfs_trans_commit(tp, 0, &log_flushed);
lsn = ip->i_itemp->ili_last_lsn;
xfs_iunlock(ip, XFS_ILOCK_EXCL); xfs_iunlock(ip, XFS_ILOCK_EXCL);
} else { } else {
/* /*
...@@ -227,14 +228,14 @@ xfs_file_fsync( ...@@ -227,14 +228,14 @@ xfs_file_fsync(
* disk yet, the inode will be still be pinned. If it is, * disk yet, the inode will be still be pinned. If it is,
* force the log. * force the log.
*/ */
if (xfs_ipincount(ip)) { if (xfs_ipincount(ip))
error = _xfs_log_force_lsn(mp, lsn = ip->i_itemp->ili_last_lsn;
ip->i_itemp->ili_last_lsn,
XFS_LOG_SYNC, &log_flushed);
}
xfs_iunlock(ip, XFS_ILOCK_SHARED); xfs_iunlock(ip, XFS_ILOCK_SHARED);
} }
if (!error && lsn)
error = _xfs_log_force_lsn(mp, lsn, XFS_LOG_SYNC, &log_flushed);
/* /*
* If we only have a single device, and the log force about was * If we only have a single device, and the log force about was
* a no-op we might have to flush the data device cache here. * a no-op we might have to flush the data device cache here.
......
...@@ -1790,9 +1790,7 @@ xfs_trans_commit_cil( ...@@ -1790,9 +1790,7 @@ xfs_trans_commit_cil(
} }
/* /*
* xfs_trans_commit * Commit the given transaction to the log.
*
* Commit the given transaction to the log a/synchronously.
* *
* XFS disk error handling mechanism is not based on a typical * XFS disk error handling mechanism is not based on a typical
* transaction abort mechanism. Logically after the filesystem * transaction abort mechanism. Logically after the filesystem
...@@ -1804,10 +1802,9 @@ xfs_trans_commit_cil( ...@@ -1804,10 +1802,9 @@ xfs_trans_commit_cil(
* Do not reference the transaction structure after this call. * Do not reference the transaction structure after this call.
*/ */
int int
_xfs_trans_commit( xfs_trans_commit(
struct xfs_trans *tp, struct xfs_trans *tp,
uint flags, uint flags)
int *log_flushed)
{ {
struct xfs_mount *mp = tp->t_mountp; struct xfs_mount *mp = tp->t_mountp;
xfs_lsn_t commit_lsn = -1; xfs_lsn_t commit_lsn = -1;
...@@ -1866,7 +1863,7 @@ _xfs_trans_commit( ...@@ -1866,7 +1863,7 @@ _xfs_trans_commit(
if (sync) { if (sync) {
if (!error) { if (!error) {
error = _xfs_log_force_lsn(mp, commit_lsn, error = _xfs_log_force_lsn(mp, commit_lsn,
XFS_LOG_SYNC, log_flushed); XFS_LOG_SYNC, NULL);
} }
XFS_STATS_INC(xs_trans_sync); XFS_STATS_INC(xs_trans_sync);
} else { } else {
......
...@@ -487,10 +487,7 @@ void xfs_trans_log_efd_extent(xfs_trans_t *, ...@@ -487,10 +487,7 @@ void xfs_trans_log_efd_extent(xfs_trans_t *,
struct xfs_efd_log_item *, struct xfs_efd_log_item *,
xfs_fsblock_t, xfs_fsblock_t,
xfs_extlen_t); xfs_extlen_t);
int _xfs_trans_commit(xfs_trans_t *, int xfs_trans_commit(xfs_trans_t *, uint flags);
uint flags,
int *);
#define xfs_trans_commit(tp, flags) _xfs_trans_commit(tp, flags, NULL)
void xfs_trans_cancel(xfs_trans_t *, int); void xfs_trans_cancel(xfs_trans_t *, int);
int xfs_trans_ail_init(struct xfs_mount *); int xfs_trans_ail_init(struct xfs_mount *);
void xfs_trans_ail_destroy(struct xfs_mount *); void xfs_trans_ail_destroy(struct xfs_mount *);
......
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