diff options
author | Nick Desaulniers <ndesaulniers@google.com> | 2018-08-22 19:37:24 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2018-08-22 20:31:34 -0400 |
commit | 815f0ddb346c196018d4d8f8f55c12b83da1de3f (patch) | |
tree | 4805bf7e3cb7ec4e727aba8e62f9211e9001a760 /include/linux/compiler-clang.h | |
parent | 899fbc33fd775b9dfa363db28f322272920a2196 (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.h | 20 |
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__))) | ||