diff options
-rw-r--r-- | fs/xfs/xfs_attr.c | 2 | ||||
-rw-r--r-- | fs/xfs/xfs_buf.c | 4 | ||||
-rw-r--r-- | fs/xfs/xfs_buf.h | 6 | ||||
-rw-r--r-- | fs/xfs/xfs_buf_item.c | 6 | ||||
-rw-r--r-- | fs/xfs/xfs_inode.c | 4 | ||||
-rw-r--r-- | fs/xfs/xfs_log.c | 4 | ||||
-rw-r--r-- | fs/xfs/xfs_log_recover.c | 2 | ||||
-rw-r--r-- | fs/xfs/xfs_rw.c | 2 | ||||
-rw-r--r-- | fs/xfs/xfs_trans_buf.c | 13 |
9 files changed, 22 insertions, 21 deletions
diff --git a/fs/xfs/xfs_attr.c b/fs/xfs/xfs_attr.c index 981a0624f382..ae8f917490d4 100644 --- a/fs/xfs/xfs_attr.c +++ b/fs/xfs/xfs_attr.c | |||
@@ -2168,7 +2168,7 @@ xfs_attr_rmtval_remove(xfs_da_args_t *args) | |||
2168 | */ | 2168 | */ |
2169 | bp = xfs_incore(mp->m_ddev_targp, dblkno, blkcnt, XBF_TRYLOCK); | 2169 | bp = xfs_incore(mp->m_ddev_targp, dblkno, blkcnt, XBF_TRYLOCK); |
2170 | if (bp) { | 2170 | if (bp) { |
2171 | XFS_BUF_STALE(bp); | 2171 | xfs_buf_stale(bp); |
2172 | xfs_buf_delwri_dequeue(bp); | 2172 | xfs_buf_delwri_dequeue(bp); |
2173 | xfs_buf_relse(bp); | 2173 | xfs_buf_relse(bp); |
2174 | bp = NULL; | 2174 | bp = NULL; |
diff --git a/fs/xfs/xfs_buf.c b/fs/xfs/xfs_buf.c index 36fed03da26f..f88eab9e8144 100644 --- a/fs/xfs/xfs_buf.c +++ b/fs/xfs/xfs_buf.c | |||
@@ -1061,7 +1061,7 @@ xfs_bioerror( | |||
1061 | XFS_BUF_UNREAD(bp); | 1061 | XFS_BUF_UNREAD(bp); |
1062 | xfs_buf_delwri_dequeue(bp); | 1062 | xfs_buf_delwri_dequeue(bp); |
1063 | XFS_BUF_UNDONE(bp); | 1063 | XFS_BUF_UNDONE(bp); |
1064 | XFS_BUF_STALE(bp); | 1064 | xfs_buf_stale(bp); |
1065 | 1065 | ||
1066 | xfs_buf_ioend(bp, 0); | 1066 | xfs_buf_ioend(bp, 0); |
1067 | 1067 | ||
@@ -1090,7 +1090,7 @@ xfs_bioerror_relse( | |||
1090 | XFS_BUF_UNREAD(bp); | 1090 | XFS_BUF_UNREAD(bp); |
1091 | xfs_buf_delwri_dequeue(bp); | 1091 | xfs_buf_delwri_dequeue(bp); |
1092 | XFS_BUF_DONE(bp); | 1092 | XFS_BUF_DONE(bp); |
1093 | XFS_BUF_STALE(bp); | 1093 | xfs_buf_stale(bp); |
1094 | bp->b_iodone = NULL; | 1094 | bp->b_iodone = NULL; |
1095 | if (!(fl & XBF_ASYNC)) { | 1095 | if (!(fl & XBF_ASYNC)) { |
1096 | /* | 1096 | /* |
diff --git a/fs/xfs/xfs_buf.h b/fs/xfs/xfs_buf.h index ca2934717343..fa38401449d9 100644 --- a/fs/xfs/xfs_buf.h +++ b/fs/xfs/xfs_buf.h | |||
@@ -242,14 +242,8 @@ xfs_buf_target_name(struct xfs_buftarg *target) | |||
242 | XBF_SYNCIO|XBF_FUA|XBF_FLUSH)) | 242 | XBF_SYNCIO|XBF_FUA|XBF_FLUSH)) |
243 | 243 | ||
244 | void xfs_buf_stale(struct xfs_buf *bp); | 244 | void xfs_buf_stale(struct xfs_buf *bp); |
245 | #define XFS_BUF_STALE(bp) xfs_buf_stale(bp); | ||
246 | #define XFS_BUF_UNSTALE(bp) ((bp)->b_flags &= ~XBF_STALE) | 245 | #define XFS_BUF_UNSTALE(bp) ((bp)->b_flags &= ~XBF_STALE) |
247 | #define XFS_BUF_ISSTALE(bp) ((bp)->b_flags & XBF_STALE) | 246 | #define XFS_BUF_ISSTALE(bp) ((bp)->b_flags & XBF_STALE) |
248 | #define XFS_BUF_SUPER_STALE(bp) do { \ | ||
249 | XFS_BUF_STALE(bp); \ | ||
250 | xfs_buf_delwri_dequeue(bp); \ | ||
251 | XFS_BUF_DONE(bp); \ | ||
252 | } while (0) | ||
253 | 247 | ||
254 | #define XFS_BUF_ISDELAYWRITE(bp) ((bp)->b_flags & XBF_DELWRI) | 248 | #define XFS_BUF_ISDELAYWRITE(bp) ((bp)->b_flags & XBF_DELWRI) |
255 | 249 | ||
diff --git a/fs/xfs/xfs_buf_item.c b/fs/xfs/xfs_buf_item.c index 3243083d8693..8213f4a753dc 100644 --- a/fs/xfs/xfs_buf_item.c +++ b/fs/xfs/xfs_buf_item.c | |||
@@ -966,7 +966,9 @@ xfs_buf_iodone_callbacks( | |||
966 | * I/O errors, there's no point in giving this a retry. | 966 | * I/O errors, there's no point in giving this a retry. |
967 | */ | 967 | */ |
968 | if (XFS_FORCED_SHUTDOWN(mp)) { | 968 | if (XFS_FORCED_SHUTDOWN(mp)) { |
969 | XFS_BUF_SUPER_STALE(bp); | 969 | xfs_buf_stale(bp); |
970 | xfs_buf_delwri_dequeue(bp); | ||
971 | XFS_BUF_DONE(bp); | ||
970 | trace_xfs_buf_item_iodone(bp, _RET_IP_); | 972 | trace_xfs_buf_item_iodone(bp, _RET_IP_); |
971 | goto do_callbacks; | 973 | goto do_callbacks; |
972 | } | 974 | } |
@@ -1005,7 +1007,7 @@ xfs_buf_iodone_callbacks( | |||
1005 | * If the write of the buffer was synchronous, we want to make | 1007 | * If the write of the buffer was synchronous, we want to make |
1006 | * sure to return the error to the caller of xfs_bwrite(). | 1008 | * sure to return the error to the caller of xfs_bwrite(). |
1007 | */ | 1009 | */ |
1008 | XFS_BUF_STALE(bp); | 1010 | xfs_buf_stale(bp); |
1009 | XFS_BUF_DONE(bp); | 1011 | XFS_BUF_DONE(bp); |
1010 | xfs_buf_delwri_dequeue(bp); | 1012 | xfs_buf_delwri_dequeue(bp); |
1011 | 1013 | ||
diff --git a/fs/xfs/xfs_inode.c b/fs/xfs/xfs_inode.c index 21cec6cdf453..c0237c602f11 100644 --- a/fs/xfs/xfs_inode.c +++ b/fs/xfs/xfs_inode.c | |||
@@ -2469,11 +2469,11 @@ cluster_corrupt_out: | |||
2469 | */ | 2469 | */ |
2470 | if (bp->b_iodone) { | 2470 | if (bp->b_iodone) { |
2471 | XFS_BUF_UNDONE(bp); | 2471 | XFS_BUF_UNDONE(bp); |
2472 | XFS_BUF_STALE(bp); | 2472 | xfs_buf_stale(bp); |
2473 | xfs_buf_ioerror(bp, EIO); | 2473 | xfs_buf_ioerror(bp, EIO); |
2474 | xfs_buf_ioend(bp, 0); | 2474 | xfs_buf_ioend(bp, 0); |
2475 | } else { | 2475 | } else { |
2476 | XFS_BUF_STALE(bp); | 2476 | xfs_buf_stale(bp); |
2477 | xfs_buf_relse(bp); | 2477 | xfs_buf_relse(bp); |
2478 | } | 2478 | } |
2479 | } | 2479 | } |
diff --git a/fs/xfs/xfs_log.c b/fs/xfs/xfs_log.c index 3a8d4f66d702..493447dc4f55 100644 --- a/fs/xfs/xfs_log.c +++ b/fs/xfs/xfs_log.c | |||
@@ -881,7 +881,7 @@ xlog_iodone(xfs_buf_t *bp) | |||
881 | if (XFS_TEST_ERROR((xfs_buf_geterror(bp)), l->l_mp, | 881 | if (XFS_TEST_ERROR((xfs_buf_geterror(bp)), l->l_mp, |
882 | XFS_ERRTAG_IODONE_IOERR, XFS_RANDOM_IODONE_IOERR)) { | 882 | XFS_ERRTAG_IODONE_IOERR, XFS_RANDOM_IODONE_IOERR)) { |
883 | xfs_ioerror_alert("xlog_iodone", l->l_mp, bp, XFS_BUF_ADDR(bp)); | 883 | xfs_ioerror_alert("xlog_iodone", l->l_mp, bp, XFS_BUF_ADDR(bp)); |
884 | XFS_BUF_STALE(bp); | 884 | xfs_buf_stale(bp); |
885 | xfs_force_shutdown(l->l_mp, SHUTDOWN_LOG_IO_ERROR); | 885 | xfs_force_shutdown(l->l_mp, SHUTDOWN_LOG_IO_ERROR); |
886 | /* | 886 | /* |
887 | * This flag will be propagated to the trans-committed | 887 | * This flag will be propagated to the trans-committed |
@@ -1247,7 +1247,7 @@ xlog_bdstrat( | |||
1247 | 1247 | ||
1248 | if (iclog->ic_state & XLOG_STATE_IOERROR) { | 1248 | if (iclog->ic_state & XLOG_STATE_IOERROR) { |
1249 | xfs_buf_ioerror(bp, EIO); | 1249 | xfs_buf_ioerror(bp, EIO); |
1250 | XFS_BUF_STALE(bp); | 1250 | xfs_buf_stale(bp); |
1251 | xfs_buf_ioend(bp, 0); | 1251 | xfs_buf_ioend(bp, 0); |
1252 | /* | 1252 | /* |
1253 | * It would seem logical to return EIO here, but we rely on | 1253 | * It would seem logical to return EIO here, but we rely on |
diff --git a/fs/xfs/xfs_log_recover.c b/fs/xfs/xfs_log_recover.c index be173852b2ca..8f70f3469997 100644 --- a/fs/xfs/xfs_log_recover.c +++ b/fs/xfs/xfs_log_recover.c | |||
@@ -2174,7 +2174,7 @@ xlog_recover_buffer_pass2( | |||
2174 | be16_to_cpu(*((__be16 *)xfs_buf_offset(bp, 0))) && | 2174 | be16_to_cpu(*((__be16 *)xfs_buf_offset(bp, 0))) && |
2175 | (XFS_BUF_COUNT(bp) != MAX(log->l_mp->m_sb.sb_blocksize, | 2175 | (XFS_BUF_COUNT(bp) != MAX(log->l_mp->m_sb.sb_blocksize, |
2176 | (__uint32_t)XFS_INODE_CLUSTER_SIZE(log->l_mp)))) { | 2176 | (__uint32_t)XFS_INODE_CLUSTER_SIZE(log->l_mp)))) { |
2177 | XFS_BUF_STALE(bp); | 2177 | xfs_buf_stale(bp); |
2178 | error = xfs_bwrite(bp); | 2178 | error = xfs_bwrite(bp); |
2179 | } else { | 2179 | } else { |
2180 | ASSERT(bp->b_target->bt_mount == mp); | 2180 | ASSERT(bp->b_target->bt_mount == mp); |
diff --git a/fs/xfs/xfs_rw.c b/fs/xfs/xfs_rw.c index 99823c3b9aca..ff33645fe62d 100644 --- a/fs/xfs/xfs_rw.c +++ b/fs/xfs/xfs_rw.c | |||
@@ -150,7 +150,7 @@ xfs_read_buf( | |||
150 | if (bp) { | 150 | if (bp) { |
151 | XFS_BUF_UNDONE(bp); | 151 | XFS_BUF_UNDONE(bp); |
152 | xfs_buf_delwri_dequeue(bp); | 152 | xfs_buf_delwri_dequeue(bp); |
153 | XFS_BUF_STALE(bp); | 153 | xfs_buf_stale(bp); |
154 | /* | 154 | /* |
155 | * brelse clears B_ERROR and b_error | 155 | * brelse clears B_ERROR and b_error |
156 | */ | 156 | */ |
diff --git a/fs/xfs/xfs_trans_buf.c b/fs/xfs/xfs_trans_buf.c index 5e5196a269dd..d03a8ee19172 100644 --- a/fs/xfs/xfs_trans_buf.c +++ b/fs/xfs/xfs_trans_buf.c | |||
@@ -160,8 +160,11 @@ xfs_trans_get_buf(xfs_trans_t *tp, | |||
160 | bp = xfs_trans_buf_item_match(tp, target_dev, blkno, len); | 160 | bp = xfs_trans_buf_item_match(tp, target_dev, blkno, len); |
161 | if (bp != NULL) { | 161 | if (bp != NULL) { |
162 | ASSERT(xfs_buf_islocked(bp)); | 162 | ASSERT(xfs_buf_islocked(bp)); |
163 | if (XFS_FORCED_SHUTDOWN(tp->t_mountp)) | 163 | if (XFS_FORCED_SHUTDOWN(tp->t_mountp)) { |
164 | XFS_BUF_SUPER_STALE(bp); | 164 | xfs_buf_stale(bp); |
165 | xfs_buf_delwri_dequeue(bp); | ||
166 | XFS_BUF_DONE(bp); | ||
167 | } | ||
165 | 168 | ||
166 | /* | 169 | /* |
167 | * If the buffer is stale then it was binval'ed | 170 | * If the buffer is stale then it was binval'ed |
@@ -387,7 +390,9 @@ xfs_trans_read_buf( | |||
387 | } | 390 | } |
388 | if (bp->b_error) { | 391 | if (bp->b_error) { |
389 | error = bp->b_error; | 392 | error = bp->b_error; |
390 | XFS_BUF_SUPER_STALE(bp); | 393 | xfs_buf_stale(bp); |
394 | xfs_buf_delwri_dequeue(bp); | ||
395 | XFS_BUF_DONE(bp); | ||
391 | xfs_ioerror_alert("xfs_trans_read_buf", mp, | 396 | xfs_ioerror_alert("xfs_trans_read_buf", mp, |
392 | bp, blkno); | 397 | bp, blkno); |
393 | if (tp->t_flags & XFS_TRANS_DIRTY) | 398 | if (tp->t_flags & XFS_TRANS_DIRTY) |
@@ -740,7 +745,7 @@ xfs_trans_binval( | |||
740 | * rid of it. | 745 | * rid of it. |
741 | */ | 746 | */ |
742 | xfs_buf_delwri_dequeue(bp); | 747 | xfs_buf_delwri_dequeue(bp); |
743 | XFS_BUF_STALE(bp); | 748 | xfs_buf_stale(bp); |
744 | bip->bli_flags |= XFS_BLI_STALE; | 749 | bip->bli_flags |= XFS_BLI_STALE; |
745 | bip->bli_flags &= ~(XFS_BLI_INODE_BUF | XFS_BLI_LOGGED | XFS_BLI_DIRTY); | 750 | bip->bli_flags &= ~(XFS_BLI_INODE_BUF | XFS_BLI_LOGGED | XFS_BLI_DIRTY); |
746 | bip->bli_format.blf_flags &= ~XFS_BLF_INODE_BUF; | 751 | bip->bli_format.blf_flags &= ~XFS_BLF_INODE_BUF; |