On Tue, May 24, 2022 at 12:21:57PM +1000, Dave Chinner wrote: > From: Dave Chinner <dchinner@xxxxxxxxxx> > > Not fatal, the assert is there to catch developer attention. I'm > seeing this occasionally during recoveryloop testing after a > shutdown, and I don't want this to stop an overnight recoveryloop > run as it is currently doing. > > Convert the ASSERT to a XFS_IS_CORRUPT() check so it will dump a > corruption report into the log and cause a test failure that way, > but it won't stop the machine dead. > > Signed-off-by: Dave Chinner <dchinner@xxxxxxxxxx> > --- > fs/xfs/libxfs/xfs_ag.c | 3 +-- > 1 file changed, 1 insertion(+), 2 deletions(-) > > diff --git a/fs/xfs/libxfs/xfs_ag.c b/fs/xfs/libxfs/xfs_ag.c > index 1e4ee042d52f..3e920cf1b454 100644 > --- a/fs/xfs/libxfs/xfs_ag.c > +++ b/fs/xfs/libxfs/xfs_ag.c > @@ -173,7 +173,6 @@ __xfs_free_perag( > struct xfs_perag *pag = container_of(head, struct xfs_perag, rcu_head); > > ASSERT(!delayed_work_pending(&pag->pag_blockgc_work)); > - ASSERT(atomic_read(&pag->pag_ref) == 0); Er, shouldn't this also be converted to XFS_IS_CORRUPT? That's what the commit message said... --D > kmem_free(pag); > } > > @@ -192,7 +191,7 @@ xfs_free_perag( > pag = radix_tree_delete(&mp->m_perag_tree, agno); > spin_unlock(&mp->m_perag_lock); > ASSERT(pag); > - ASSERT(atomic_read(&pag->pag_ref) == 0); > + XFS_IS_CORRUPT(pag->pag_mount, atomic_read(&pag->pag_ref) != 0); > > cancel_delayed_work_sync(&pag->pag_blockgc_work); > xfs_iunlink_destroy(pag); > -- > 2.35.1 >