locking/atomics: Instrument cmpxchg_double*()
We currently don't instrument cmpxchg_double() and cmpxchg_double_local() due to compilation issues reported in the past, which are supposedly related to GCC bug 72873 [1], reported when GCC 7 was not yet released. This bug only applies to x86-64, and does not apply to other architectures. While the test case for GCC bug 72873 triggers issues with released versions of GCC, the instrumented kernel code compiles fine for all configurations I have tried, and it is unclear how the two cases are/were related. As we can't reproduce the kernel build failures, let's instrument cmpxchg_double*() again. We can revisit the issue if build failures reappear. Signed-off-by: Mark Rutland <mark.rutland@arm.com> Acked-by: Peter Zijlstra (Intel) <peterz@infradead.org> Acked-by: Will Deacon <will.deacon@arm.com> Cc: Arnd Bergmann <arnd@arndb.de> Cc: Boqun Feng <boqun.feng@gmail.com> Cc: Dmitry Vyukov <dvyukov@google.com> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: andy.shevchenko@gmail.com Cc: aryabinin@virtuozzo.com Cc: catalin.marinas@arm.com Cc: glider@google.com Cc: linux-arm-kernel@lists.infradead.org Cc: parri.andrea@gmail.com Cc: peter@hurleysoftware.com Link: http://lkml.kernel.org/r/20180716113017.3909-6-mark.rutland@arm.com Signed-off-by: Ingo Molnar <mingo@kernel.org>
This commit is contained in:
parent
f9881cc43b
commit
4d2b25f630
|
@ -450,23 +450,18 @@ static __always_inline bool atomic64_add_negative(s64 i, atomic64_t *v)
|
||||||
arch_cmpxchg64_local(__ai_ptr, (old), (new)); \
|
arch_cmpxchg64_local(__ai_ptr, (old), (new)); \
|
||||||
})
|
})
|
||||||
|
|
||||||
/*
|
|
||||||
* Originally we had the following code here:
|
|
||||||
* __typeof__(p1) ____p1 = (p1);
|
|
||||||
* kasan_check_write(____p1, 2 * sizeof(*____p1));
|
|
||||||
* arch_cmpxchg_double(____p1, (p2), (o1), (o2), (n1), (n2));
|
|
||||||
* But it leads to compilation failures (see gcc issue 72873).
|
|
||||||
* So for now it's left non-instrumented.
|
|
||||||
* There are few callers of cmpxchg_double(), so it's not critical.
|
|
||||||
*/
|
|
||||||
#define cmpxchg_double(p1, p2, o1, o2, n1, n2) \
|
#define cmpxchg_double(p1, p2, o1, o2, n1, n2) \
|
||||||
({ \
|
({ \
|
||||||
arch_cmpxchg_double((p1), (p2), (o1), (o2), (n1), (n2)); \
|
typeof(p1) __ai_p1 = (p1); \
|
||||||
|
kasan_check_write(__ai_p1, 2 * sizeof(*__ai_p1)); \
|
||||||
|
arch_cmpxchg_double(__ai_p1, (p2), (o1), (o2), (n1), (n2)); \
|
||||||
})
|
})
|
||||||
|
|
||||||
#define cmpxchg_double_local(p1, p2, o1, o2, n1, n2) \
|
#define cmpxchg_double_local(p1, p2, o1, o2, n1, n2) \
|
||||||
({ \
|
({ \
|
||||||
arch_cmpxchg_double_local((p1), (p2), (o1), (o2), (n1), (n2)); \
|
typeof(p1) __ai_p1 = (p1); \
|
||||||
|
kasan_check_write(__ai_p1, 2 * sizeof(*__ai_p1)); \
|
||||||
|
arch_cmpxchg_double_local(__ai_p1, (p2), (o1), (o2), (n1), (n2)); \
|
||||||
})
|
})
|
||||||
|
|
||||||
#endif /* _LINUX_ATOMIC_INSTRUMENTED_H */
|
#endif /* _LINUX_ATOMIC_INSTRUMENTED_H */
|
||||||
|
|
Loading…
Reference in New Issue