Commit 733ed6e4 authored by Daniel Santos's avatar Daniel Santos Committed by Linus Torvalds

compiler-gcc{3,4}.h: Use GCC_VERSION macro

Using GCC_VERSION reduces complexity, is easier to read and is GCC's
recommended mechanism for doing version checks.  (Just don't ask me why
they didn't define it in the first place.) This also makes it easy to
merge compiler-gcc{,3,4}.h should somebody want to.
Signed-off-by: default avatarDaniel Santos <daniel.santos@pobox.com>
Acked-by: default avatarDavid Rientjes <rientjes@google.com>
Acked-by: default avatarBorislav Petkov <bp@alien8.de>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Joe Perches <joe@perches.com>
Cc: Josh Triplett <josh@joshtriplett.org>
Cc: Paul Gortmaker <paul.gortmaker@windriver.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 3f3f8d2f
...@@ -2,22 +2,22 @@ ...@@ -2,22 +2,22 @@
#error "Please don't include <linux/compiler-gcc3.h> directly, include <linux/compiler.h> instead." #error "Please don't include <linux/compiler-gcc3.h> directly, include <linux/compiler.h> instead."
#endif #endif
#if __GNUC_MINOR__ < 2 #if GCC_VERSION < 30200
# error Sorry, your compiler is too old - please upgrade it. # error Sorry, your compiler is too old - please upgrade it.
#endif #endif
#if __GNUC_MINOR__ >= 3 #if GCC_VERSION >= 30300
# define __used __attribute__((__used__)) # define __used __attribute__((__used__))
#else #else
# define __used __attribute__((__unused__)) # define __used __attribute__((__unused__))
#endif #endif
#if __GNUC_MINOR__ >= 4 #if GCC_VERSION >= 30400
#define __must_check __attribute__((warn_unused_result)) #define __must_check __attribute__((warn_unused_result))
#endif #endif
#ifdef CONFIG_GCOV_KERNEL #ifdef CONFIG_GCOV_KERNEL
# if __GNUC_MINOR__ < 4 # if GCC_VERSION < 30400
# error "GCOV profiling support for gcc versions below 3.4 not included" # error "GCOV profiling support for gcc versions below 3.4 not included"
# endif /* __GNUC_MINOR__ */ # endif /* __GNUC_MINOR__ */
#endif /* CONFIG_GCOV_KERNEL */ #endif /* CONFIG_GCOV_KERNEL */
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
/* GCC 4.1.[01] miscompiles __weak */ /* GCC 4.1.[01] miscompiles __weak */
#ifdef __KERNEL__ #ifdef __KERNEL__
# if __GNUC_MINOR__ == 1 && __GNUC_PATCHLEVEL__ <= 1 # if GCC_VERSION >= 40100 && GCC_VERSION <= 40101
# error Your version of gcc miscompiles the __weak directive # error Your version of gcc miscompiles the __weak directive
# endif # endif
#endif #endif
...@@ -13,11 +13,11 @@ ...@@ -13,11 +13,11 @@
#define __must_check __attribute__((warn_unused_result)) #define __must_check __attribute__((warn_unused_result))
#define __compiler_offsetof(a,b) __builtin_offsetof(a,b) #define __compiler_offsetof(a,b) __builtin_offsetof(a,b)
#if __GNUC_MINOR__ > 0 #if GCC_VERSION >= 40100
# define __compiletime_object_size(obj) __builtin_object_size(obj, 0) # define __compiletime_object_size(obj) __builtin_object_size(obj, 0)
#endif #endif
#if __GNUC_MINOR__ >= 3 #if GCC_VERSION >= 40300
/* Mark functions as cold. gcc will assume any path leading to a call /* Mark functions as cold. gcc will assume any path leading to a call
to them will be unlikely. This means a lot of manual unlikely()s to them will be unlikely. This means a lot of manual unlikely()s
are unnecessary now for any paths leading to the usual suspects are unnecessary now for any paths leading to the usual suspects
...@@ -41,9 +41,9 @@ ...@@ -41,9 +41,9 @@
# define __compiletime_warning(message) __attribute__((warning(message))) # define __compiletime_warning(message) __attribute__((warning(message)))
# define __compiletime_error(message) __attribute__((error(message))) # define __compiletime_error(message) __attribute__((error(message)))
#endif /* __CHECKER__ */ #endif /* __CHECKER__ */
#endif /* __GNUC_MINOR__ >= 3 */ #endif /* GCC_VERSION >= 40300 */
#if __GNUC_MINOR__ >= 5 #if GCC_VERSION >= 40500
/* /*
* Mark a position in code as unreachable. This can be used to * Mark a position in code as unreachable. This can be used to
* suppress control flow warnings after asm blocks that transfer * suppress control flow warnings after asm blocks that transfer
...@@ -58,9 +58,9 @@ ...@@ -58,9 +58,9 @@
/* Mark a function definition as prohibited from being cloned. */ /* Mark a function definition as prohibited from being cloned. */
#define __noclone __attribute__((__noclone__)) #define __noclone __attribute__((__noclone__))
#endif /* __GNUC_MINOR__ >= 5 */ #endif /* GCC_VERSION >= 40500 */
#if __GNUC_MINOR__ >= 6 #if GCC_VERSION >= 40600
/* /*
* Tell the optimizer that something else uses this function or variable. * Tell the optimizer that something else uses this function or variable.
*/ */
...@@ -69,11 +69,11 @@ ...@@ -69,11 +69,11 @@
#ifdef CONFIG_ARCH_USE_BUILTIN_BSWAP #ifdef CONFIG_ARCH_USE_BUILTIN_BSWAP
#if __GNUC_MINOR__ >= 4 #if GCC_VERSION >= 40400
#define __HAVE_BUILTIN_BSWAP32__ #define __HAVE_BUILTIN_BSWAP32__
#define __HAVE_BUILTIN_BSWAP64__ #define __HAVE_BUILTIN_BSWAP64__
#endif #endif
#if __GNUC_MINOR__ >= 8 || (defined(__powerpc__) && __GNUC_MINOR__ >= 6) #if GCC_VERSION >= 40800 || (defined(__powerpc__) && GCC_VERSION >= 40600)
#define __HAVE_BUILTIN_BSWAP16__ #define __HAVE_BUILTIN_BSWAP16__
#endif #endif
#endif #endif /* CONFIG_ARCH_USE_BUILTIN_BSWAP */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment