aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux/compiler-clang.h
diff options
context:
space:
mode:
authorNick Desaulniers <ndesaulniers@google.com>2018-08-22 19:37:24 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2018-08-22 20:31:34 -0400
commit815f0ddb346c196018d4d8f8f55c12b83da1de3f (patch)
tree4805bf7e3cb7ec4e727aba8e62f9211e9001a760 /include/linux/compiler-clang.h
parent899fbc33fd775b9dfa363db28f322272920a2196 (diff)
include/linux/compiler*.h: make compiler-*.h mutually exclusive
Commit cafa0010cd51 ("Raise the minimum required gcc version to 4.6") recently exposed a brittle part of the build for supporting non-gcc compilers. Both Clang and ICC define __GNUC__, __GNUC_MINOR__, and __GNUC_PATCHLEVEL__ for quick compatibility with code bases that haven't added compiler specific checks for __clang__ or __INTEL_COMPILER. This is brittle, as they happened to get compatibility by posing as a certain version of GCC. This broke when upgrading the minimal version of GCC required to build the kernel, to a version above what ICC and Clang claim to be. Rather than always including compiler-gcc.h then undefining or redefining macros in compiler-intel.h or compiler-clang.h, let's separate out the compiler specific macro definitions into mutually exclusive headers, do more proper compiler detection, and keep shared definitions in compiler_types.h. Fixes: cafa0010cd51 ("Raise the minimum required gcc version to 4.6") Reported-by: Masahiro Yamada <yamada.masahiro@socionext.com> Suggested-by: Eli Friedman <efriedma@codeaurora.org> Suggested-by: Joe Perches <joe@perches.com> Signed-off-by: Nick Desaulniers <ndesaulniers@google.com> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'include/linux/compiler-clang.h')
-rw-r--r--include/linux/compiler-clang.h20
1 files changed, 9 insertions, 11 deletions
diff --git a/include/linux/compiler-clang.h b/include/linux/compiler-clang.h
index 7087446c24c8..b1ce500fe8b3 100644
--- a/include/linux/compiler-clang.h
+++ b/include/linux/compiler-clang.h
@@ -6,11 +6,7 @@
6/* Some compiler specific definitions are overwritten here 6/* Some compiler specific definitions are overwritten here
7 * for Clang compiler 7 * for Clang compiler
8 */ 8 */
9
10#ifdef uninitialized_var
11#undef uninitialized_var
12#define uninitialized_var(x) x = *(&(x)) 9#define uninitialized_var(x) x = *(&(x))
13#endif
14 10
15/* same as gcc, this was present in clang-2.6 so we can assume it works 11/* same as gcc, this was present in clang-2.6 so we can assume it works
16 * with any version that can compile the kernel 12 * with any version that can compile the kernel
@@ -25,14 +21,8 @@
25#define __SANITIZE_ADDRESS__ 21#define __SANITIZE_ADDRESS__
26#endif 22#endif
27 23
28#undef __no_sanitize_address
29#define __no_sanitize_address __attribute__((no_sanitize("address"))) 24#define __no_sanitize_address __attribute__((no_sanitize("address")))
30 25
31/* Clang doesn't have a way to turn it off per-function, yet. */
32#ifdef __noretpoline
33#undef __noretpoline
34#endif
35
36/* 26/*
37 * Not all versions of clang implement the the type-generic versions 27 * Not all versions of clang implement the the type-generic versions
38 * of the builtin overflow checkers. Fortunately, clang implements 28 * of the builtin overflow checkers. Fortunately, clang implements
@@ -40,9 +30,17 @@
40 * checks. Unfortunately, we don't know which version of gcc clang 30 * checks. Unfortunately, we don't know which version of gcc clang
41 * pretends to be, so the macro may or may not be defined. 31 * pretends to be, so the macro may or may not be defined.
42 */ 32 */
43#undef COMPILER_HAS_GENERIC_BUILTIN_OVERFLOW
44#if __has_builtin(__builtin_mul_overflow) && \ 33#if __has_builtin(__builtin_mul_overflow) && \
45 __has_builtin(__builtin_add_overflow) && \ 34 __has_builtin(__builtin_add_overflow) && \
46 __has_builtin(__builtin_sub_overflow) 35 __has_builtin(__builtin_sub_overflow)
47#define COMPILER_HAS_GENERIC_BUILTIN_OVERFLOW 1 36#define COMPILER_HAS_GENERIC_BUILTIN_OVERFLOW 1
48#endif 37#endif
38
39/* The following are for compatibility with GCC, from compiler-gcc.h,
40 * and may be redefined here because they should not be shared with other
41 * compilers, like ICC.
42 */
43#define barrier() __asm__ __volatile__("" : : : "memory")
44#define __must_be_array(a) BUILD_BUG_ON_ZERO(__same_type((a), &(a)[0]))
45#define __assume_aligned(a, ...) \
46 __attribute__((__assume_aligned__(a, ## __VA_ARGS__)))