forked from luck/tmp_suning_uos_patched
x86: fix spin_is_contended()
The masked difference is what needs to be compared against 1, rather than the difference of masked values (which can be negative). Signed-off-by: Jan Beulich <jbeulich@novell.com> Acked-by: Nick Piggin <npiggin@suse.de> Cc: <stable@kernel.org> Signed-off-by: Ingo Molnar <mingo@elte.hu>
This commit is contained in:
parent
8bb851900f
commit
7bc069c6bc
@ -65,7 +65,7 @@ static inline int __ticket_spin_is_contended(raw_spinlock_t *lock)
|
|||||||
{
|
{
|
||||||
int tmp = ACCESS_ONCE(lock->slock);
|
int tmp = ACCESS_ONCE(lock->slock);
|
||||||
|
|
||||||
return (((tmp >> 8) & 0xff) - (tmp & 0xff)) > 1;
|
return (((tmp >> 8) - tmp) & 0xff) > 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static __always_inline void __ticket_spin_lock(raw_spinlock_t *lock)
|
static __always_inline void __ticket_spin_lock(raw_spinlock_t *lock)
|
||||||
@ -127,7 +127,7 @@ static inline int __ticket_spin_is_contended(raw_spinlock_t *lock)
|
|||||||
{
|
{
|
||||||
int tmp = ACCESS_ONCE(lock->slock);
|
int tmp = ACCESS_ONCE(lock->slock);
|
||||||
|
|
||||||
return (((tmp >> 16) & 0xffff) - (tmp & 0xffff)) > 1;
|
return (((tmp >> 16) - tmp) & 0xffff) > 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static __always_inline void __ticket_spin_lock(raw_spinlock_t *lock)
|
static __always_inline void __ticket_spin_lock(raw_spinlock_t *lock)
|
||||||
|
Loading…
Reference in New Issue
Block a user