Commit 9343ee76 authored by Dave Chinner's avatar Dave Chinner Committed by Darrick J. Wong

xfs: convert bp->b_bn references to xfs_buf_daddr()

Stop directly referencing b_bn in code outside the buffer cache, as
b_bn is supposed to be used only as an internal cache index.
Signed-off-by: default avatarDave Chinner <dchinner@redhat.com>
Reviewed-by: default avatarChristoph Hellwig <hch@lst.de>
Reviewed-by: default avatarDarrick J. Wong <djwong@kernel.org>
Signed-off-by: default avatarDarrick J. Wong <djwong@kernel.org>
parent 04fcad80
...@@ -313,7 +313,6 @@ xfs_get_aghdr_buf( ...@@ -313,7 +313,6 @@ xfs_get_aghdr_buf(
if (error) if (error)
return error; return error;
bp->b_bn = blkno;
bp->b_maps[0].bm_bn = blkno; bp->b_maps[0].bm_bn = blkno;
bp->b_ops = ops; bp->b_ops = ops;
......
...@@ -1206,7 +1206,7 @@ xfs_attr3_leaf_to_node( ...@@ -1206,7 +1206,7 @@ xfs_attr3_leaf_to_node(
memcpy(bp2->b_addr, bp1->b_addr, args->geo->blksize); memcpy(bp2->b_addr, bp1->b_addr, args->geo->blksize);
if (xfs_has_crc(mp)) { if (xfs_has_crc(mp)) {
struct xfs_da3_blkinfo *hdr3 = bp2->b_addr; struct xfs_da3_blkinfo *hdr3 = bp2->b_addr;
hdr3->blkno = cpu_to_be64(bp2->b_bn); hdr3->blkno = cpu_to_be64(xfs_buf_daddr(bp2));
} }
xfs_trans_log_buf(args->trans, bp2, 0, args->geo->blksize - 1); xfs_trans_log_buf(args->trans, bp2, 0, args->geo->blksize - 1);
...@@ -1274,7 +1274,7 @@ xfs_attr3_leaf_create( ...@@ -1274,7 +1274,7 @@ xfs_attr3_leaf_create(
ichdr.magic = XFS_ATTR3_LEAF_MAGIC; ichdr.magic = XFS_ATTR3_LEAF_MAGIC;
hdr3->blkno = cpu_to_be64(bp->b_bn); hdr3->blkno = cpu_to_be64(xfs_buf_daddr(bp));
hdr3->owner = cpu_to_be64(dp->i_ino); hdr3->owner = cpu_to_be64(dp->i_ino);
uuid_copy(&hdr3->uuid, &mp->m_sb.sb_meta_uuid); uuid_copy(&hdr3->uuid, &mp->m_sb.sb_meta_uuid);
......
...@@ -130,7 +130,7 @@ __xfs_attr3_rmt_read_verify( ...@@ -130,7 +130,7 @@ __xfs_attr3_rmt_read_verify(
return 0; return 0;
ptr = bp->b_addr; ptr = bp->b_addr;
bno = bp->b_bn; bno = xfs_buf_daddr(bp);
len = BBTOB(bp->b_length); len = BBTOB(bp->b_length);
ASSERT(len >= blksize); ASSERT(len >= blksize);
...@@ -195,7 +195,7 @@ xfs_attr3_rmt_write_verify( ...@@ -195,7 +195,7 @@ xfs_attr3_rmt_write_verify(
return; return;
ptr = bp->b_addr; ptr = bp->b_addr;
bno = bp->b_bn; bno = xfs_buf_daddr(bp);
len = BBTOB(bp->b_length); len = BBTOB(bp->b_length);
ASSERT(len >= blksize); ASSERT(len >= blksize);
...@@ -284,7 +284,7 @@ xfs_attr_rmtval_copyout( ...@@ -284,7 +284,7 @@ xfs_attr_rmtval_copyout(
uint8_t **dst) uint8_t **dst)
{ {
char *src = bp->b_addr; char *src = bp->b_addr;
xfs_daddr_t bno = bp->b_bn; xfs_daddr_t bno = xfs_buf_daddr(bp);
int len = BBTOB(bp->b_length); int len = BBTOB(bp->b_length);
int blksize = mp->m_attr_geo->blksize; int blksize = mp->m_attr_geo->blksize;
...@@ -332,7 +332,7 @@ xfs_attr_rmtval_copyin( ...@@ -332,7 +332,7 @@ xfs_attr_rmtval_copyin(
uint8_t **src) uint8_t **src)
{ {
char *dst = bp->b_addr; char *dst = bp->b_addr;
xfs_daddr_t bno = bp->b_bn; xfs_daddr_t bno = xfs_buf_daddr(bp);
int len = BBTOB(bp->b_length); int len = BBTOB(bp->b_length);
int blksize = mp->m_attr_geo->blksize; int blksize = mp->m_attr_geo->blksize;
......
...@@ -739,7 +739,7 @@ xfs_bmap_extents_to_btree( ...@@ -739,7 +739,7 @@ xfs_bmap_extents_to_btree(
*/ */
abp->b_ops = &xfs_bmbt_buf_ops; abp->b_ops = &xfs_bmbt_buf_ops;
ablock = XFS_BUF_TO_BLOCK(abp); ablock = XFS_BUF_TO_BLOCK(abp);
xfs_btree_init_block_int(mp, ablock, abp->b_bn, xfs_btree_init_block_int(mp, ablock, xfs_buf_daddr(abp),
XFS_BTNUM_BMAP, 0, 0, ip->i_ino, XFS_BTNUM_BMAP, 0, 0, ip->i_ino,
XFS_BTREE_LONG_PTRS); XFS_BTREE_LONG_PTRS);
......
...@@ -70,7 +70,7 @@ __xfs_btree_check_lblock( ...@@ -70,7 +70,7 @@ __xfs_btree_check_lblock(
if (!uuid_equal(&block->bb_u.l.bb_uuid, &mp->m_sb.sb_meta_uuid)) if (!uuid_equal(&block->bb_u.l.bb_uuid, &mp->m_sb.sb_meta_uuid))
return __this_address; return __this_address;
if (block->bb_u.l.bb_blkno != if (block->bb_u.l.bb_blkno !=
cpu_to_be64(bp ? bp->b_bn : XFS_BUF_DADDR_NULL)) cpu_to_be64(bp ? xfs_buf_daddr(bp) : XFS_BUF_DADDR_NULL))
return __this_address; return __this_address;
if (block->bb_u.l.bb_pad != cpu_to_be32(0)) if (block->bb_u.l.bb_pad != cpu_to_be32(0))
return __this_address; return __this_address;
...@@ -135,7 +135,7 @@ __xfs_btree_check_sblock( ...@@ -135,7 +135,7 @@ __xfs_btree_check_sblock(
if (!uuid_equal(&block->bb_u.s.bb_uuid, &mp->m_sb.sb_meta_uuid)) if (!uuid_equal(&block->bb_u.s.bb_uuid, &mp->m_sb.sb_meta_uuid))
return __this_address; return __this_address;
if (block->bb_u.s.bb_blkno != if (block->bb_u.s.bb_blkno !=
cpu_to_be64(bp ? bp->b_bn : XFS_BUF_DADDR_NULL)) cpu_to_be64(bp ? xfs_buf_daddr(bp) : XFS_BUF_DADDR_NULL))
return __this_address; return __this_address;
} }
...@@ -1131,7 +1131,7 @@ xfs_btree_init_block( ...@@ -1131,7 +1131,7 @@ xfs_btree_init_block(
__u16 numrecs, __u16 numrecs,
__u64 owner) __u64 owner)
{ {
xfs_btree_init_block_int(mp, XFS_BUF_TO_BLOCK(bp), bp->b_bn, xfs_btree_init_block_int(mp, XFS_BUF_TO_BLOCK(bp), xfs_buf_daddr(bp),
btnum, level, numrecs, owner, 0); btnum, level, numrecs, owner, 0);
} }
...@@ -1155,9 +1155,9 @@ xfs_btree_init_block_cur( ...@@ -1155,9 +1155,9 @@ xfs_btree_init_block_cur(
else else
owner = cur->bc_ag.pag->pag_agno; owner = cur->bc_ag.pag->pag_agno;
xfs_btree_init_block_int(cur->bc_mp, XFS_BUF_TO_BLOCK(bp), bp->b_bn, xfs_btree_init_block_int(cur->bc_mp, XFS_BUF_TO_BLOCK(bp),
cur->bc_btnum, level, numrecs, xfs_buf_daddr(bp), cur->bc_btnum, level,
owner, cur->bc_flags); numrecs, owner, cur->bc_flags);
} }
/* /*
...@@ -2923,10 +2923,11 @@ xfs_btree_new_iroot( ...@@ -2923,10 +2923,11 @@ xfs_btree_new_iroot(
*/ */
memcpy(cblock, block, xfs_btree_block_len(cur)); memcpy(cblock, block, xfs_btree_block_len(cur));
if (cur->bc_flags & XFS_BTREE_CRC_BLOCKS) { if (cur->bc_flags & XFS_BTREE_CRC_BLOCKS) {
__be64 bno = cpu_to_be64(xfs_buf_daddr(cbp));
if (cur->bc_flags & XFS_BTREE_LONG_PTRS) if (cur->bc_flags & XFS_BTREE_LONG_PTRS)
cblock->bb_u.l.bb_blkno = cpu_to_be64(cbp->b_bn); cblock->bb_u.l.bb_blkno = bno;
else else
cblock->bb_u.s.bb_blkno = cpu_to_be64(cbp->b_bn); cblock->bb_u.s.bb_blkno = bno;
} }
be16_add_cpu(&block->bb_level, 1); be16_add_cpu(&block->bb_level, 1);
...@@ -3225,7 +3226,7 @@ xfs_btree_insrec( ...@@ -3225,7 +3226,7 @@ xfs_btree_insrec(
/* Get pointers to the btree buffer and block. */ /* Get pointers to the btree buffer and block. */
block = xfs_btree_get_block(cur, level, &bp); block = xfs_btree_get_block(cur, level, &bp);
old_bn = bp ? bp->b_bn : XFS_BUF_DADDR_NULL; old_bn = bp ? xfs_buf_daddr(bp) : XFS_BUF_DADDR_NULL;
numrecs = xfs_btree_get_numrecs(block); numrecs = xfs_btree_get_numrecs(block);
#ifdef DEBUG #ifdef DEBUG
...@@ -3341,7 +3342,7 @@ xfs_btree_insrec( ...@@ -3341,7 +3342,7 @@ xfs_btree_insrec(
* some records into the new tree block), so use the regular key * some records into the new tree block), so use the regular key
* update mechanism. * update mechanism.
*/ */
if (bp && bp->b_bn != old_bn) { if (bp && xfs_buf_daddr(bp) != old_bn) {
xfs_btree_get_keys(cur, block, lkey); xfs_btree_get_keys(cur, block, lkey);
} else if (xfs_btree_needs_key_update(cur, optr)) { } else if (xfs_btree_needs_key_update(cur, optr)) {
error = xfs_btree_update_keys(cur, level); error = xfs_btree_update_keys(cur, level);
...@@ -4422,7 +4423,7 @@ xfs_btree_lblock_v5hdr_verify( ...@@ -4422,7 +4423,7 @@ xfs_btree_lblock_v5hdr_verify(
return __this_address; return __this_address;
if (!uuid_equal(&block->bb_u.l.bb_uuid, &mp->m_sb.sb_meta_uuid)) if (!uuid_equal(&block->bb_u.l.bb_uuid, &mp->m_sb.sb_meta_uuid))
return __this_address; return __this_address;
if (block->bb_u.l.bb_blkno != cpu_to_be64(bp->b_bn)) if (block->bb_u.l.bb_blkno != cpu_to_be64(xfs_buf_daddr(bp)))
return __this_address; return __this_address;
if (owner != XFS_RMAP_OWN_UNKNOWN && if (owner != XFS_RMAP_OWN_UNKNOWN &&
be64_to_cpu(block->bb_u.l.bb_owner) != owner) be64_to_cpu(block->bb_u.l.bb_owner) != owner)
...@@ -4472,7 +4473,7 @@ xfs_btree_sblock_v5hdr_verify( ...@@ -4472,7 +4473,7 @@ xfs_btree_sblock_v5hdr_verify(
return __this_address; return __this_address;
if (!uuid_equal(&block->bb_u.s.bb_uuid, &mp->m_sb.sb_meta_uuid)) if (!uuid_equal(&block->bb_u.s.bb_uuid, &mp->m_sb.sb_meta_uuid))
return __this_address; return __this_address;
if (block->bb_u.s.bb_blkno != cpu_to_be64(bp->b_bn)) if (block->bb_u.s.bb_blkno != cpu_to_be64(xfs_buf_daddr(bp)))
return __this_address; return __this_address;
if (pag && be32_to_cpu(block->bb_u.s.bb_owner) != pag->pag_agno) if (pag && be32_to_cpu(block->bb_u.s.bb_owner) != pag->pag_agno)
return __this_address; return __this_address;
......
...@@ -194,7 +194,7 @@ xfs_da3_blkinfo_verify( ...@@ -194,7 +194,7 @@ xfs_da3_blkinfo_verify(
if (xfs_has_crc(mp)) { if (xfs_has_crc(mp)) {
if (!uuid_equal(&hdr3->uuid, &mp->m_sb.sb_meta_uuid)) if (!uuid_equal(&hdr3->uuid, &mp->m_sb.sb_meta_uuid))
return __this_address; return __this_address;
if (be64_to_cpu(hdr3->blkno) != bp->b_bn) if (be64_to_cpu(hdr3->blkno) != xfs_buf_daddr(bp))
return __this_address; return __this_address;
if (!xfs_log_check_lsn(mp, be64_to_cpu(hdr3->lsn))) if (!xfs_log_check_lsn(mp, be64_to_cpu(hdr3->lsn)))
return __this_address; return __this_address;
...@@ -447,7 +447,7 @@ xfs_da3_node_create( ...@@ -447,7 +447,7 @@ xfs_da3_node_create(
memset(hdr3, 0, sizeof(struct xfs_da3_node_hdr)); memset(hdr3, 0, sizeof(struct xfs_da3_node_hdr));
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(xfs_buf_daddr(bp));
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_meta_uuid); uuid_copy(&hdr3->info.uuid, &mp->m_sb.sb_meta_uuid);
} else { } else {
...@@ -711,7 +711,7 @@ xfs_da3_root_split( ...@@ -711,7 +711,7 @@ xfs_da3_root_split(
oldroot->hdr.info.magic == cpu_to_be16(XFS_DIR3_LEAFN_MAGIC)) { oldroot->hdr.info.magic == cpu_to_be16(XFS_DIR3_LEAFN_MAGIC)) {
struct xfs_da3_intnode *node3 = (struct xfs_da3_intnode *)node; struct xfs_da3_intnode *node3 = (struct xfs_da3_intnode *)node;
node3->hdr.info.blkno = cpu_to_be64(bp->b_bn); node3->hdr.info.blkno = cpu_to_be64(xfs_buf_daddr(bp));
} }
xfs_trans_log_buf(tp, bp, 0, size - 1); xfs_trans_log_buf(tp, bp, 0, size - 1);
...@@ -1219,7 +1219,7 @@ xfs_da3_root_join( ...@@ -1219,7 +1219,7 @@ xfs_da3_root_join(
xfs_trans_buf_copy_type(root_blk->bp, bp); xfs_trans_buf_copy_type(root_blk->bp, bp);
if (oldroothdr.magic == XFS_DA3_NODE_MAGIC) { if (oldroothdr.magic == XFS_DA3_NODE_MAGIC) {
struct xfs_da3_blkinfo *da3 = root_blk->bp->b_addr; struct xfs_da3_blkinfo *da3 = root_blk->bp->b_addr;
da3->blkno = cpu_to_be64(root_blk->bp->b_bn); da3->blkno = cpu_to_be64(xfs_buf_daddr(root_blk->bp));
} }
xfs_trans_log_buf(args->trans, root_blk->bp, 0, xfs_trans_log_buf(args->trans, root_blk->bp, 0,
args->geo->blksize - 1); args->geo->blksize - 1);
......
...@@ -56,7 +56,7 @@ xfs_dir3_block_verify( ...@@ -56,7 +56,7 @@ xfs_dir3_block_verify(
if (xfs_has_crc(mp)) { if (xfs_has_crc(mp)) {
if (!uuid_equal(&hdr3->uuid, &mp->m_sb.sb_meta_uuid)) if (!uuid_equal(&hdr3->uuid, &mp->m_sb.sb_meta_uuid))
return __this_address; return __this_address;
if (be64_to_cpu(hdr3->blkno) != bp->b_bn) if (be64_to_cpu(hdr3->blkno) != xfs_buf_daddr(bp))
return __this_address; return __this_address;
if (!xfs_log_check_lsn(mp, be64_to_cpu(hdr3->lsn))) if (!xfs_log_check_lsn(mp, be64_to_cpu(hdr3->lsn)))
return __this_address; return __this_address;
...@@ -174,7 +174,7 @@ xfs_dir3_block_init( ...@@ -174,7 +174,7 @@ xfs_dir3_block_init(
if (xfs_has_crc(mp)) { if (xfs_has_crc(mp)) {
memset(hdr3, 0, sizeof(*hdr3)); memset(hdr3, 0, sizeof(*hdr3));
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(xfs_buf_daddr(bp));
hdr3->owner = cpu_to_be64(dp->i_ino); hdr3->owner = cpu_to_be64(dp->i_ino);
uuid_copy(&hdr3->uuid, &mp->m_sb.sb_meta_uuid); uuid_copy(&hdr3->uuid, &mp->m_sb.sb_meta_uuid);
return; return;
......
...@@ -300,7 +300,7 @@ xfs_dir3_data_verify( ...@@ -300,7 +300,7 @@ xfs_dir3_data_verify(
if (xfs_has_crc(mp)) { if (xfs_has_crc(mp)) {
if (!uuid_equal(&hdr3->uuid, &mp->m_sb.sb_meta_uuid)) if (!uuid_equal(&hdr3->uuid, &mp->m_sb.sb_meta_uuid))
return __this_address; return __this_address;
if (be64_to_cpu(hdr3->blkno) != bp->b_bn) if (be64_to_cpu(hdr3->blkno) != xfs_buf_daddr(bp))
return __this_address; return __this_address;
if (!xfs_log_check_lsn(mp, be64_to_cpu(hdr3->lsn))) if (!xfs_log_check_lsn(mp, be64_to_cpu(hdr3->lsn)))
return __this_address; return __this_address;
...@@ -722,7 +722,7 @@ xfs_dir3_data_init( ...@@ -722,7 +722,7 @@ xfs_dir3_data_init(
memset(hdr3, 0, sizeof(*hdr3)); memset(hdr3, 0, sizeof(*hdr3));
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(xfs_buf_daddr(bp));
hdr3->owner = cpu_to_be64(dp->i_ino); hdr3->owner = cpu_to_be64(dp->i_ino);
uuid_copy(&hdr3->uuid, &mp->m_sb.sb_meta_uuid); uuid_copy(&hdr3->uuid, &mp->m_sb.sb_meta_uuid);
......
...@@ -108,7 +108,7 @@ xfs_dir3_leaf1_check( ...@@ -108,7 +108,7 @@ xfs_dir3_leaf1_check(
if (leafhdr.magic == XFS_DIR3_LEAF1_MAGIC) { if (leafhdr.magic == XFS_DIR3_LEAF1_MAGIC) {
struct xfs_dir3_leaf_hdr *leaf3 = bp->b_addr; struct xfs_dir3_leaf_hdr *leaf3 = bp->b_addr;
if (be64_to_cpu(leaf3->info.blkno) != bp->b_bn) if (be64_to_cpu(leaf3->info.blkno) != xfs_buf_daddr(bp))
return __this_address; return __this_address;
} else if (leafhdr.magic != XFS_DIR2_LEAF1_MAGIC) } else if (leafhdr.magic != XFS_DIR2_LEAF1_MAGIC)
return __this_address; return __this_address;
...@@ -316,7 +316,7 @@ xfs_dir3_leaf_init( ...@@ -316,7 +316,7 @@ xfs_dir3_leaf_init(
leaf3->info.hdr.magic = (type == XFS_DIR2_LEAF1_MAGIC) leaf3->info.hdr.magic = (type == XFS_DIR2_LEAF1_MAGIC)
? cpu_to_be16(XFS_DIR3_LEAF1_MAGIC) ? cpu_to_be16(XFS_DIR3_LEAF1_MAGIC)
: 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(xfs_buf_daddr(bp));
leaf3->info.owner = cpu_to_be64(owner); leaf3->info.owner = cpu_to_be64(owner);
uuid_copy(&leaf3->info.uuid, &mp->m_sb.sb_meta_uuid); uuid_copy(&leaf3->info.uuid, &mp->m_sb.sb_meta_uuid);
} else { } else {
......
...@@ -68,7 +68,7 @@ xfs_dir3_leafn_check( ...@@ -68,7 +68,7 @@ xfs_dir3_leafn_check(
if (leafhdr.magic == XFS_DIR3_LEAFN_MAGIC) { if (leafhdr.magic == XFS_DIR3_LEAFN_MAGIC) {
struct xfs_dir3_leaf_hdr *leaf3 = bp->b_addr; struct xfs_dir3_leaf_hdr *leaf3 = bp->b_addr;
if (be64_to_cpu(leaf3->info.blkno) != bp->b_bn) if (be64_to_cpu(leaf3->info.blkno) != xfs_buf_daddr(bp))
return __this_address; return __this_address;
} else if (leafhdr.magic != XFS_DIR2_LEAFN_MAGIC) } else if (leafhdr.magic != XFS_DIR2_LEAFN_MAGIC)
return __this_address; return __this_address;
...@@ -110,7 +110,7 @@ xfs_dir3_free_verify( ...@@ -110,7 +110,7 @@ xfs_dir3_free_verify(
if (!uuid_equal(&hdr3->uuid, &mp->m_sb.sb_meta_uuid)) if (!uuid_equal(&hdr3->uuid, &mp->m_sb.sb_meta_uuid))
return __this_address; return __this_address;
if (be64_to_cpu(hdr3->blkno) != bp->b_bn) if (be64_to_cpu(hdr3->blkno) != xfs_buf_daddr(bp))
return __this_address; return __this_address;
if (!xfs_log_check_lsn(mp, be64_to_cpu(hdr3->lsn))) if (!xfs_log_check_lsn(mp, be64_to_cpu(hdr3->lsn)))
return __this_address; return __this_address;
...@@ -346,7 +346,7 @@ xfs_dir3_free_get_buf( ...@@ -346,7 +346,7 @@ xfs_dir3_free_get_buf(
hdr.magic = XFS_DIR3_FREE_MAGIC; hdr.magic = XFS_DIR3_FREE_MAGIC;
hdr3->hdr.blkno = cpu_to_be64(bp->b_bn); hdr3->hdr.blkno = cpu_to_be64(xfs_buf_daddr(bp));
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_meta_uuid); uuid_copy(&hdr3->hdr.uuid, &mp->m_sb.sb_meta_uuid);
} else } else
......
...@@ -71,7 +71,7 @@ xfs_inode_buf_verify( ...@@ -71,7 +71,7 @@ xfs_inode_buf_verify(
#ifdef DEBUG #ifdef DEBUG
xfs_alert(mp, xfs_alert(mp,
"bad inode magic/vsn daddr %lld #%d (magic=%x)", "bad inode magic/vsn daddr %lld #%d (magic=%x)",
(unsigned long long)bp->b_bn, i, (unsigned long long)xfs_buf_daddr(bp), i,
be16_to_cpu(dip->di_magic)); be16_to_cpu(dip->di_magic));
#endif #endif
xfs_buf_verifier_error(bp, -EFSCORRUPTED, xfs_buf_verifier_error(bp, -EFSCORRUPTED,
......
...@@ -747,7 +747,7 @@ xfs_sb_read_verify( ...@@ -747,7 +747,7 @@ xfs_sb_read_verify(
if (!xfs_buf_verify_cksum(bp, XFS_SB_CRC_OFF)) { if (!xfs_buf_verify_cksum(bp, XFS_SB_CRC_OFF)) {
/* Only fail bad secondaries on a known V5 filesystem */ /* Only fail bad secondaries on a known V5 filesystem */
if (bp->b_maps[0].bm_bn == XFS_SB_DADDR || if (xfs_buf_daddr(bp) == XFS_SB_DADDR ||
xfs_has_crc(mp)) { xfs_has_crc(mp)) {
error = -EFSBADCRC; error = -EFSBADCRC;
goto out_error; goto out_error;
......
...@@ -51,7 +51,7 @@ xfs_symlink_hdr_set( ...@@ -51,7 +51,7 @@ xfs_symlink_hdr_set(
dsl->sl_bytes = cpu_to_be32(size); dsl->sl_bytes = cpu_to_be32(size);
uuid_copy(&dsl->sl_uuid, &mp->m_sb.sb_meta_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(xfs_buf_daddr(bp));
bp->b_ops = &xfs_symlink_buf_ops; bp->b_ops = &xfs_symlink_buf_ops;
return sizeof(struct xfs_dsymlink_hdr); return sizeof(struct xfs_dsymlink_hdr);
...@@ -95,7 +95,7 @@ xfs_symlink_verify( ...@@ -95,7 +95,7 @@ xfs_symlink_verify(
return __this_address; return __this_address;
if (!uuid_equal(&dsl->sl_uuid, &mp->m_sb.sb_meta_uuid)) if (!uuid_equal(&dsl->sl_uuid, &mp->m_sb.sb_meta_uuid))
return __this_address; return __this_address;
if (bp->b_bn != be64_to_cpu(dsl->sl_blkno)) if (xfs_buf_daddr(bp) != be64_to_cpu(dsl->sl_blkno))
return __this_address; return __this_address;
if (be32_to_cpu(dsl->sl_offset) + if (be32_to_cpu(dsl->sl_offset) +
be32_to_cpu(dsl->sl_bytes) >= XFS_SYMLINK_MAXLEN) be32_to_cpu(dsl->sl_bytes) >= XFS_SYMLINK_MAXLEN)
......
...@@ -260,7 +260,7 @@ xbitmap_set_btcur_path( ...@@ -260,7 +260,7 @@ xbitmap_set_btcur_path(
xfs_btree_get_block(cur, i, &bp); xfs_btree_get_block(cur, i, &bp);
if (!bp) if (!bp)
continue; continue;
fsb = XFS_DADDR_TO_FSB(cur->bc_mp, bp->b_bn); fsb = XFS_DADDR_TO_FSB(cur->bc_mp, xfs_buf_daddr(bp));
error = xbitmap_set(bitmap, fsb, 1); error = xbitmap_set(bitmap, fsb, 1);
if (error) if (error)
return error; return error;
...@@ -284,7 +284,7 @@ xbitmap_collect_btblock( ...@@ -284,7 +284,7 @@ xbitmap_collect_btblock(
if (!bp) if (!bp)
return 0; return 0;
fsbno = XFS_DADDR_TO_FSB(cur->bc_mp, bp->b_bn); fsbno = XFS_DADDR_TO_FSB(cur->bc_mp, xfs_buf_daddr(bp));
return xbitmap_set(bitmap, fsbno, 1); return xbitmap_set(bitmap, fsbno, 1);
} }
......
...@@ -186,7 +186,7 @@ xchk_block_set_preen( ...@@ -186,7 +186,7 @@ xchk_block_set_preen(
struct xfs_buf *bp) struct xfs_buf *bp)
{ {
sc->sm->sm_flags |= XFS_SCRUB_OFLAG_PREEN; sc->sm->sm_flags |= XFS_SCRUB_OFLAG_PREEN;
trace_xchk_block_preen(sc, bp->b_bn, __return_address); trace_xchk_block_preen(sc, xfs_buf_daddr(bp), __return_address);
} }
/* /*
...@@ -219,7 +219,7 @@ xchk_block_set_corrupt( ...@@ -219,7 +219,7 @@ xchk_block_set_corrupt(
struct xfs_buf *bp) struct xfs_buf *bp)
{ {
sc->sm->sm_flags |= XFS_SCRUB_OFLAG_CORRUPT; sc->sm->sm_flags |= XFS_SCRUB_OFLAG_CORRUPT;
trace_xchk_block_error(sc, bp->b_bn, __return_address); trace_xchk_block_error(sc, xfs_buf_daddr(bp), __return_address);
} }
/* Record a corruption while cross-referencing. */ /* Record a corruption while cross-referencing. */
...@@ -229,7 +229,7 @@ xchk_block_xref_set_corrupt( ...@@ -229,7 +229,7 @@ xchk_block_xref_set_corrupt(
struct xfs_buf *bp) struct xfs_buf *bp)
{ {
sc->sm->sm_flags |= XFS_SCRUB_OFLAG_XCORRUPT; sc->sm->sm_flags |= XFS_SCRUB_OFLAG_XCORRUPT;
trace_xchk_block_error(sc, bp->b_bn, __return_address); trace_xchk_block_error(sc, xfs_buf_daddr(bp), __return_address);
} }
/* /*
...@@ -784,7 +784,7 @@ xchk_buffer_recheck( ...@@ -784,7 +784,7 @@ xchk_buffer_recheck(
if (!fa) if (!fa)
return; return;
sc->sm->sm_flags |= XFS_SCRUB_OFLAG_CORRUPT; sc->sm->sm_flags |= XFS_SCRUB_OFLAG_CORRUPT;
trace_xchk_block_error(sc, bp->b_bn, fa); trace_xchk_block_error(sc, xfs_buf_daddr(bp), fa);
} }
/* /*
......
...@@ -22,11 +22,11 @@ xchk_btree_cur_fsbno( ...@@ -22,11 +22,11 @@ xchk_btree_cur_fsbno(
int level) int level)
{ {
if (level < cur->bc_nlevels && cur->bc_bufs[level]) if (level < cur->bc_nlevels && cur->bc_bufs[level])
return XFS_DADDR_TO_FSB(cur->bc_mp, cur->bc_bufs[level]->b_bn); return XFS_DADDR_TO_FSB(cur->bc_mp,
else if (level == cur->bc_nlevels - 1 && xfs_buf_daddr(cur->bc_bufs[level]));
cur->bc_flags & XFS_BTREE_LONG_PTRS) if (level == cur->bc_nlevels - 1 && cur->bc_flags & XFS_BTREE_LONG_PTRS)
return XFS_INO_TO_FSB(cur->bc_mp, cur->bc_ino.ip->i_ino); return XFS_INO_TO_FSB(cur->bc_mp, cur->bc_ino.ip->i_ino);
else if (!(cur->bc_flags & XFS_BTREE_LONG_PTRS)) if (!(cur->bc_flags & XFS_BTREE_LONG_PTRS))
return XFS_AGB_TO_FSB(cur->bc_mp, cur->bc_ag.pag->pag_agno, 0); return XFS_AGB_TO_FSB(cur->bc_mp, cur->bc_ag.pag->pag_agno, 0);
return NULLFSBLOCK; return NULLFSBLOCK;
} }
......
...@@ -151,7 +151,7 @@ xfs_attr3_node_inactive( ...@@ -151,7 +151,7 @@ xfs_attr3_node_inactive(
} }
xfs_da3_node_hdr_from_disk(dp->i_mount, &ichdr, bp->b_addr); xfs_da3_node_hdr_from_disk(dp->i_mount, &ichdr, bp->b_addr);
parent_blkno = bp->b_bn; parent_blkno = xfs_buf_daddr(bp);
if (!ichdr.count) { if (!ichdr.count) {
xfs_trans_brelse(*trans, bp); xfs_trans_brelse(*trans, bp);
return 0; return 0;
...@@ -271,7 +271,7 @@ xfs_attr3_root_inactive( ...@@ -271,7 +271,7 @@ xfs_attr3_root_inactive(
error = xfs_da3_node_read(*trans, dp, 0, &bp, XFS_ATTR_FORK); error = xfs_da3_node_read(*trans, dp, 0, &bp, XFS_ATTR_FORK);
if (error) if (error)
return error; return error;
blkno = bp->b_bn; blkno = xfs_buf_daddr(bp);
/* /*
* Invalidate the tree, even if the "tree" is only a single leaf block. * Invalidate the tree, even if the "tree" is only a single leaf block.
......
...@@ -581,7 +581,7 @@ xfs_buf_item_push( ...@@ -581,7 +581,7 @@ xfs_buf_item_push(
if (bp->b_flags & XBF_WRITE_FAIL) { if (bp->b_flags & XBF_WRITE_FAIL) {
xfs_buf_alert_ratelimited(bp, "XFS: Failing async write", xfs_buf_alert_ratelimited(bp, "XFS: Failing async write",
"Failing async write on buffer block 0x%llx. Retrying async write.", "Failing async write on buffer block 0x%llx. Retrying async write.",
(long long)bp->b_bn); (long long)xfs_buf_daddr(bp));
} }
if (!xfs_buf_delwri_queue(bp, buffer_list)) if (!xfs_buf_delwri_queue(bp, buffer_list))
......
...@@ -497,7 +497,7 @@ xlog_recover_do_reg_buffer( ...@@ -497,7 +497,7 @@ xlog_recover_do_reg_buffer(
if (fa) { if (fa) {
xfs_alert(mp, xfs_alert(mp,
"dquot corrupt at %pS trying to replay into block 0x%llx", "dquot corrupt at %pS trying to replay into block 0x%llx",
fa, bp->b_bn); fa, xfs_buf_daddr(bp));
goto next; goto next;
} }
} }
......
...@@ -371,7 +371,7 @@ xfs_buf_corruption_error( ...@@ -371,7 +371,7 @@ xfs_buf_corruption_error(
xfs_alert_tag(mp, XFS_PTAG_VERIFIER_ERROR, xfs_alert_tag(mp, XFS_PTAG_VERIFIER_ERROR,
"Metadata corruption detected at %pS, %s block 0x%llx", "Metadata corruption detected at %pS, %s block 0x%llx",
fa, bp->b_ops->name, bp->b_bn); fa, bp->b_ops->name, xfs_buf_daddr(bp));
xfs_alert(mp, "Unmount and run xfs_repair"); xfs_alert(mp, "Unmount and run xfs_repair");
...@@ -402,7 +402,7 @@ xfs_buf_verifier_error( ...@@ -402,7 +402,7 @@ xfs_buf_verifier_error(
xfs_alert_tag(mp, XFS_PTAG_VERIFIER_ERROR, xfs_alert_tag(mp, XFS_PTAG_VERIFIER_ERROR,
"Metadata %s detected at %pS, %s block 0x%llx %s", "Metadata %s detected at %pS, %s block 0x%llx %s",
bp->b_error == -EFSBADCRC ? "CRC error" : "corruption", bp->b_error == -EFSBADCRC ? "CRC error" : "corruption",
fa, bp->b_ops->name, bp->b_bn, name); fa, bp->b_ops->name, xfs_buf_daddr(bp), name);
xfs_alert(mp, "Unmount and run xfs_repair"); xfs_alert(mp, "Unmount and run xfs_repair");
......
...@@ -421,10 +421,7 @@ DECLARE_EVENT_CLASS(xfs_buf_class, ...@@ -421,10 +421,7 @@ DECLARE_EVENT_CLASS(xfs_buf_class,
), ),
TP_fast_assign( TP_fast_assign(
__entry->dev = bp->b_target->bt_dev; __entry->dev = bp->b_target->bt_dev;
if (bp->b_bn == XFS_BUF_DADDR_NULL) __entry->bno = xfs_buf_daddr(bp);
__entry->bno = bp->b_maps[0].bm_bn;
else
__entry->bno = bp->b_bn;
__entry->nblks = bp->b_length; __entry->nblks = bp->b_length;
__entry->hold = atomic_read(&bp->b_hold); __entry->hold = atomic_read(&bp->b_hold);
__entry->pincount = atomic_read(&bp->b_pin_count); __entry->pincount = atomic_read(&bp->b_pin_count);
...@@ -492,7 +489,7 @@ DECLARE_EVENT_CLASS(xfs_buf_flags_class, ...@@ -492,7 +489,7 @@ DECLARE_EVENT_CLASS(xfs_buf_flags_class,
), ),
TP_fast_assign( TP_fast_assign(
__entry->dev = bp->b_target->bt_dev; __entry->dev = bp->b_target->bt_dev;
__entry->bno = bp->b_bn; __entry->bno = xfs_buf_daddr(bp);
__entry->length = bp->b_length; __entry->length = bp->b_length;
__entry->flags = flags; __entry->flags = flags;
__entry->hold = atomic_read(&bp->b_hold); __entry->hold = atomic_read(&bp->b_hold);
...@@ -536,7 +533,7 @@ TRACE_EVENT(xfs_buf_ioerror, ...@@ -536,7 +533,7 @@ TRACE_EVENT(xfs_buf_ioerror,
), ),
TP_fast_assign( TP_fast_assign(
__entry->dev = bp->b_target->bt_dev; __entry->dev = bp->b_target->bt_dev;
__entry->bno = bp->b_bn; __entry->bno = xfs_buf_daddr(bp);
__entry->length = bp->b_length; __entry->length = bp->b_length;
__entry->hold = atomic_read(&bp->b_hold); __entry->hold = atomic_read(&bp->b_hold);
__entry->pincount = atomic_read(&bp->b_pin_count); __entry->pincount = atomic_read(&bp->b_pin_count);
...@@ -579,7 +576,7 @@ DECLARE_EVENT_CLASS(xfs_buf_item_class, ...@@ -579,7 +576,7 @@ DECLARE_EVENT_CLASS(xfs_buf_item_class,
__entry->bli_flags = bip->bli_flags; __entry->bli_flags = bip->bli_flags;
__entry->bli_recur = bip->bli_recur; __entry->bli_recur = bip->bli_recur;
__entry->bli_refcount = atomic_read(&bip->bli_refcount); __entry->bli_refcount = atomic_read(&bip->bli_refcount);
__entry->buf_bno = bip->bli_buf->b_bn; __entry->buf_bno = xfs_buf_daddr(bip->bli_buf);
__entry->buf_len = bip->bli_buf->b_length; __entry->buf_len = bip->bli_buf->b_length;
__entry->buf_flags = bip->bli_buf->b_flags; __entry->buf_flags = bip->bli_buf->b_flags;
__entry->buf_hold = atomic_read(&bip->bli_buf->b_hold); __entry->buf_hold = atomic_read(&bip->bli_buf->b_hold);
...@@ -2480,7 +2477,7 @@ DECLARE_EVENT_CLASS(xfs_btree_cur_class, ...@@ -2480,7 +2477,7 @@ DECLARE_EVENT_CLASS(xfs_btree_cur_class,
__entry->level = level; __entry->level = level;
__entry->nlevels = cur->bc_nlevels; __entry->nlevels = cur->bc_nlevels;
__entry->ptr = cur->bc_ptrs[level]; __entry->ptr = cur->bc_ptrs[level];
__entry->daddr = bp ? bp->b_bn : -1; __entry->daddr = bp ? xfs_buf_daddr(bp) : -1;
), ),
TP_printk("dev %d:%d btree %s level %d/%d ptr %d daddr 0x%llx", TP_printk("dev %d:%d btree %s level %d/%d ptr %d daddr 0x%llx",
MAJOR(__entry->dev), MINOR(__entry->dev), MAJOR(__entry->dev), MINOR(__entry->dev),
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment