diff options
| -rw-r--r-- | fs/xfs/xfs_fsops.c | 26 | ||||
| -rw-r--r-- | fs/xfs/xfs_fsops.h | 1 | ||||
| -rw-r--r-- | fs/xfs/xfs_vfsops.c | 2 |
3 files changed, 29 insertions, 0 deletions
diff --git a/fs/xfs/xfs_fsops.c b/fs/xfs/xfs_fsops.c index d1236d6f4045..163031c1e394 100644 --- a/fs/xfs/xfs_fsops.c +++ b/fs/xfs/xfs_fsops.c | |||
| @@ -540,6 +540,32 @@ xfs_reserve_blocks( | |||
| 540 | return(0); | 540 | return(0); |
| 541 | } | 541 | } |
| 542 | 542 | ||
| 543 | void | ||
| 544 | xfs_fs_log_dummy(xfs_mount_t *mp) | ||
| 545 | { | ||
| 546 | xfs_trans_t *tp; | ||
| 547 | xfs_inode_t *ip; | ||
| 548 | |||
| 549 | |||
| 550 | tp = _xfs_trans_alloc(mp, XFS_TRANS_DUMMY1); | ||
| 551 | atomic_inc(&mp->m_active_trans); | ||
| 552 | if (xfs_trans_reserve(tp, 0, XFS_ICHANGE_LOG_RES(mp), 0, 0, 0)) { | ||
| 553 | xfs_trans_cancel(tp, 0); | ||
| 554 | return; | ||
| 555 | } | ||
| 556 | |||
| 557 | ip = mp->m_rootip; | ||
| 558 | xfs_ilock(ip, XFS_ILOCK_EXCL); | ||
| 559 | |||
| 560 | xfs_trans_ijoin(tp, ip, XFS_ILOCK_EXCL); | ||
| 561 | xfs_trans_ihold(tp, ip); | ||
| 562 | xfs_trans_log_inode(tp, ip, XFS_ILOG_CORE); | ||
| 563 | xfs_trans_set_sync(tp); | ||
| 564 | xfs_trans_commit(tp, 0, NULL); | ||
| 565 | |||
| 566 | xfs_iunlock(ip, XFS_ILOCK_EXCL); | ||
| 567 | } | ||
| 568 | |||
| 543 | int | 569 | int |
| 544 | xfs_fs_goingdown( | 570 | xfs_fs_goingdown( |
| 545 | xfs_mount_t *mp, | 571 | xfs_mount_t *mp, |
diff --git a/fs/xfs/xfs_fsops.h b/fs/xfs/xfs_fsops.h index f32713f14f9a..300d0c9d61ad 100644 --- a/fs/xfs/xfs_fsops.h +++ b/fs/xfs/xfs_fsops.h | |||
| @@ -25,5 +25,6 @@ extern int xfs_fs_counts(xfs_mount_t *mp, xfs_fsop_counts_t *cnt); | |||
| 25 | extern int xfs_reserve_blocks(xfs_mount_t *mp, __uint64_t *inval, | 25 | extern int xfs_reserve_blocks(xfs_mount_t *mp, __uint64_t *inval, |
| 26 | xfs_fsop_resblks_t *outval); | 26 | xfs_fsop_resblks_t *outval); |
| 27 | extern int xfs_fs_goingdown(xfs_mount_t *mp, __uint32_t inflags); | 27 | extern int xfs_fs_goingdown(xfs_mount_t *mp, __uint32_t inflags); |
| 28 | extern void xfs_fs_log_dummy(xfs_mount_t *mp); | ||
| 28 | 29 | ||
| 29 | #endif /* __XFS_FSOPS_H__ */ | 30 | #endif /* __XFS_FSOPS_H__ */ |
diff --git a/fs/xfs/xfs_vfsops.c b/fs/xfs/xfs_vfsops.c index bfdabde23db0..dcdb0a8578e1 100644 --- a/fs/xfs/xfs_vfsops.c +++ b/fs/xfs/xfs_vfsops.c | |||
| @@ -53,6 +53,7 @@ | |||
| 53 | #include "xfs_acl.h" | 53 | #include "xfs_acl.h" |
| 54 | #include "xfs_attr.h" | 54 | #include "xfs_attr.h" |
| 55 | #include "xfs_clnt.h" | 55 | #include "xfs_clnt.h" |
| 56 | #include "xfs_fsops.h" | ||
| 56 | 57 | ||
| 57 | STATIC int xfs_sync(bhv_desc_t *, int, cred_t *); | 58 | STATIC int xfs_sync(bhv_desc_t *, int, cred_t *); |
| 58 | 59 | ||
| @@ -1967,6 +1968,7 @@ xfs_freeze( | |||
| 1967 | /* Push the superblock and write an unmount record */ | 1968 | /* Push the superblock and write an unmount record */ |
| 1968 | xfs_log_unmount_write(mp); | 1969 | xfs_log_unmount_write(mp); |
| 1969 | xfs_unmountfs_writesb(mp); | 1970 | xfs_unmountfs_writesb(mp); |
| 1971 | xfs_fs_log_dummy(mp); | ||
| 1970 | } | 1972 | } |
| 1971 | 1973 | ||
| 1972 | 1974 | ||
