diff options
Diffstat (limited to 'fs/xfs/xfs_log_recover.c')
-rw-r--r-- | fs/xfs/xfs_log_recover.c | 26 |
1 files changed, 9 insertions, 17 deletions
diff --git a/fs/xfs/xfs_log_recover.c b/fs/xfs/xfs_log_recover.c index 51412cced010..35cca98bd94c 100644 --- a/fs/xfs/xfs_log_recover.c +++ b/fs/xfs/xfs_log_recover.c | |||
@@ -267,21 +267,16 @@ STATIC void | |||
267 | xlog_recover_iodone( | 267 | xlog_recover_iodone( |
268 | struct xfs_buf *bp) | 268 | struct xfs_buf *bp) |
269 | { | 269 | { |
270 | xfs_mount_t *mp; | ||
271 | |||
272 | ASSERT(XFS_BUF_FSPRIVATE(bp, void *)); | ||
273 | |||
274 | if (XFS_BUF_GETERROR(bp)) { | 270 | if (XFS_BUF_GETERROR(bp)) { |
275 | /* | 271 | /* |
276 | * We're not going to bother about retrying | 272 | * We're not going to bother about retrying |
277 | * this during recovery. One strike! | 273 | * this during recovery. One strike! |
278 | */ | 274 | */ |
279 | mp = XFS_BUF_FSPRIVATE(bp, xfs_mount_t *); | ||
280 | xfs_ioerror_alert("xlog_recover_iodone", | 275 | xfs_ioerror_alert("xlog_recover_iodone", |
281 | mp, bp, XFS_BUF_ADDR(bp)); | 276 | bp->b_mount, bp, XFS_BUF_ADDR(bp)); |
282 | xfs_force_shutdown(mp, SHUTDOWN_META_IO_ERROR); | 277 | xfs_force_shutdown(bp->b_mount, SHUTDOWN_META_IO_ERROR); |
283 | } | 278 | } |
284 | XFS_BUF_SET_FSPRIVATE(bp, NULL); | 279 | bp->b_mount = NULL; |
285 | XFS_BUF_CLR_IODONE_FUNC(bp); | 280 | XFS_BUF_CLR_IODONE_FUNC(bp); |
286 | xfs_biodone(bp); | 281 | xfs_biodone(bp); |
287 | } | 282 | } |
@@ -2225,9 +2220,8 @@ xlog_recover_do_buffer_trans( | |||
2225 | XFS_BUF_STALE(bp); | 2220 | XFS_BUF_STALE(bp); |
2226 | error = xfs_bwrite(mp, bp); | 2221 | error = xfs_bwrite(mp, bp); |
2227 | } else { | 2222 | } else { |
2228 | ASSERT(XFS_BUF_FSPRIVATE(bp, void *) == NULL || | 2223 | ASSERT(bp->b_mount == NULL || bp->b_mount == mp); |
2229 | XFS_BUF_FSPRIVATE(bp, xfs_mount_t *) == mp); | 2224 | bp->b_mount = mp; |
2230 | XFS_BUF_SET_FSPRIVATE(bp, mp); | ||
2231 | XFS_BUF_SET_IODONE_FUNC(bp, xlog_recover_iodone); | 2225 | XFS_BUF_SET_IODONE_FUNC(bp, xlog_recover_iodone); |
2232 | xfs_bdwrite(mp, bp); | 2226 | xfs_bdwrite(mp, bp); |
2233 | } | 2227 | } |
@@ -2490,9 +2484,8 @@ xlog_recover_do_inode_trans( | |||
2490 | 2484 | ||
2491 | write_inode_buffer: | 2485 | write_inode_buffer: |
2492 | if (ITEM_TYPE(item) == XFS_LI_INODE) { | 2486 | if (ITEM_TYPE(item) == XFS_LI_INODE) { |
2493 | ASSERT(XFS_BUF_FSPRIVATE(bp, void *) == NULL || | 2487 | ASSERT(bp->b_mount == NULL || bp->b_mount == mp); |
2494 | XFS_BUF_FSPRIVATE(bp, xfs_mount_t *) == mp); | 2488 | bp->b_mount = mp; |
2495 | XFS_BUF_SET_FSPRIVATE(bp, mp); | ||
2496 | XFS_BUF_SET_IODONE_FUNC(bp, xlog_recover_iodone); | 2489 | XFS_BUF_SET_IODONE_FUNC(bp, xlog_recover_iodone); |
2497 | xfs_bdwrite(mp, bp); | 2490 | xfs_bdwrite(mp, bp); |
2498 | } else { | 2491 | } else { |
@@ -2623,9 +2616,8 @@ xlog_recover_do_dquot_trans( | |||
2623 | memcpy(ddq, recddq, item->ri_buf[1].i_len); | 2616 | memcpy(ddq, recddq, item->ri_buf[1].i_len); |
2624 | 2617 | ||
2625 | ASSERT(dq_f->qlf_size == 2); | 2618 | ASSERT(dq_f->qlf_size == 2); |
2626 | ASSERT(XFS_BUF_FSPRIVATE(bp, void *) == NULL || | 2619 | ASSERT(bp->b_mount == NULL || bp->b_mount == mp); |
2627 | XFS_BUF_FSPRIVATE(bp, xfs_mount_t *) == mp); | 2620 | bp->b_mount = mp; |
2628 | XFS_BUF_SET_FSPRIVATE(bp, mp); | ||
2629 | XFS_BUF_SET_IODONE_FUNC(bp, xlog_recover_iodone); | 2621 | XFS_BUF_SET_IODONE_FUNC(bp, xlog_recover_iodone); |
2630 | xfs_bdwrite(mp, bp); | 2622 | xfs_bdwrite(mp, bp); |
2631 | 2623 | ||