|
@@ -540,6 +540,32 @@ xfs_reserve_blocks(
|
|
return(0);
|
|
return(0);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+void
|
|
|
|
+xfs_fs_log_dummy(xfs_mount_t *mp)
|
|
|
|
+{
|
|
|
|
+ xfs_trans_t *tp;
|
|
|
|
+ xfs_inode_t *ip;
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+ tp = _xfs_trans_alloc(mp, XFS_TRANS_DUMMY1);
|
|
|
|
+ atomic_inc(&mp->m_active_trans);
|
|
|
|
+ if (xfs_trans_reserve(tp, 0, XFS_ICHANGE_LOG_RES(mp), 0, 0, 0)) {
|
|
|
|
+ xfs_trans_cancel(tp, 0);
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ ip = mp->m_rootip;
|
|
|
|
+ xfs_ilock(ip, XFS_ILOCK_EXCL);
|
|
|
|
+
|
|
|
|
+ xfs_trans_ijoin(tp, ip, XFS_ILOCK_EXCL);
|
|
|
|
+ xfs_trans_ihold(tp, ip);
|
|
|
|
+ xfs_trans_log_inode(tp, ip, XFS_ILOG_CORE);
|
|
|
|
+ xfs_trans_set_sync(tp);
|
|
|
|
+ xfs_trans_commit(tp, 0, NULL);
|
|
|
|
+
|
|
|
|
+ xfs_iunlock(ip, XFS_ILOCK_EXCL);
|
|
|
|
+}
|
|
|
|
+
|
|
int
|
|
int
|
|
xfs_fs_goingdown(
|
|
xfs_fs_goingdown(
|
|
xfs_mount_t *mp,
|
|
xfs_mount_t *mp,
|