diff options
| author | Christoph Hellwig <hch@lst.de> | 2024-11-03 20:18:44 -0800 | 
|---|---|---|
| committer | Darrick J. Wong <djwong@kernel.org> | 2024-11-05 13:38:29 -0800 | 
| commit | 77a530e6c49d22bd4a221d2f059db24fc30094db (patch) | |
| tree | 9c91268de40a88bb0f4bacd8b8c0f6028f13d1a9 /fs/xfs/libxfs/xfs_ialloc_btree.c | |
| parent | adbc76aa0fedcb6da2d1ceb1ce786d1f963afee8 (diff) | |
xfs: add a generic group pointer to the btree cursor
Replace the pag pointers in the type specific union with a generic
xfs_group pointer.  This prepares for adding realtime group support.
Signed-off-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Darrick J. Wong <djwong@kernel.org>
Signed-off-by: Darrick J. Wong <djwong@kernel.org>
Diffstat (limited to 'fs/xfs/libxfs/xfs_ialloc_btree.c')
| -rw-r--r-- | fs/xfs/libxfs/xfs_ialloc_btree.c | 15 | 
1 files changed, 8 insertions, 7 deletions
| diff --git a/fs/xfs/libxfs/xfs_ialloc_btree.c b/fs/xfs/libxfs/xfs_ialloc_btree.c index 91d44be2ce48..4c28deb3e988 100644 --- a/fs/xfs/libxfs/xfs_ialloc_btree.c +++ b/fs/xfs/libxfs/xfs_ialloc_btree.c @@ -37,7 +37,7 @@ STATIC struct xfs_btree_cur *  xfs_inobt_dup_cursor(  	struct xfs_btree_cur	*cur)  { -	return xfs_inobt_init_cursor(cur->bc_ag.pag, cur->bc_tp, +	return xfs_inobt_init_cursor(to_perag(cur->bc_group), cur->bc_tp,  			cur->bc_ag.agbp);  } @@ -45,7 +45,7 @@ STATIC struct xfs_btree_cur *  xfs_finobt_dup_cursor(  	struct xfs_btree_cur	*cur)  { -	return xfs_finobt_init_cursor(cur->bc_ag.pag, cur->bc_tp, +	return xfs_finobt_init_cursor(to_perag(cur->bc_group), cur->bc_tp,  			cur->bc_ag.agbp);  } @@ -112,7 +112,7 @@ __xfs_inobt_alloc_block(  	memset(&args, 0, sizeof(args));  	args.tp = cur->bc_tp;  	args.mp = cur->bc_mp; -	args.pag = cur->bc_ag.pag; +	args.pag = to_perag(cur->bc_group);  	args.oinfo = XFS_RMAP_OINFO_INOBT;  	args.minlen = 1;  	args.maxlen = 1; @@ -248,7 +248,7 @@ xfs_inobt_init_ptr_from_cur(  {  	struct xfs_agi		*agi = cur->bc_ag.agbp->b_addr; -	ASSERT(pag_agno(cur->bc_ag.pag) == be32_to_cpu(agi->agi_seqno)); +	ASSERT(cur->bc_group->xg_gno == be32_to_cpu(agi->agi_seqno));  	ptr->s = agi->agi_root;  } @@ -260,7 +260,8 @@ xfs_finobt_init_ptr_from_cur(  {  	struct xfs_agi		*agi = cur->bc_ag.agbp->b_addr; -	ASSERT(pag_agno(cur->bc_ag.pag) == be32_to_cpu(agi->agi_seqno)); +	ASSERT(cur->bc_group->xg_gno == be32_to_cpu(agi->agi_seqno)); +  	ptr->s = agi->agi_free_root;  } @@ -483,7 +484,7 @@ xfs_inobt_init_cursor(  	cur = xfs_btree_alloc_cursor(mp, tp, &xfs_inobt_ops,  			M_IGEO(mp)->inobt_maxlevels, xfs_inobt_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_agi		*agi = agbp->b_addr; @@ -509,7 +510,7 @@ xfs_finobt_init_cursor(  	cur = xfs_btree_alloc_cursor(mp, tp, &xfs_finobt_ops,  			M_IGEO(mp)->inobt_maxlevels, xfs_inobt_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_agi		*agi = agbp->b_addr; | 
