]> www.infradead.org Git - users/willy/linux.git/commitdiff
KVM: arm64: Add hyp_spin_is_locked() for basic locking assertions at EL2
authorWill Deacon <will@kernel.org>
Mon, 9 Aug 2021 15:24:28 +0000 (16:24 +0100)
committerMarc Zyngier <maz@kernel.org>
Wed, 11 Aug 2021 10:39:35 +0000 (11:39 +0100)
Introduce hyp_spin_is_locked() so that functions can easily assert that
a given lock is held (albeit possibly by another CPU!) without having to
drag full lockdep support up to EL2.

Signed-off-by: Will Deacon <will@kernel.org>
Signed-off-by: Quentin Perret <qperret@google.com>
Signed-off-by: Marc Zyngier <maz@kernel.org>
Link: https://lore.kernel.org/r/20210809152448.1810400-2-qperret@google.com
arch/arm64/kvm/hyp/include/nvhe/spinlock.h

index 76b537f8d1c6eda22734eaeb66c2dc67920816b4..04f65b655fcf69052e1f8696451a732116be35d9 100644 (file)
@@ -15,6 +15,7 @@
 
 #include <asm/alternative.h>
 #include <asm/lse.h>
+#include <asm/rwonce.h>
 
 typedef union hyp_spinlock {
        u32     __val;
@@ -89,4 +90,11 @@ static inline void hyp_spin_unlock(hyp_spinlock_t *lock)
        : "memory");
 }
 
+static inline bool hyp_spin_is_locked(hyp_spinlock_t *lock)
+{
+       hyp_spinlock_t lockval = READ_ONCE(*lock);
+
+       return lockval.owner != lockval.next;
+}
+
 #endif /* __ARM64_KVM_NVHE_SPINLOCK_H__ */