Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 47854
b: refs/heads/master
c: 2823945
h: refs/heads/master
v: v3
  • Loading branch information
David Chinner authored and Tim Shimmin committed Feb 10, 2007
1 parent 2c4157a commit 1f6f659
Show file tree
Hide file tree
Showing 4 changed files with 35 additions and 8 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 549054afadae44889c0b40d4c3bfb0207b98d5a0
refs/heads/master: 2823945fda94e0636be573a037c45cb7b6495af2
14 changes: 11 additions & 3 deletions trunk/fs/xfs/linux-2.6/xfs_super.c
Original file line number Diff line number Diff line change
Expand Up @@ -659,9 +659,17 @@ xfs_fs_sync_super(
int error;
int flags;

if (unlikely(sb->s_frozen == SB_FREEZE_WRITE))
flags = SYNC_QUIESCE;
else
if (unlikely(sb->s_frozen == SB_FREEZE_WRITE)) {
/*
* First stage of freeze - no more writers will make progress
* now we are here, so we flush delwri and delalloc buffers
* here, then wait for all I/O to complete. Data is frozen at
* that point. Metadata is not frozen, transactions can still
* occur here so don't bother flushing the buftarg (i.e
* SYNC_QUIESCE) because it'll just get dirty again.
*/
flags = SYNC_FSDATA | SYNC_DELWRI | SYNC_WAIT | SYNC_DIO_WAIT;
} else
flags = SYNC_FSDATA | (wait ? SYNC_WAIT : 0);

error = bhv_vfs_sync(vfsp, flags, NULL);
Expand Down
1 change: 1 addition & 0 deletions trunk/fs/xfs/linux-2.6/xfs_vfs.h
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,7 @@ typedef enum {
#define SYNC_REFCACHE 0x0040 /* prune some of the nfs ref cache */
#define SYNC_REMOUNT 0x0080 /* remount readonly, no dummy LRs */
#define SYNC_QUIESCE 0x0100 /* quiesce fileystem for a snapshot */
#define SYNC_DIO_WAIT 0x0200 /* wait for direct I/O to complete */

#define SHUTDOWN_META_IO_ERROR 0x0001 /* write attempt to metadata failed */
#define SHUTDOWN_LOG_IO_ERROR 0x0002 /* write attempt to the log failed */
Expand Down
26 changes: 22 additions & 4 deletions trunk/fs/xfs/xfs_vfsops.c
Original file line number Diff line number Diff line change
Expand Up @@ -872,6 +872,10 @@ xfs_statvfs(
* this by simply making sure the log gets flushed
* if SYNC_BDFLUSH is set, and by actually writing it
* out otherwise.
* SYNC_DIO_WAIT - The caller wants us to wait for all direct I/Os
* as well to ensure all data I/O completes before we
* return. Forms the drain side of the write barrier needed
* to safely quiesce the filesystem.
*
*/
/*ARGSUSED*/
Expand All @@ -883,10 +887,7 @@ xfs_sync(
{
xfs_mount_t *mp = XFS_BHVTOM(bdp);

if (unlikely(flags == SYNC_QUIESCE))
return xfs_quiesce_fs(mp);
else
return xfs_syncsub(mp, flags, NULL);
return xfs_syncsub(mp, flags, NULL);
}

/*
Expand Down Expand Up @@ -1172,6 +1173,12 @@ xfs_sync_inodes(
}

}
/*
* When freezing, we need to wait ensure direct I/O is complete
* as well to ensure all data modification is complete here
*/
if (flags & SYNC_DIO_WAIT)
vn_iowait(vp);

if (flags & SYNC_BDFLUSH) {
if ((flags & SYNC_ATTR) &&
Expand Down Expand Up @@ -1950,15 +1957,26 @@ xfs_showargs(
return 0;
}

/*
* Second stage of a freeze. The data is already frozen, now we have to take
* care of the metadata. New transactions are already blocked, so we need to
* wait for any remaining transactions to drain out before proceding.
*/
STATIC void
xfs_freeze(
bhv_desc_t *bdp)
{
xfs_mount_t *mp = XFS_BHVTOM(bdp);

/* wait for all modifications to complete */
while (atomic_read(&mp->m_active_trans) > 0)
delay(100);

/* flush inodes and push all remaining buffers out to disk */
xfs_quiesce_fs(mp);

BUG_ON(atomic_read(&mp->m_active_trans) > 0);

/* Push the superblock and write an unmount record */
xfs_log_unmount_write(mp);
xfs_unmountfs_writesb(mp);
Expand Down

0 comments on commit 1f6f659

Please sign in to comment.