diff options
Diffstat (limited to 'fs/xfs/libxfs/xfs_rmap_btree.c')
| -rw-r--r-- | fs/xfs/libxfs/xfs_rmap_btree.c | 19 | 
1 files changed, 10 insertions, 9 deletions
| diff --git a/fs/xfs/libxfs/xfs_rmap_btree.c b/fs/xfs/libxfs/xfs_rmap_btree.c index b37eaf37c7fd..2cab694ac58a 100644 --- a/fs/xfs/libxfs/xfs_rmap_btree.c +++ b/fs/xfs/libxfs/xfs_rmap_btree.c @@ -57,7 +57,7 @@ xfs_rmapbt_dup_cursor(  	struct xfs_btree_cur	*cur)  {  	return xfs_rmapbt_init_cursor(cur->bc_mp, cur->bc_tp, -				cur->bc_ag.agbp, cur->bc_ag.pag); +				cur->bc_ag.agbp, to_perag(cur->bc_group));  }  STATIC void @@ -66,14 +66,15 @@ xfs_rmapbt_set_root(  	const union xfs_btree_ptr	*ptr,  	int				inc)  { -	struct xfs_buf		*agbp = cur->bc_ag.agbp; -	struct xfs_agf		*agf = agbp->b_addr; +	struct xfs_buf			*agbp = cur->bc_ag.agbp; +	struct xfs_agf			*agf = agbp->b_addr; +	struct xfs_perag		*pag = to_perag(cur->bc_group);  	ASSERT(ptr->s != 0);  	agf->agf_rmap_root = ptr->s;  	be32_add_cpu(&agf->agf_rmap_level, inc); -	cur->bc_ag.pag->pagf_rmap_level += inc; +	pag->pagf_rmap_level += inc;  	xfs_alloc_log_agf(cur->bc_tp, agbp, XFS_AGF_ROOTS | XFS_AGF_LEVELS);  } @@ -87,7 +88,7 @@ xfs_rmapbt_alloc_block(  {  	struct xfs_buf		*agbp = cur->bc_ag.agbp;  	struct xfs_agf		*agf = agbp->b_addr; -	struct xfs_perag	*pag = cur->bc_ag.pag; +	struct xfs_perag	*pag = to_perag(cur->bc_group);  	struct xfs_alloc_arg    args = { .len = 1 };  	int			error;  	xfs_agblock_t		bno; @@ -125,7 +126,7 @@ xfs_rmapbt_free_block(  {  	struct xfs_buf		*agbp = cur->bc_ag.agbp;  	struct xfs_agf		*agf = agbp->b_addr; -	struct xfs_perag	*pag = cur->bc_ag.pag; +	struct xfs_perag	*pag = to_perag(cur->bc_group);  	xfs_agblock_t		bno;  	int			error; @@ -227,7 +228,7 @@ xfs_rmapbt_init_ptr_from_cur(  {  	struct xfs_agf		*agf = cur->bc_ag.agbp->b_addr; -	ASSERT(pag_agno(cur->bc_ag.pag) == be32_to_cpu(agf->agf_seqno)); +	ASSERT(cur->bc_group->xg_gno == be32_to_cpu(agf->agf_seqno));  	ptr->s = agf->agf_rmap_root;  } @@ -538,7 +539,7 @@ xfs_rmapbt_init_cursor(  	cur = xfs_btree_alloc_cursor(mp, tp, &xfs_rmapbt_ops,  			mp->m_rmap_maxlevels, xfs_rmapbt_cur_cache); -	cur->bc_ag.pag = xfs_perag_hold(pag); +	cur->bc_group = xfs_group_hold(pag_group(pag));  	cur->bc_ag.agbp = agbp;  	if (agbp) {  		struct xfs_agf		*agf = agbp->b_addr; @@ -653,7 +654,7 @@ xfs_rmapbt_mem_cursor(  	cur->bc_mem.xfbtree = xfbt;  	cur->bc_nlevels = xfbt->nlevels; -	cur->bc_mem.pag = xfs_perag_hold(pag); +	cur->bc_group = xfs_group_hold(pag_group(pag));  	return cur;  } | 
