提交 ce748eaa 编写于 作者: E Eric Sandeen 提交者: Dave Chinner

xfs: create new metadata UUID field and incompat flag

This adds a new superblock field, sb_meta_uuid.  If set, along with
a new incompat flag, the code will use that field on a V5 filesystem
to compare to metadata UUIDs, which allows us to change the user-
visible UUID at will.  Userspace handles the setting and clearing
of the incompat flag as appropriate, as the UUID gets changed; i.e.
setting the user-visible UUID back to the original UUID (as stored in
the new field) will remove the incompatible feature flag.

If the incompat flag is not set, this copies the user-visible UUID into
into the meta_uuid slot in memory when the superblock is read from disk;
the meta_uuid field is not written back to disk in this case.

The remainder of this patch simply switches verifiers, initializers,
etc to use the new sb_meta_uuid field.
Signed-off-by: NEric Sandeen <sandeen@redhat.com>
Reviewed-by: NBrian Foster <bfoster@redhat.com>
Signed-off-by: NDave Chinner <david@fromorbit.com>
上级 bc0195aa
...@@ -464,7 +464,7 @@ xfs_agfl_verify( ...@@ -464,7 +464,7 @@ xfs_agfl_verify(
struct xfs_agfl *agfl = XFS_BUF_TO_AGFL(bp); struct xfs_agfl *agfl = XFS_BUF_TO_AGFL(bp);
int i; int i;
if (!uuid_equal(&agfl->agfl_uuid, &mp->m_sb.sb_uuid)) if (!uuid_equal(&agfl->agfl_uuid, &mp->m_sb.sb_meta_uuid))
return false; return false;
if (be32_to_cpu(agfl->agfl_magicnum) != XFS_AGFL_MAGIC) if (be32_to_cpu(agfl->agfl_magicnum) != XFS_AGFL_MAGIC)
return false; return false;
...@@ -2260,7 +2260,7 @@ xfs_agf_verify( ...@@ -2260,7 +2260,7 @@ xfs_agf_verify(
struct xfs_agf *agf = XFS_BUF_TO_AGF(bp); struct xfs_agf *agf = XFS_BUF_TO_AGF(bp);
if (xfs_sb_version_hascrc(&mp->m_sb) && if (xfs_sb_version_hascrc(&mp->m_sb) &&
!uuid_equal(&agf->agf_uuid, &mp->m_sb.sb_uuid)) !uuid_equal(&agf->agf_uuid, &mp->m_sb.sb_meta_uuid))
return false; return false;
if (!(agf->agf_magicnum == cpu_to_be32(XFS_AGF_MAGIC) && if (!(agf->agf_magicnum == cpu_to_be32(XFS_AGF_MAGIC) &&
......
...@@ -295,7 +295,7 @@ xfs_allocbt_verify( ...@@ -295,7 +295,7 @@ xfs_allocbt_verify(
case cpu_to_be32(XFS_ABTB_CRC_MAGIC): case cpu_to_be32(XFS_ABTB_CRC_MAGIC):
if (!xfs_sb_version_hascrc(&mp->m_sb)) if (!xfs_sb_version_hascrc(&mp->m_sb))
return false; return false;
if (!uuid_equal(&block->bb_u.s.bb_uuid, &mp->m_sb.sb_uuid)) if (!uuid_equal(&block->bb_u.s.bb_uuid, &mp->m_sb.sb_meta_uuid))
return false; return false;
if (block->bb_u.s.bb_blkno != cpu_to_be64(bp->b_bn)) if (block->bb_u.s.bb_blkno != cpu_to_be64(bp->b_bn))
return false; return false;
...@@ -313,7 +313,7 @@ xfs_allocbt_verify( ...@@ -313,7 +313,7 @@ xfs_allocbt_verify(
case cpu_to_be32(XFS_ABTC_CRC_MAGIC): case cpu_to_be32(XFS_ABTC_CRC_MAGIC):
if (!xfs_sb_version_hascrc(&mp->m_sb)) if (!xfs_sb_version_hascrc(&mp->m_sb))
return false; return false;
if (!uuid_equal(&block->bb_u.s.bb_uuid, &mp->m_sb.sb_uuid)) if (!uuid_equal(&block->bb_u.s.bb_uuid, &mp->m_sb.sb_meta_uuid))
return false; return false;
if (block->bb_u.s.bb_blkno != cpu_to_be64(bp->b_bn)) if (block->bb_u.s.bb_blkno != cpu_to_be64(bp->b_bn))
return false; return false;
......
...@@ -262,7 +262,7 @@ xfs_attr3_leaf_verify( ...@@ -262,7 +262,7 @@ xfs_attr3_leaf_verify(
if (ichdr.magic != XFS_ATTR3_LEAF_MAGIC) if (ichdr.magic != XFS_ATTR3_LEAF_MAGIC)
return false; return false;
if (!uuid_equal(&hdr3->info.uuid, &mp->m_sb.sb_uuid)) if (!uuid_equal(&hdr3->info.uuid, &mp->m_sb.sb_meta_uuid))
return false; return false;
if (be64_to_cpu(hdr3->info.blkno) != bp->b_bn) if (be64_to_cpu(hdr3->info.blkno) != bp->b_bn)
return false; return false;
...@@ -1056,7 +1056,7 @@ xfs_attr3_leaf_create( ...@@ -1056,7 +1056,7 @@ xfs_attr3_leaf_create(
hdr3->blkno = cpu_to_be64(bp->b_bn); hdr3->blkno = cpu_to_be64(bp->b_bn);
hdr3->owner = cpu_to_be64(dp->i_ino); hdr3->owner = cpu_to_be64(dp->i_ino);
uuid_copy(&hdr3->uuid, &mp->m_sb.sb_uuid); uuid_copy(&hdr3->uuid, &mp->m_sb.sb_meta_uuid);
ichdr.freemap[0].base = sizeof(struct xfs_attr3_leaf_hdr); ichdr.freemap[0].base = sizeof(struct xfs_attr3_leaf_hdr);
} else { } else {
......
...@@ -100,7 +100,7 @@ xfs_attr3_rmt_verify( ...@@ -100,7 +100,7 @@ xfs_attr3_rmt_verify(
return false; return false;
if (rmt->rm_magic != cpu_to_be32(XFS_ATTR3_RMT_MAGIC)) if (rmt->rm_magic != cpu_to_be32(XFS_ATTR3_RMT_MAGIC))
return false; return false;
if (!uuid_equal(&rmt->rm_uuid, &mp->m_sb.sb_uuid)) if (!uuid_equal(&rmt->rm_uuid, &mp->m_sb.sb_meta_uuid))
return false; return false;
if (be64_to_cpu(rmt->rm_blkno) != bno) if (be64_to_cpu(rmt->rm_blkno) != bno)
return false; return false;
...@@ -217,7 +217,7 @@ xfs_attr3_rmt_hdr_set( ...@@ -217,7 +217,7 @@ xfs_attr3_rmt_hdr_set(
rmt->rm_magic = cpu_to_be32(XFS_ATTR3_RMT_MAGIC); rmt->rm_magic = cpu_to_be32(XFS_ATTR3_RMT_MAGIC);
rmt->rm_offset = cpu_to_be32(offset); rmt->rm_offset = cpu_to_be32(offset);
rmt->rm_bytes = cpu_to_be32(size); rmt->rm_bytes = cpu_to_be32(size);
uuid_copy(&rmt->rm_uuid, &mp->m_sb.sb_uuid); uuid_copy(&rmt->rm_uuid, &mp->m_sb.sb_meta_uuid);
rmt->rm_owner = cpu_to_be64(ino); rmt->rm_owner = cpu_to_be64(ino);
rmt->rm_blkno = cpu_to_be64(bno); rmt->rm_blkno = cpu_to_be64(bno);
......
...@@ -349,7 +349,8 @@ xfs_bmbt_to_bmdr( ...@@ -349,7 +349,8 @@ xfs_bmbt_to_bmdr(
if (xfs_sb_version_hascrc(&mp->m_sb)) { if (xfs_sb_version_hascrc(&mp->m_sb)) {
ASSERT(rblock->bb_magic == cpu_to_be32(XFS_BMAP_CRC_MAGIC)); ASSERT(rblock->bb_magic == cpu_to_be32(XFS_BMAP_CRC_MAGIC));
ASSERT(uuid_equal(&rblock->bb_u.l.bb_uuid, &mp->m_sb.sb_uuid)); ASSERT(uuid_equal(&rblock->bb_u.l.bb_uuid,
&mp->m_sb.sb_meta_uuid));
ASSERT(rblock->bb_u.l.bb_blkno == ASSERT(rblock->bb_u.l.bb_blkno ==
cpu_to_be64(XFS_BUF_DADDR_NULL)); cpu_to_be64(XFS_BUF_DADDR_NULL));
} else } else
...@@ -647,7 +648,7 @@ xfs_bmbt_verify( ...@@ -647,7 +648,7 @@ xfs_bmbt_verify(
case cpu_to_be32(XFS_BMAP_CRC_MAGIC): case cpu_to_be32(XFS_BMAP_CRC_MAGIC):
if (!xfs_sb_version_hascrc(&mp->m_sb)) if (!xfs_sb_version_hascrc(&mp->m_sb))
return false; return false;
if (!uuid_equal(&block->bb_u.l.bb_uuid, &mp->m_sb.sb_uuid)) if (!uuid_equal(&block->bb_u.l.bb_uuid, &mp->m_sb.sb_meta_uuid))
return false; return false;
if (be64_to_cpu(block->bb_u.l.bb_blkno) != bp->b_bn) if (be64_to_cpu(block->bb_u.l.bb_blkno) != bp->b_bn)
return false; return false;
......
...@@ -65,7 +65,8 @@ xfs_btree_check_lblock( ...@@ -65,7 +65,8 @@ xfs_btree_check_lblock(
if (xfs_sb_version_hascrc(&mp->m_sb)) { if (xfs_sb_version_hascrc(&mp->m_sb)) {
lblock_ok = lblock_ok && lblock_ok = lblock_ok &&
uuid_equal(&block->bb_u.l.bb_uuid, &mp->m_sb.sb_uuid) && uuid_equal(&block->bb_u.l.bb_uuid,
&mp->m_sb.sb_meta_uuid) &&
block->bb_u.l.bb_blkno == cpu_to_be64( block->bb_u.l.bb_blkno == cpu_to_be64(
bp ? bp->b_bn : XFS_BUF_DADDR_NULL); bp ? bp->b_bn : XFS_BUF_DADDR_NULL);
} }
...@@ -115,7 +116,8 @@ xfs_btree_check_sblock( ...@@ -115,7 +116,8 @@ xfs_btree_check_sblock(
if (xfs_sb_version_hascrc(&mp->m_sb)) { if (xfs_sb_version_hascrc(&mp->m_sb)) {
sblock_ok = sblock_ok && sblock_ok = sblock_ok &&
uuid_equal(&block->bb_u.s.bb_uuid, &mp->m_sb.sb_uuid) && uuid_equal(&block->bb_u.s.bb_uuid,
&mp->m_sb.sb_meta_uuid) &&
block->bb_u.s.bb_blkno == cpu_to_be64( block->bb_u.s.bb_blkno == cpu_to_be64(
bp ? bp->b_bn : XFS_BUF_DADDR_NULL); bp ? bp->b_bn : XFS_BUF_DADDR_NULL);
} }
...@@ -1000,7 +1002,7 @@ xfs_btree_init_block_int( ...@@ -1000,7 +1002,7 @@ xfs_btree_init_block_int(
if (flags & XFS_BTREE_CRC_BLOCKS) { if (flags & XFS_BTREE_CRC_BLOCKS) {
buf->bb_u.l.bb_blkno = cpu_to_be64(blkno); buf->bb_u.l.bb_blkno = cpu_to_be64(blkno);
buf->bb_u.l.bb_owner = cpu_to_be64(owner); buf->bb_u.l.bb_owner = cpu_to_be64(owner);
uuid_copy(&buf->bb_u.l.bb_uuid, &mp->m_sb.sb_uuid); uuid_copy(&buf->bb_u.l.bb_uuid, &mp->m_sb.sb_meta_uuid);
buf->bb_u.l.bb_pad = 0; buf->bb_u.l.bb_pad = 0;
buf->bb_u.l.bb_lsn = 0; buf->bb_u.l.bb_lsn = 0;
} }
...@@ -1013,7 +1015,7 @@ xfs_btree_init_block_int( ...@@ -1013,7 +1015,7 @@ xfs_btree_init_block_int(
if (flags & XFS_BTREE_CRC_BLOCKS) { if (flags & XFS_BTREE_CRC_BLOCKS) {
buf->bb_u.s.bb_blkno = cpu_to_be64(blkno); buf->bb_u.s.bb_blkno = cpu_to_be64(blkno);
buf->bb_u.s.bb_owner = cpu_to_be32(__owner); buf->bb_u.s.bb_owner = cpu_to_be32(__owner);
uuid_copy(&buf->bb_u.s.bb_uuid, &mp->m_sb.sb_uuid); uuid_copy(&buf->bb_u.s.bb_uuid, &mp->m_sb.sb_meta_uuid);
buf->bb_u.s.bb_lsn = 0; buf->bb_u.s.bb_lsn = 0;
} }
} }
......
...@@ -146,7 +146,7 @@ xfs_da3_node_verify( ...@@ -146,7 +146,7 @@ xfs_da3_node_verify(
if (ichdr.magic != XFS_DA3_NODE_MAGIC) if (ichdr.magic != XFS_DA3_NODE_MAGIC)
return false; return false;
if (!uuid_equal(&hdr3->info.uuid, &mp->m_sb.sb_uuid)) if (!uuid_equal(&hdr3->info.uuid, &mp->m_sb.sb_meta_uuid))
return false; return false;
if (be64_to_cpu(hdr3->info.blkno) != bp->b_bn) if (be64_to_cpu(hdr3->info.blkno) != bp->b_bn)
return false; return false;
...@@ -324,7 +324,7 @@ xfs_da3_node_create( ...@@ -324,7 +324,7 @@ xfs_da3_node_create(
ichdr.magic = XFS_DA3_NODE_MAGIC; ichdr.magic = XFS_DA3_NODE_MAGIC;
hdr3->info.blkno = cpu_to_be64(bp->b_bn); hdr3->info.blkno = cpu_to_be64(bp->b_bn);
hdr3->info.owner = cpu_to_be64(args->dp->i_ino); hdr3->info.owner = cpu_to_be64(args->dp->i_ino);
uuid_copy(&hdr3->info.uuid, &mp->m_sb.sb_uuid); uuid_copy(&hdr3->info.uuid, &mp->m_sb.sb_meta_uuid);
} else { } else {
ichdr.magic = XFS_DA_NODE_MAGIC; ichdr.magic = XFS_DA_NODE_MAGIC;
} }
......
...@@ -67,7 +67,7 @@ xfs_dir3_block_verify( ...@@ -67,7 +67,7 @@ xfs_dir3_block_verify(
if (xfs_sb_version_hascrc(&mp->m_sb)) { if (xfs_sb_version_hascrc(&mp->m_sb)) {
if (hdr3->magic != cpu_to_be32(XFS_DIR3_BLOCK_MAGIC)) if (hdr3->magic != cpu_to_be32(XFS_DIR3_BLOCK_MAGIC))
return false; return false;
if (!uuid_equal(&hdr3->uuid, &mp->m_sb.sb_uuid)) if (!uuid_equal(&hdr3->uuid, &mp->m_sb.sb_meta_uuid))
return false; return false;
if (be64_to_cpu(hdr3->blkno) != bp->b_bn) if (be64_to_cpu(hdr3->blkno) != bp->b_bn)
return false; return false;
...@@ -157,7 +157,7 @@ xfs_dir3_block_init( ...@@ -157,7 +157,7 @@ xfs_dir3_block_init(
hdr3->magic = cpu_to_be32(XFS_DIR3_BLOCK_MAGIC); hdr3->magic = cpu_to_be32(XFS_DIR3_BLOCK_MAGIC);
hdr3->blkno = cpu_to_be64(bp->b_bn); hdr3->blkno = cpu_to_be64(bp->b_bn);
hdr3->owner = cpu_to_be64(dp->i_ino); hdr3->owner = cpu_to_be64(dp->i_ino);
uuid_copy(&hdr3->uuid, &mp->m_sb.sb_uuid); uuid_copy(&hdr3->uuid, &mp->m_sb.sb_meta_uuid);
return; return;
} }
......
...@@ -220,7 +220,7 @@ xfs_dir3_data_verify( ...@@ -220,7 +220,7 @@ xfs_dir3_data_verify(
if (xfs_sb_version_hascrc(&mp->m_sb)) { if (xfs_sb_version_hascrc(&mp->m_sb)) {
if (hdr3->magic != cpu_to_be32(XFS_DIR3_DATA_MAGIC)) if (hdr3->magic != cpu_to_be32(XFS_DIR3_DATA_MAGIC))
return false; return false;
if (!uuid_equal(&hdr3->uuid, &mp->m_sb.sb_uuid)) if (!uuid_equal(&hdr3->uuid, &mp->m_sb.sb_meta_uuid))
return false; return false;
if (be64_to_cpu(hdr3->blkno) != bp->b_bn) if (be64_to_cpu(hdr3->blkno) != bp->b_bn)
return false; return false;
...@@ -604,7 +604,7 @@ xfs_dir3_data_init( ...@@ -604,7 +604,7 @@ xfs_dir3_data_init(
hdr3->magic = cpu_to_be32(XFS_DIR3_DATA_MAGIC); hdr3->magic = cpu_to_be32(XFS_DIR3_DATA_MAGIC);
hdr3->blkno = cpu_to_be64(bp->b_bn); hdr3->blkno = cpu_to_be64(bp->b_bn);
hdr3->owner = cpu_to_be64(dp->i_ino); hdr3->owner = cpu_to_be64(dp->i_ino);
uuid_copy(&hdr3->uuid, &mp->m_sb.sb_uuid); uuid_copy(&hdr3->uuid, &mp->m_sb.sb_meta_uuid);
} else } else
hdr->magic = cpu_to_be32(XFS_DIR2_DATA_MAGIC); hdr->magic = cpu_to_be32(XFS_DIR2_DATA_MAGIC);
......
...@@ -160,7 +160,7 @@ xfs_dir3_leaf_verify( ...@@ -160,7 +160,7 @@ xfs_dir3_leaf_verify(
if (leaf3->info.hdr.magic != cpu_to_be16(magic3)) if (leaf3->info.hdr.magic != cpu_to_be16(magic3))
return false; return false;
if (!uuid_equal(&leaf3->info.uuid, &mp->m_sb.sb_uuid)) if (!uuid_equal(&leaf3->info.uuid, &mp->m_sb.sb_meta_uuid))
return false; return false;
if (be64_to_cpu(leaf3->info.blkno) != bp->b_bn) if (be64_to_cpu(leaf3->info.blkno) != bp->b_bn)
return false; return false;
...@@ -310,7 +310,7 @@ xfs_dir3_leaf_init( ...@@ -310,7 +310,7 @@ xfs_dir3_leaf_init(
: cpu_to_be16(XFS_DIR3_LEAFN_MAGIC); : cpu_to_be16(XFS_DIR3_LEAFN_MAGIC);
leaf3->info.blkno = cpu_to_be64(bp->b_bn); leaf3->info.blkno = cpu_to_be64(bp->b_bn);
leaf3->info.owner = cpu_to_be64(owner); leaf3->info.owner = cpu_to_be64(owner);
uuid_copy(&leaf3->info.uuid, &mp->m_sb.sb_uuid); uuid_copy(&leaf3->info.uuid, &mp->m_sb.sb_meta_uuid);
} else { } else {
memset(leaf, 0, sizeof(*leaf)); memset(leaf, 0, sizeof(*leaf));
leaf->hdr.info.magic = cpu_to_be16(type); leaf->hdr.info.magic = cpu_to_be16(type);
......
...@@ -93,7 +93,7 @@ xfs_dir3_free_verify( ...@@ -93,7 +93,7 @@ xfs_dir3_free_verify(
if (hdr3->magic != cpu_to_be32(XFS_DIR3_FREE_MAGIC)) if (hdr3->magic != cpu_to_be32(XFS_DIR3_FREE_MAGIC))
return false; return false;
if (!uuid_equal(&hdr3->uuid, &mp->m_sb.sb_uuid)) if (!uuid_equal(&hdr3->uuid, &mp->m_sb.sb_meta_uuid))
return false; return false;
if (be64_to_cpu(hdr3->blkno) != bp->b_bn) if (be64_to_cpu(hdr3->blkno) != bp->b_bn)
return false; return false;
...@@ -226,7 +226,7 @@ xfs_dir3_free_get_buf( ...@@ -226,7 +226,7 @@ xfs_dir3_free_get_buf(
hdr3->hdr.blkno = cpu_to_be64(bp->b_bn); hdr3->hdr.blkno = cpu_to_be64(bp->b_bn);
hdr3->hdr.owner = cpu_to_be64(dp->i_ino); hdr3->hdr.owner = cpu_to_be64(dp->i_ino);
uuid_copy(&hdr3->hdr.uuid, &mp->m_sb.sb_uuid); uuid_copy(&hdr3->hdr.uuid, &mp->m_sb.sb_meta_uuid);
} else } else
hdr.magic = XFS_DIR2_FREE_MAGIC; hdr.magic = XFS_DIR2_FREE_MAGIC;
dp->d_ops->free_hdr_to_disk(bp->b_addr, &hdr); dp->d_ops->free_hdr_to_disk(bp->b_addr, &hdr);
......
...@@ -163,7 +163,7 @@ xfs_dqcheck( ...@@ -163,7 +163,7 @@ xfs_dqcheck(
d->dd_diskdq.d_id = cpu_to_be32(id); d->dd_diskdq.d_id = cpu_to_be32(id);
if (xfs_sb_version_hascrc(&mp->m_sb)) { if (xfs_sb_version_hascrc(&mp->m_sb)) {
uuid_copy(&d->dd_uuid, &mp->m_sb.sb_uuid); uuid_copy(&d->dd_uuid, &mp->m_sb.sb_meta_uuid);
xfs_update_cksum((char *)d, sizeof(struct xfs_dqblk), xfs_update_cksum((char *)d, sizeof(struct xfs_dqblk),
XFS_DQUOT_CRC_OFF); XFS_DQUOT_CRC_OFF);
} }
...@@ -198,7 +198,7 @@ xfs_dquot_buf_verify_crc( ...@@ -198,7 +198,7 @@ xfs_dquot_buf_verify_crc(
if (!xfs_verify_cksum((char *)d, sizeof(struct xfs_dqblk), if (!xfs_verify_cksum((char *)d, sizeof(struct xfs_dqblk),
XFS_DQUOT_CRC_OFF)) XFS_DQUOT_CRC_OFF))
return false; return false;
if (!uuid_equal(&d->dd_uuid, &mp->m_sb.sb_uuid)) if (!uuid_equal(&d->dd_uuid, &mp->m_sb.sb_meta_uuid))
return false; return false;
} }
return true; return true;
......
...@@ -100,7 +100,7 @@ typedef struct xfs_sb { ...@@ -100,7 +100,7 @@ typedef struct xfs_sb {
xfs_rfsblock_t sb_dblocks; /* number of data blocks */ xfs_rfsblock_t sb_dblocks; /* number of data blocks */
xfs_rfsblock_t sb_rblocks; /* number of realtime blocks */ xfs_rfsblock_t sb_rblocks; /* number of realtime blocks */
xfs_rtblock_t sb_rextents; /* number of realtime extents */ xfs_rtblock_t sb_rextents; /* number of realtime extents */
uuid_t sb_uuid; /* file system unique id */ uuid_t sb_uuid; /* user-visible file system unique id */
xfs_fsblock_t sb_logstart; /* starting block of log if internal */ xfs_fsblock_t sb_logstart; /* starting block of log if internal */
xfs_ino_t sb_rootino; /* root inode number */ xfs_ino_t sb_rootino; /* root inode number */
xfs_ino_t sb_rbmino; /* bitmap inode for realtime extents */ xfs_ino_t sb_rbmino; /* bitmap inode for realtime extents */
...@@ -174,6 +174,7 @@ typedef struct xfs_sb { ...@@ -174,6 +174,7 @@ typedef struct xfs_sb {
xfs_ino_t sb_pquotino; /* project quota inode */ xfs_ino_t sb_pquotino; /* project quota inode */
xfs_lsn_t sb_lsn; /* last write sequence */ xfs_lsn_t sb_lsn; /* last write sequence */
uuid_t sb_meta_uuid; /* metadata file system unique id */
/* must be padded to 64 bit alignment */ /* must be padded to 64 bit alignment */
} xfs_sb_t; } xfs_sb_t;
...@@ -190,7 +191,7 @@ typedef struct xfs_dsb { ...@@ -190,7 +191,7 @@ typedef struct xfs_dsb {
__be64 sb_dblocks; /* number of data blocks */ __be64 sb_dblocks; /* number of data blocks */
__be64 sb_rblocks; /* number of realtime blocks */ __be64 sb_rblocks; /* number of realtime blocks */
__be64 sb_rextents; /* number of realtime extents */ __be64 sb_rextents; /* number of realtime extents */
uuid_t sb_uuid; /* file system unique id */ uuid_t sb_uuid; /* user-visible file system unique id */
__be64 sb_logstart; /* starting block of log if internal */ __be64 sb_logstart; /* starting block of log if internal */
__be64 sb_rootino; /* root inode number */ __be64 sb_rootino; /* root inode number */
__be64 sb_rbmino; /* bitmap inode for realtime extents */ __be64 sb_rbmino; /* bitmap inode for realtime extents */
...@@ -260,6 +261,7 @@ typedef struct xfs_dsb { ...@@ -260,6 +261,7 @@ typedef struct xfs_dsb {
__be64 sb_pquotino; /* project quota inode */ __be64 sb_pquotino; /* project quota inode */
__be64 sb_lsn; /* last write sequence */ __be64 sb_lsn; /* last write sequence */
uuid_t sb_meta_uuid; /* metadata file system unique id */
/* must be padded to 64 bit alignment */ /* must be padded to 64 bit alignment */
} xfs_dsb_t; } xfs_dsb_t;
...@@ -458,9 +460,11 @@ xfs_sb_has_ro_compat_feature( ...@@ -458,9 +460,11 @@ xfs_sb_has_ro_compat_feature(
#define XFS_SB_FEAT_INCOMPAT_FTYPE (1 << 0) /* filetype in dirent */ #define XFS_SB_FEAT_INCOMPAT_FTYPE (1 << 0) /* filetype in dirent */
#define XFS_SB_FEAT_INCOMPAT_SPINODES (1 << 1) /* sparse inode chunks */ #define XFS_SB_FEAT_INCOMPAT_SPINODES (1 << 1) /* sparse inode chunks */
#define XFS_SB_FEAT_INCOMPAT_META_UUID (1 << 2) /* metadata UUID */
#define XFS_SB_FEAT_INCOMPAT_ALL \ #define XFS_SB_FEAT_INCOMPAT_ALL \
(XFS_SB_FEAT_INCOMPAT_FTYPE| \ (XFS_SB_FEAT_INCOMPAT_FTYPE| \
XFS_SB_FEAT_INCOMPAT_SPINODES) XFS_SB_FEAT_INCOMPAT_SPINODES| \
XFS_SB_FEAT_INCOMPAT_META_UUID)
#define XFS_SB_FEAT_INCOMPAT_UNKNOWN ~XFS_SB_FEAT_INCOMPAT_ALL #define XFS_SB_FEAT_INCOMPAT_UNKNOWN ~XFS_SB_FEAT_INCOMPAT_ALL
static inline bool static inline bool
...@@ -514,6 +518,18 @@ static inline bool xfs_sb_version_hassparseinodes(struct xfs_sb *sbp) ...@@ -514,6 +518,18 @@ static inline bool xfs_sb_version_hassparseinodes(struct xfs_sb *sbp)
xfs_sb_has_incompat_feature(sbp, XFS_SB_FEAT_INCOMPAT_SPINODES); xfs_sb_has_incompat_feature(sbp, XFS_SB_FEAT_INCOMPAT_SPINODES);
} }
/*
* XFS_SB_FEAT_INCOMPAT_META_UUID indicates that the metadata UUID
* is stored separately from the user-visible UUID; this allows the
* user-visible UUID to be changed on V5 filesystems which have a
* filesystem UUID stamped into every piece of metadata.
*/
static inline bool xfs_sb_version_hasmetauuid(struct xfs_sb *sbp)
{
return (XFS_SB_VERSION_NUM(sbp) == XFS_SB_VERSION_5) &&
(sbp->sb_features_incompat & XFS_SB_FEAT_INCOMPAT_META_UUID);
}
/* /*
* end of superblock version macros * end of superblock version macros
*/ */
......
...@@ -338,7 +338,8 @@ xfs_ialloc_inode_init( ...@@ -338,7 +338,8 @@ xfs_ialloc_inode_init(
if (version == 3) { if (version == 3) {
free->di_ino = cpu_to_be64(ino); free->di_ino = cpu_to_be64(ino);
ino++; ino++;
uuid_copy(&free->di_uuid, &mp->m_sb.sb_uuid); uuid_copy(&free->di_uuid,
&mp->m_sb.sb_meta_uuid);
xfs_dinode_calc_crc(mp, free); xfs_dinode_calc_crc(mp, free);
} else if (tp) { } else if (tp) {
/* just log the inode core */ /* just log the inode core */
...@@ -2500,7 +2501,7 @@ xfs_agi_verify( ...@@ -2500,7 +2501,7 @@ xfs_agi_verify(
struct xfs_agi *agi = XFS_BUF_TO_AGI(bp); struct xfs_agi *agi = XFS_BUF_TO_AGI(bp);
if (xfs_sb_version_hascrc(&mp->m_sb) && if (xfs_sb_version_hascrc(&mp->m_sb) &&
!uuid_equal(&agi->agi_uuid, &mp->m_sb.sb_uuid)) !uuid_equal(&agi->agi_uuid, &mp->m_sb.sb_meta_uuid))
return false; return false;
/* /*
* Validate the magic number of the agi block. * Validate the magic number of the agi block.
......
...@@ -239,7 +239,7 @@ xfs_inobt_verify( ...@@ -239,7 +239,7 @@ xfs_inobt_verify(
case cpu_to_be32(XFS_FIBT_CRC_MAGIC): case cpu_to_be32(XFS_FIBT_CRC_MAGIC):
if (!xfs_sb_version_hascrc(&mp->m_sb)) if (!xfs_sb_version_hascrc(&mp->m_sb))
return false; return false;
if (!uuid_equal(&block->bb_u.s.bb_uuid, &mp->m_sb.sb_uuid)) if (!uuid_equal(&block->bb_u.s.bb_uuid, &mp->m_sb.sb_meta_uuid))
return false; return false;
if (block->bb_u.s.bb_blkno != cpu_to_be64(bp->b_bn)) if (block->bb_u.s.bb_blkno != cpu_to_be64(bp->b_bn))
return false; return false;
......
...@@ -304,7 +304,7 @@ xfs_dinode_verify( ...@@ -304,7 +304,7 @@ xfs_dinode_verify(
return false; return false;
if (be64_to_cpu(dip->di_ino) != ip->i_ino) if (be64_to_cpu(dip->di_ino) != ip->i_ino)
return false; return false;
if (!uuid_equal(&dip->di_uuid, &mp->m_sb.sb_uuid)) if (!uuid_equal(&dip->di_uuid, &mp->m_sb.sb_meta_uuid))
return false; return false;
return true; return true;
} }
...@@ -366,7 +366,7 @@ xfs_iread( ...@@ -366,7 +366,7 @@ xfs_iread(
if (xfs_sb_version_hascrc(&mp->m_sb)) { if (xfs_sb_version_hascrc(&mp->m_sb)) {
ip->i_d.di_version = 3; ip->i_d.di_version = 3;
ip->i_d.di_ino = ip->i_ino; ip->i_d.di_ino = ip->i_ino;
uuid_copy(&ip->i_d.di_uuid, &mp->m_sb.sb_uuid); uuid_copy(&ip->i_d.di_uuid, &mp->m_sb.sb_meta_uuid);
} else } else
ip->i_d.di_version = 2; ip->i_d.di_version = 2;
return 0; return 0;
......
...@@ -398,6 +398,14 @@ __xfs_sb_from_disk( ...@@ -398,6 +398,14 @@ __xfs_sb_from_disk(
to->sb_spino_align = be32_to_cpu(from->sb_spino_align); to->sb_spino_align = be32_to_cpu(from->sb_spino_align);
to->sb_pquotino = be64_to_cpu(from->sb_pquotino); to->sb_pquotino = be64_to_cpu(from->sb_pquotino);
to->sb_lsn = be64_to_cpu(from->sb_lsn); to->sb_lsn = be64_to_cpu(from->sb_lsn);
/*
* sb_meta_uuid is only on disk if it differs from sb_uuid and the
* feature flag is set; if not set we keep it only in memory.
*/
if (xfs_sb_version_hasmetauuid(to))
uuid_copy(&to->sb_meta_uuid, &from->sb_meta_uuid);
else
uuid_copy(&to->sb_meta_uuid, &from->sb_uuid);
/* Convert on-disk flags to in-memory flags? */ /* Convert on-disk flags to in-memory flags? */
if (convert_xquota) if (convert_xquota)
xfs_sb_quota_from_disk(to); xfs_sb_quota_from_disk(to);
...@@ -539,6 +547,8 @@ xfs_sb_to_disk( ...@@ -539,6 +547,8 @@ xfs_sb_to_disk(
cpu_to_be32(from->sb_features_log_incompat); cpu_to_be32(from->sb_features_log_incompat);
to->sb_spino_align = cpu_to_be32(from->sb_spino_align); to->sb_spino_align = cpu_to_be32(from->sb_spino_align);
to->sb_lsn = cpu_to_be64(from->sb_lsn); to->sb_lsn = cpu_to_be64(from->sb_lsn);
if (xfs_sb_version_hasmetauuid(from))
uuid_copy(&to->sb_meta_uuid, &from->sb_meta_uuid);
} }
} }
......
...@@ -63,7 +63,7 @@ xfs_symlink_hdr_set( ...@@ -63,7 +63,7 @@ xfs_symlink_hdr_set(
dsl->sl_magic = cpu_to_be32(XFS_SYMLINK_MAGIC); dsl->sl_magic = cpu_to_be32(XFS_SYMLINK_MAGIC);
dsl->sl_offset = cpu_to_be32(offset); dsl->sl_offset = cpu_to_be32(offset);
dsl->sl_bytes = cpu_to_be32(size); dsl->sl_bytes = cpu_to_be32(size);
uuid_copy(&dsl->sl_uuid, &mp->m_sb.sb_uuid); uuid_copy(&dsl->sl_uuid, &mp->m_sb.sb_meta_uuid);
dsl->sl_owner = cpu_to_be64(ino); dsl->sl_owner = cpu_to_be64(ino);
dsl->sl_blkno = cpu_to_be64(bp->b_bn); dsl->sl_blkno = cpu_to_be64(bp->b_bn);
bp->b_ops = &xfs_symlink_buf_ops; bp->b_ops = &xfs_symlink_buf_ops;
...@@ -107,7 +107,7 @@ xfs_symlink_verify( ...@@ -107,7 +107,7 @@ xfs_symlink_verify(
return false; return false;
if (dsl->sl_magic != cpu_to_be32(XFS_SYMLINK_MAGIC)) if (dsl->sl_magic != cpu_to_be32(XFS_SYMLINK_MAGIC))
return false; return false;
if (!uuid_equal(&dsl->sl_uuid, &mp->m_sb.sb_uuid)) if (!uuid_equal(&dsl->sl_uuid, &mp->m_sb.sb_meta_uuid))
return false; return false;
if (bp->b_bn != be64_to_cpu(dsl->sl_blkno)) if (bp->b_bn != be64_to_cpu(dsl->sl_blkno))
return false; return false;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册