Skip to content

Commit b987ffc

Browse files
Peter ZijlstraIngo Molnar
authored andcommitted
x86/qspinlock: Fix compile error
With a compiler that has asm-goto but not asm-cc-output and CONFIG_PROFILE_ALL_BRANCHES=y we get a compiler error: arch/x86/include/asm/rmwcc.h:23:17: error: jump into statement expression Fix this by writing the if() as a boolean multiplication instead. Reported-by: kbuild test robot <lkp@intel.com> Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Will Deacon <will.deacon@arm.com> Cc: linux-kernel@vger.kernel.org Fixes: 7aa54be ("locking/qspinlock, x86: Provide liveness guarantee") Signed-off-by: Ingo Molnar <mingo@kernel.org>
1 parent 5b74498 commit b987ffc

File tree

1 file changed

+8
-5
lines changed

1 file changed

+8
-5
lines changed

arch/x86/include/asm/qspinlock.h

Lines changed: 8 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -13,12 +13,15 @@
1313
#define queued_fetch_set_pending_acquire queued_fetch_set_pending_acquire
1414
static __always_inline u32 queued_fetch_set_pending_acquire(struct qspinlock *lock)
1515
{
16-
u32 val = 0;
17-
18-
if (GEN_BINARY_RMWcc(LOCK_PREFIX "btsl", lock->val.counter, c,
19-
"I", _Q_PENDING_OFFSET))
20-
val |= _Q_PENDING_VAL;
16+
u32 val;
2117

18+
/*
19+
* We can't use GEN_BINARY_RMWcc() inside an if() stmt because asm goto
20+
* and CONFIG_PROFILE_ALL_BRANCHES=y results in a label inside a
21+
* statement expression, which GCC doesn't like.
22+
*/
23+
val = GEN_BINARY_RMWcc(LOCK_PREFIX "btsl", lock->val.counter, c,
24+
"I", _Q_PENDING_OFFSET) * _Q_PENDING_VAL;
2225
val |= atomic_read(&lock->val) & ~_Q_PENDING_MASK;
2326

2427
return val;

0 commit comments

Comments
 (0)