On Tue, May 11, 2021 at 08:34:40AM -0400, Brian Foster wrote: > On Thu, May 06, 2021 at 05:20:48PM +1000, Dave Chinner wrote: > > From: Dave Chinner <dchinner@xxxxxxxxxx> > > > > Now that everything passes a perag, the agno is not needed anymore. > > Convert all the users to use pag->pag_agno instead and remove the > > agno from the cursor. This was largely done as an automated search > > and replace. > > > > Signed-off-by: Dave Chinner <dchinner@xxxxxxxxxx> > > --- > > fs/xfs/libxfs/xfs_alloc.c | 2 +- > > fs/xfs/libxfs/xfs_alloc_btree.c | 1 - > > fs/xfs/libxfs/xfs_btree.c | 12 ++-- > > fs/xfs/libxfs/xfs_btree.h | 1 - > > fs/xfs/libxfs/xfs_ialloc.c | 2 +- > > fs/xfs/libxfs/xfs_ialloc_btree.c | 7 +- > > fs/xfs/libxfs/xfs_refcount.c | 82 +++++++++++----------- > > fs/xfs/libxfs/xfs_refcount_btree.c | 11 ++- > > fs/xfs/libxfs/xfs_rmap.c | 108 ++++++++++++++--------------- > > fs/xfs/libxfs/xfs_rmap_btree.c | 1 - > > fs/xfs/scrub/agheader_repair.c | 2 +- > > fs/xfs/scrub/alloc.c | 3 +- > > fs/xfs/scrub/bmap.c | 2 +- > > fs/xfs/scrub/ialloc.c | 9 +-- > > fs/xfs/scrub/refcount.c | 3 +- > > fs/xfs/scrub/rmap.c | 3 +- > > fs/xfs/scrub/trace.c | 3 +- > > fs/xfs/xfs_fsmap.c | 4 +- > > fs/xfs/xfs_trace.h | 4 +- > > 19 files changed, 130 insertions(+), 130 deletions(-) > > > ... > > diff --git a/fs/xfs/libxfs/xfs_rmap.c b/fs/xfs/libxfs/xfs_rmap.c > > index b23f949ee15c..d1dfad0204e3 100644 > > --- a/fs/xfs/libxfs/xfs_rmap.c > > +++ b/fs/xfs/libxfs/xfs_rmap.c > ... > > @@ -2389,7 +2389,7 @@ xfs_rmap_finish_one( > > * the startblock, get one now. > > */ > > rcur = *pcur; > > - if (rcur != NULL && rcur->bc_ag.agno != pag->pag_agno) { > > + if (rcur != NULL && rcur->bc_ag.pag != pag) { > > I wonder a bit about this sort of logic if the goal is to ultimately > allow for dynamic instantiation of perag structures, though it's > probably not an issue here. The cursor will have an active reference, hence the perag it holds cannot be reclaimed until it drops it's reference. THis is the reason for pushing the perag into the cursor - we can guarantee the existence of the perag for as long as a btree cursor chain (i.e. the original cursor + all it's children that were duplicated from it). Hence I think that checks that the pag is the same memory address indicate that the perag is still the same. > > xfs_rmap_finish_one_cleanup(tp, rcur, 0); > > rcur = NULL; > > *pcur = NULL; > ... > > diff --git a/fs/xfs/xfs_trace.h b/fs/xfs/xfs_trace.h > > index 808ae337b222..5ba9c6396dcb 100644 > > --- a/fs/xfs/xfs_trace.h > > +++ b/fs/xfs/xfs_trace.h > > @@ -3730,7 +3730,7 @@ TRACE_EVENT(xfs_btree_commit_afakeroot, > > TP_fast_assign( > > __entry->dev = cur->bc_mp->m_super->s_dev; > > __entry->btnum = cur->bc_btnum; > > - __entry->agno = cur->bc_ag.agno; > > + __entry->agno = cur->bc_ag.pag->pag_agno; > > It would be nice if we did this with some of the other tracepoints > rather than pulling ->pag_agno out at every callsite, but that's > probably something for another patch. All in all this looks fine to me: Yeah, that's something to clean up down the track. Cleaning up tracepoints have been low on my priority list - just retaining what they capture is sufficient for the initial conversion.... > Reviewed-by: Brian Foster <bfoster@xxxxxxxxxx> Ta. Cheers, Dave. -- Dave Chinner david@xxxxxxxxxxxxx