compiler-gcc4.h 3.02 KB
Newer Older
1
2
3
#ifndef __LINUX_COMPILER_H
#error "Please don't include <linux/compiler-gcc4.h> directly, include <linux/compiler.h> instead."
#endif
Linus Torvalds's avatar
Linus Torvalds committed
4

5
/* GCC 4.1.[01] miscompiles __weak */
6
#ifdef __KERNEL__
7
# if GCC_VERSION >= 40100 &&  GCC_VERSION <= 40101
8
9
#  error Your version of gcc miscompiles the __weak directive
# endif
10
11
#endif

12
#define __used			__attribute__((__used__))
Linus Torvalds's avatar
Linus Torvalds committed
13
14
#define __must_check 		__attribute__((warn_unused_result))
#define __compiler_offsetof(a,b) __builtin_offsetof(a,b)
15

16
#if GCC_VERSION >= 40100 && GCC_VERSION < 40600
17
18
19
# define __compiletime_object_size(obj) __builtin_object_size(obj, 0)
#endif

20
#if GCC_VERSION >= 40300
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
/* 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
   are unnecessary now for any paths leading to the usual suspects
   like BUG(), printk(), panic() etc. [but let's keep them for now for
   older compilers]

   Early snapshots of gcc 4.3 don't support this and we can't detect this
   in the preprocessor, but we can live with this because they're unreleased.
   Maketime probing would be overkill here.

   gcc also has a __attribute__((__hot__)) to move hot functions into
   a special section, but I don't see any sense in this right now in
   the kernel context */
#define __cold			__attribute__((__cold__))

Rusty Russell's avatar
Rusty Russell committed
36
37
#define __UNIQUE_ID(prefix) __PASTE(__PASTE(__UNIQUE_ID_, prefix), __COUNTER__)

38
39
40
41
#ifndef __CHECKER__
# define __compiletime_warning(message) __attribute__((warning(message)))
# define __compiletime_error(message) __attribute__((error(message)))
#endif /* __CHECKER__ */
42
#endif /* GCC_VERSION >= 40300 */
43

44
#if GCC_VERSION >= 40500
45
46
47
48
49
50
51
52
53
54
/*
 * Mark a position in code as unreachable.  This can be used to
 * suppress control flow warnings after asm blocks that transfer
 * control elsewhere.
 *
 * Early snapshots of gcc 4.5 don't support this and we can't detect
 * this in the preprocessor, but we can live with this because they're
 * unreleased.  Really, we need to have autoconf for the kernel.
 */
#define unreachable() __builtin_unreachable()
55
56
57
58

/* Mark a function definition as prohibited from being cloned. */
#define __noclone	__attribute__((__noclone__))

59
#endif /* GCC_VERSION >= 40500 */
60

61
#if GCC_VERSION >= 40600
Andi Kleen's avatar
Andi Kleen committed
62
63
64
65
66
67
/*
 * Tell the optimizer that something else uses this function or variable.
 */
#define __visible __attribute__((externally_visible))
#endif

68
69
70
71
72
73
74
75
76
/*
 * GCC 'asm goto' miscompiles certain code sequences:
 *
 *   http://gcc.gnu.org/bugzilla/show_bug.cgi?id=58670
 *
 * Work it around via a compiler barrier quirk suggested by Jakub Jelinek.
 *
 * (asm goto is automatically volatile - the naming reflects this.)
 */
77
#define asm_volatile_goto(x...)	do { asm goto(x); asm (""); } while (0)
78
79

#ifdef CONFIG_ARCH_USE_BUILTIN_BSWAP
80
#if GCC_VERSION >= 40400
81
82
83
#define __HAVE_BUILTIN_BSWAP32__
#define __HAVE_BUILTIN_BSWAP64__
#endif
84
#if GCC_VERSION >= 40800 || (defined(__powerpc__) && GCC_VERSION >= 40600)
85
86
#define __HAVE_BUILTIN_BSWAP16__
#endif
87
#endif /* CONFIG_ARCH_USE_BUILTIN_BSWAP */
88
89
90
91

#if GCC_VERSION >= 40902
#define KASAN_ABI_VERSION 3
#endif