diff options
author | Christoph Hellwig <hch@infradead.org> | 2012-07-13 02:24:10 -0400 |
---|---|---|
committer | Ben Myers <bpm@sgi.com> | 2012-07-13 13:50:54 -0400 |
commit | a2dcf5df5f3813a44423d4a5026666e751ec00dd (patch) | |
tree | 76ef63788a8e8c98824ef7cc7b70535d4c7b154f | |
parent | 08023d6dbe840dc4271805a9ea376fcbdee9f744 (diff) |
xfs: do not call xfs_bdstrat_cb in xfs_buf_iodone_callbacks
xfs_bdstrat_cb only adds a check for a shutdown filesystem over
xfs_buf_iorequest, but xfs_buf_iodone_callbacks just checked for a shut down
filesystem a little earlier. In addition the shutdown handling in
xfs_bdstrat_cb is not very suitable for this caller.
Signed-off-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Dave Chinner <dchinner@redhat.com>
Signed-off-by: Ben Myers <bpm@sgi.com>
-rw-r--r-- | fs/xfs/xfs_buf.c | 51 | ||||
-rw-r--r-- | fs/xfs/xfs_buf.h | 1 | ||||
-rw-r--r-- | fs/xfs/xfs_buf_item.c | 2 |
3 files changed, 23 insertions, 31 deletions
diff --git a/fs/xfs/xfs_buf.c b/fs/xfs/xfs_buf.c index d1edfa1a8112..d7a9dd735e1e 100644 --- a/fs/xfs/xfs_buf.c +++ b/fs/xfs/xfs_buf.c | |||
@@ -1049,27 +1049,6 @@ xfs_buf_ioerror_alert( | |||
1049 | (__uint64_t)XFS_BUF_ADDR(bp), func, bp->b_error, bp->b_length); | 1049 | (__uint64_t)XFS_BUF_ADDR(bp), func, bp->b_error, bp->b_length); |
1050 | } | 1050 | } |
1051 | 1051 | ||
1052 | int | ||
1053 | xfs_bwrite( | ||
1054 | struct xfs_buf *bp) | ||
1055 | { | ||
1056 | int error; | ||
1057 | |||
1058 | ASSERT(xfs_buf_islocked(bp)); | ||
1059 | |||
1060 | bp->b_flags |= XBF_WRITE; | ||
1061 | bp->b_flags &= ~(XBF_ASYNC | XBF_READ | _XBF_DELWRI_Q); | ||
1062 | |||
1063 | xfs_bdstrat_cb(bp); | ||
1064 | |||
1065 | error = xfs_buf_iowait(bp); | ||
1066 | if (error) { | ||
1067 | xfs_force_shutdown(bp->b_target->bt_mount, | ||
1068 | SHUTDOWN_META_IO_ERROR); | ||
1069 | } | ||
1070 | return error; | ||
1071 | } | ||
1072 | |||
1073 | /* | 1052 | /* |
1074 | * Called when we want to stop a buffer from getting written or read. | 1053 | * Called when we want to stop a buffer from getting written or read. |
1075 | * We attach the EIO error, muck with its flags, and call xfs_buf_ioend | 1054 | * We attach the EIO error, muck with its flags, and call xfs_buf_ioend |
@@ -1139,14 +1118,7 @@ xfs_bioerror_relse( | |||
1139 | return EIO; | 1118 | return EIO; |
1140 | } | 1119 | } |
1141 | 1120 | ||
1142 | 1121 | STATIC int | |
1143 | /* | ||
1144 | * All xfs metadata buffers except log state machine buffers | ||
1145 | * get this attached as their b_bdstrat callback function. | ||
1146 | * This is so that we can catch a buffer | ||
1147 | * after prematurely unpinning it to forcibly shutdown the filesystem. | ||
1148 | */ | ||
1149 | int | ||
1150 | xfs_bdstrat_cb( | 1122 | xfs_bdstrat_cb( |
1151 | struct xfs_buf *bp) | 1123 | struct xfs_buf *bp) |
1152 | { | 1124 | { |
@@ -1167,6 +1139,27 @@ xfs_bdstrat_cb( | |||
1167 | return 0; | 1139 | return 0; |
1168 | } | 1140 | } |
1169 | 1141 | ||
1142 | int | ||
1143 | xfs_bwrite( | ||
1144 | struct xfs_buf *bp) | ||
1145 | { | ||
1146 | int error; | ||
1147 | |||
1148 | ASSERT(xfs_buf_islocked(bp)); | ||
1149 | |||
1150 | bp->b_flags |= XBF_WRITE; | ||
1151 | bp->b_flags &= ~(XBF_ASYNC | XBF_READ | _XBF_DELWRI_Q); | ||
1152 | |||
1153 | xfs_bdstrat_cb(bp); | ||
1154 | |||
1155 | error = xfs_buf_iowait(bp); | ||
1156 | if (error) { | ||
1157 | xfs_force_shutdown(bp->b_target->bt_mount, | ||
1158 | SHUTDOWN_META_IO_ERROR); | ||
1159 | } | ||
1160 | return error; | ||
1161 | } | ||
1162 | |||
1170 | /* | 1163 | /* |
1171 | * Wrapper around bdstrat so that we can stop data from going to disk in case | 1164 | * Wrapper around bdstrat so that we can stop data from going to disk in case |
1172 | * we are shutting down the filesystem. Typically user data goes thru this | 1165 | * we are shutting down the filesystem. Typically user data goes thru this |
diff --git a/fs/xfs/xfs_buf.h b/fs/xfs/xfs_buf.h index aa96bd410aed..d03b73b9604e 100644 --- a/fs/xfs/xfs_buf.h +++ b/fs/xfs/xfs_buf.h | |||
@@ -250,7 +250,6 @@ extern void xfs_buf_unlock(xfs_buf_t *); | |||
250 | extern int xfs_bwrite(struct xfs_buf *bp); | 250 | extern int xfs_bwrite(struct xfs_buf *bp); |
251 | 251 | ||
252 | extern void xfsbdstrat(struct xfs_mount *, struct xfs_buf *); | 252 | extern void xfsbdstrat(struct xfs_mount *, struct xfs_buf *); |
253 | extern int xfs_bdstrat_cb(struct xfs_buf *); | ||
254 | 253 | ||
255 | extern void xfs_buf_ioend(xfs_buf_t *, int); | 254 | extern void xfs_buf_ioend(xfs_buf_t *, int); |
256 | extern void xfs_buf_ioerror(xfs_buf_t *, int); | 255 | extern void xfs_buf_ioerror(xfs_buf_t *, int); |
diff --git a/fs/xfs/xfs_buf_item.c b/fs/xfs/xfs_buf_item.c index e4a6e4b6fa03..a8d0ed911196 100644 --- a/fs/xfs/xfs_buf_item.c +++ b/fs/xfs/xfs_buf_item.c | |||
@@ -1101,7 +1101,7 @@ xfs_buf_iodone_callbacks( | |||
1101 | 1101 | ||
1102 | if (!XFS_BUF_ISSTALE(bp)) { | 1102 | if (!XFS_BUF_ISSTALE(bp)) { |
1103 | bp->b_flags |= XBF_WRITE | XBF_ASYNC | XBF_DONE; | 1103 | bp->b_flags |= XBF_WRITE | XBF_ASYNC | XBF_DONE; |
1104 | xfs_bdstrat_cb(bp); | 1104 | xfs_buf_iorequest(bp); |
1105 | } else { | 1105 | } else { |
1106 | xfs_buf_relse(bp); | 1106 | xfs_buf_relse(bp); |
1107 | } | 1107 | } |