On Tue, Nov 09, 2021 at 07:58:34PM -0600, Eric Sandeen wrote: > The xfs_perag structure and initialization is unused in userspace, > so #ifdef it out with __KERNEL__ to facilitate the xfsprogs sync > and build. > > Signed-off-by: Eric Sandeen <sandeen@xxxxxxxxxx> Looks severely whitespace damaged, but /me has gotten tired of dealing with all the navel gazing around #ifdef __KERNEL__. I want to move on to more difficult topics like grokking and evaluating online repair, and get us away from arguing about how to preprocessor. This gets us closer to parity between the two libxfses, and reflects what the two libxfs maintainers more or less agree upon, so with patch 4/3 added in and the whitespace fixed... Reviewed-by: Darrick J. Wong <djwong@xxxxxxxxxx> --D > --- > > diff --git a/fs/xfs/libxfs/xfs_ag.c b/fs/xfs/libxfs/xfs_ag.c > index 005abfd9fd34..ecfb213d8fa3 100644 > --- a/fs/xfs/libxfs/xfs_ag.c > +++ b/fs/xfs/libxfs/xfs_ag.c > @@ -248,6 +248,7 @@ xfs_initialize_perag( > spin_unlock(&mp->m_perag_lock); > radix_tree_preload_end(); > +#ifdef __KERNEL__ > /* Place kernel structure only init below this point. */ > spin_lock_init(&pag->pag_ici_lock); > spin_lock_init(&pag->pagb_lock); > @@ -257,6 +258,7 @@ xfs_initialize_perag( > init_waitqueue_head(&pag->pagb_wait); > pag->pagb_count = 0; > pag->pagb_tree = RB_ROOT; > +#endif /* __KERNEL_ */ > error = xfs_buf_hash_init(pag); > if (error) > diff --git a/fs/xfs/libxfs/xfs_ag.h b/fs/xfs/libxfs/xfs_ag.h > index 4c6f9045baca..01c36cfe6909 100644 > --- a/fs/xfs/libxfs/xfs_ag.h > +++ b/fs/xfs/libxfs/xfs_ag.h > @@ -64,6 +64,10 @@ struct xfs_perag { > /* Blocks reserved for the reverse mapping btree. */ > struct xfs_ag_resv pag_rmapbt_resv; > + /* for rcu-safe freeing */ > + struct rcu_head rcu_head; > + > +#ifdef __KERNEL__ > /* -- kernel only structures below this line -- */ > /* > @@ -90,9 +94,6 @@ struct xfs_perag { > spinlock_t pag_buf_lock; /* lock for pag_buf_hash */ > struct rhashtable pag_buf_hash; > - /* for rcu-safe freeing */ > - struct rcu_head rcu_head; > - > /* background prealloc block trimming */ > struct delayed_work pag_blockgc_work; > @@ -102,6 +103,7 @@ struct xfs_perag { > * or have some other means to control concurrency. > */ > struct rhashtable pagi_unlinked_hash; > +#endif /* __KERNEL__ */ > }; > int xfs_initialize_perag(struct xfs_mount *mp, xfs_agnumber_t agcount, >