Commit 85ab1b23 authored by Brian Foster's avatar Brian Foster Committed by Greg Kroah-Hartman

xfs: fix spurious spin_is_locked() assert failures on non-smp kernels

commit 95989c46 upstream.

The 0-day kernel test robot reports assertion failures on
!CONFIG_SMP kernels due to failed spin_is_locked() checks. As it
turns out, spin_is_locked() is hardcoded to return zero on
!CONFIG_SMP kernels and so this function cannot be relied on to
verify spinlock state in this configuration.

To avoid this problem, replace the associated asserts with lockdep
variants that do the right thing regardless of kernel configuration.
Drop the one assert that checks for an unlocked lock as there is no
suitable lockdep variant for that case. This moves the spinlock
checks from XFS debug code to lockdep, but generally provides the
same level of protection.
Reported-by: default avatarkbuild test robot <fengguang.wu@intel.com>
Signed-off-by: default avatarBrian Foster <bfoster@redhat.com>
Reviewed-by: default avatarChristoph Hellwig <hch@lst.de>
Reviewed-by: default avatarDarrick J. Wong <darrick.wong@oracle.com>
Signed-off-by: default avatarDarrick J. Wong <darrick.wong@oracle.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 4c1d33c4
...@@ -116,7 +116,7 @@ static inline void ...@@ -116,7 +116,7 @@ static inline void
__xfs_buf_ioacct_dec( __xfs_buf_ioacct_dec(
struct xfs_buf *bp) struct xfs_buf *bp)
{ {
ASSERT(spin_is_locked(&bp->b_lock)); lockdep_assert_held(&bp->b_lock);
if (bp->b_state & XFS_BSTATE_IN_FLIGHT) { if (bp->b_state & XFS_BSTATE_IN_FLIGHT) {
bp->b_state &= ~XFS_BSTATE_IN_FLIGHT; bp->b_state &= ~XFS_BSTATE_IN_FLIGHT;
......
...@@ -66,7 +66,6 @@ xfs_inode_alloc( ...@@ -66,7 +66,6 @@ xfs_inode_alloc(
XFS_STATS_INC(mp, vn_active); XFS_STATS_INC(mp, vn_active);
ASSERT(atomic_read(&ip->i_pincount) == 0); ASSERT(atomic_read(&ip->i_pincount) == 0);
ASSERT(!spin_is_locked(&ip->i_flags_lock));
ASSERT(!xfs_isiflocked(ip)); ASSERT(!xfs_isiflocked(ip));
ASSERT(ip->i_ino == 0); ASSERT(ip->i_ino == 0);
...@@ -192,7 +191,7 @@ xfs_perag_set_reclaim_tag( ...@@ -192,7 +191,7 @@ xfs_perag_set_reclaim_tag(
{ {
struct xfs_mount *mp = pag->pag_mount; struct xfs_mount *mp = pag->pag_mount;
ASSERT(spin_is_locked(&pag->pag_ici_lock)); lockdep_assert_held(&pag->pag_ici_lock);
if (pag->pag_ici_reclaimable++) if (pag->pag_ici_reclaimable++)
return; return;
...@@ -214,7 +213,7 @@ xfs_perag_clear_reclaim_tag( ...@@ -214,7 +213,7 @@ xfs_perag_clear_reclaim_tag(
{ {
struct xfs_mount *mp = pag->pag_mount; struct xfs_mount *mp = pag->pag_mount;
ASSERT(spin_is_locked(&pag->pag_ici_lock)); lockdep_assert_held(&pag->pag_ici_lock);
if (--pag->pag_ici_reclaimable) if (--pag->pag_ici_reclaimable)
return; return;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment