diff options
author | Dave Chinner <david@fromorbit.com> | 2010-01-25 23:08:49 -0500 |
---|---|---|
committer | Dave Chinner <david@fromorbit.com> | 2010-01-25 23:08:49 -0500 |
commit | cbe132a8bdcff0f9afd9060948fb50597c7400b8 (patch) | |
tree | 2bf70f1520b6cc60fb3097763dde24600466369d /fs/xfs/xfs_mount.h | |
parent | 9b00f30762fe9f914eb6e03057a616ed63a4e8ca (diff) |
xfs: don't hold onto reserved blocks on remount,ro
If we hold onto reserved blocks when doing a remount,ro we end
up writing the blocks used count to disk that includes the reserved
blocks. Reserved blocks are not actually used, so this results in
the values in the superblock being incorrect.
Hence if we run xfs_check or xfs_repair -n while the filesystem is
mounted remount,ro we end up with an inconsistent filesystem being
reported. Also, running xfs_copy on the remount,ro filesystem will
result in an inconsistent image being generated.
To fix this, unreserve the blocks when doing the remount,ro, and
reserved them again on remount,rw. This way a remount,ro filesystem
will appear consistent on disk to all utilities.
Signed-off-by: Dave Chinner <david@fromorbit.com>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Diffstat (limited to 'fs/xfs/xfs_mount.h')
-rw-r--r-- | fs/xfs/xfs_mount.h | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/fs/xfs/xfs_mount.h b/fs/xfs/xfs_mount.h index f4d1441f3f15..02d45f213e58 100644 --- a/fs/xfs/xfs_mount.h +++ b/fs/xfs/xfs_mount.h | |||
@@ -225,6 +225,7 @@ typedef struct xfs_mount { | |||
225 | __uint64_t m_maxioffset; /* maximum inode offset */ | 225 | __uint64_t m_maxioffset; /* maximum inode offset */ |
226 | __uint64_t m_resblks; /* total reserved blocks */ | 226 | __uint64_t m_resblks; /* total reserved blocks */ |
227 | __uint64_t m_resblks_avail;/* available reserved blocks */ | 227 | __uint64_t m_resblks_avail;/* available reserved blocks */ |
228 | __uint64_t m_resblks_save; /* reserved blks @ remount,ro */ | ||
228 | int m_dalign; /* stripe unit */ | 229 | int m_dalign; /* stripe unit */ |
229 | int m_swidth; /* stripe width */ | 230 | int m_swidth; /* stripe width */ |
230 | int m_sinoalign; /* stripe unit inode alignment */ | 231 | int m_sinoalign; /* stripe unit inode alignment */ |