aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDave Chinner <dchinner@redhat.com>2011-01-26 21:23:28 -0500
committerAlex Elder <aelder@sgi.com>2011-01-28 10:05:36 -0500
commitc6f990d1ff8e4e53b12f4175eb7d7ea710c3ca73 (patch)
tree109e8d588a9a04ef52b97e751450fe0fffa88a23
parent5315837daee7ed76c31ef643915f7d76ef8c1aa3 (diff)
xfs: handle CIl transaction commit failures correctly
Failure to commit a transaction into the CIL is not handled correctly. This currently can only happen when racing with a shutdown and requires an explicit shutdown check, so it rare and can be avoided. Remove the shutdown check and make the CIL commit a void function to indicate it will always succeed, thereby removing the incorrectly handled failure case. Signed-off-by: Dave Chinner <dchinner@redhat.com> Reviewed-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Alex Elder <aelder@sgi.com>
-rw-r--r--fs/xfs/xfs_log.h2
-rw-r--r--fs/xfs/xfs_log_cil.c8
-rw-r--r--fs/xfs/xfs_trans.c5
3 files changed, 3 insertions, 12 deletions
diff --git a/fs/xfs/xfs_log.h b/fs/xfs/xfs_log.h
index 916eb7db14d9..3bd3291ef8d2 100644
--- a/fs/xfs/xfs_log.h
+++ b/fs/xfs/xfs_log.h
@@ -191,7 +191,7 @@ void xfs_log_ticket_put(struct xlog_ticket *ticket);
191 191
192xlog_tid_t xfs_log_get_trans_ident(struct xfs_trans *tp); 192xlog_tid_t xfs_log_get_trans_ident(struct xfs_trans *tp);
193 193
194int xfs_log_commit_cil(struct xfs_mount *mp, struct xfs_trans *tp, 194void xfs_log_commit_cil(struct xfs_mount *mp, struct xfs_trans *tp,
195 struct xfs_log_vec *log_vector, 195 struct xfs_log_vec *log_vector,
196 xfs_lsn_t *commit_lsn, int flags); 196 xfs_lsn_t *commit_lsn, int flags);
197bool xfs_log_item_in_current_chkpt(struct xfs_log_item *lip); 197bool xfs_log_item_in_current_chkpt(struct xfs_log_item *lip);
diff --git a/fs/xfs/xfs_log_cil.c b/fs/xfs/xfs_log_cil.c
index c7eac5acbfea..9ca59be08977 100644
--- a/fs/xfs/xfs_log_cil.c
+++ b/fs/xfs/xfs_log_cil.c
@@ -625,7 +625,7 @@ out_abort:
625 * background commit, returns without it held once background commits are 625 * background commit, returns without it held once background commits are
626 * allowed again. 626 * allowed again.
627 */ 627 */
628int 628void
629xfs_log_commit_cil( 629xfs_log_commit_cil(
630 struct xfs_mount *mp, 630 struct xfs_mount *mp,
631 struct xfs_trans *tp, 631 struct xfs_trans *tp,
@@ -640,11 +640,6 @@ xfs_log_commit_cil(
640 if (flags & XFS_TRANS_RELEASE_LOG_RES) 640 if (flags & XFS_TRANS_RELEASE_LOG_RES)
641 log_flags = XFS_LOG_REL_PERM_RESERV; 641 log_flags = XFS_LOG_REL_PERM_RESERV;
642 642
643 if (XLOG_FORCED_SHUTDOWN(log)) {
644 xlog_cil_free_logvec(log_vector);
645 return XFS_ERROR(EIO);
646 }
647
648 /* 643 /*
649 * do all the hard work of formatting items (including memory 644 * do all the hard work of formatting items (including memory
650 * allocation) outside the CIL context lock. This prevents stalling CIL 645 * allocation) outside the CIL context lock. This prevents stalling CIL
@@ -704,7 +699,6 @@ xfs_log_commit_cil(
704 */ 699 */
705 if (push) 700 if (push)
706 xlog_cil_push(log, 0); 701 xlog_cil_push(log, 0);
707 return 0;
708} 702}
709 703
710/* 704/*
diff --git a/fs/xfs/xfs_trans.c b/fs/xfs/xfs_trans.c
index 29f5e5424897..76922793f64f 100644
--- a/fs/xfs/xfs_trans.c
+++ b/fs/xfs/xfs_trans.c
@@ -1755,7 +1755,6 @@ xfs_trans_commit_cil(
1755 int flags) 1755 int flags)
1756{ 1756{
1757 struct xfs_log_vec *log_vector; 1757 struct xfs_log_vec *log_vector;
1758 int error;
1759 1758
1760 /* 1759 /*
1761 * Get each log item to allocate a vector structure for 1760 * Get each log item to allocate a vector structure for
@@ -1766,9 +1765,7 @@ xfs_trans_commit_cil(
1766 if (!log_vector) 1765 if (!log_vector)
1767 return ENOMEM; 1766 return ENOMEM;
1768 1767
1769 error = xfs_log_commit_cil(mp, tp, log_vector, commit_lsn, flags); 1768 xfs_log_commit_cil(mp, tp, log_vector, commit_lsn, flags);
1770 if (error)
1771 return error;
1772 1769
1773 current_restore_flags_nested(&tp->t_pflags, PF_FSTRANS); 1770 current_restore_flags_nested(&tp->t_pflags, PF_FSTRANS);
1774 xfs_trans_free(tp); 1771 xfs_trans_free(tp);