compiler_attributes.h 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. #ifndef __LINUX_COMPILER_ATTRIBUTES_H
  3. #define __LINUX_COMPILER_ATTRIBUTES_H
  4. /*
  5. * The attributes in this file are unconditionally defined and they directly
  6. * map to compiler attribute(s), unless one of the compilers does not support
  7. * the attribute. In that case, __has_attribute is used to check for support
  8. * and the reason is stated in its comment ("Optional: ...").
  9. *
  10. * Any other "attributes" (i.e. those that depend on a configuration option,
  11. * on a compiler, on an architecture, on plugins, on other attributes...)
  12. * should be defined elsewhere (e.g. compiler_types.h or compiler-*.h).
  13. * The intention is to keep this file as simple as possible, as well as
  14. * compiler- and version-agnostic (e.g. avoiding GCC_VERSION checks).
  15. *
  16. * This file is meant to be sorted (by actual attribute name,
  17. * not by #define identifier). Use the __attribute__((__name__)) syntax
  18. * (i.e. with underscores) to avoid future collisions with other macros.
  19. * Provide links to the documentation of each supported compiler, if it exists.
  20. */
  21. /*
  22. * __has_attribute is supported on gcc >= 5, clang >= 2.9 and icc >= 17.
  23. * In the meantime, to support 4.6 <= gcc < 5, we implement __has_attribute
  24. * by hand.
  25. *
  26. * sparse does not support __has_attribute (yet) and defines __GNUC_MINOR__
  27. * depending on the compiler used to build it; however, these attributes have
  28. * no semantic effects for sparse, so it does not matter. Also note that,
  29. * in order to avoid sparse's warnings, even the unsupported ones must be
  30. * defined to 0.
  31. */
  32. #ifndef __has_attribute
  33. # define __has_attribute(x) __GCC4_has_attribute_##x
  34. # define __GCC4_has_attribute___assume_aligned__ (__GNUC_MINOR__ >= 9)
  35. # define __GCC4_has_attribute___designated_init__ 0
  36. # define __GCC4_has_attribute___externally_visible__ 1
  37. # define __GCC4_has_attribute___noclone__ 1
  38. # define __GCC4_has_attribute___optimize__ 1
  39. # define __GCC4_has_attribute___nonstring__ 0
  40. # define __GCC4_has_attribute___no_sanitize_address__ (__GNUC_MINOR__ >= 8)
  41. #endif
  42. /*
  43. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attributes.html#index-alias-function-attribute
  44. */
  45. #define __alias(symbol) __attribute__((__alias__(#symbol)))
  46. /*
  47. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attributes.html#index-aligned-function-attribute
  48. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Type-Attributes.html#index-aligned-type-attribute
  49. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Variable-Attributes.html#index-aligned-variable-attribute
  50. */
  51. #define __aligned(x) __attribute__((__aligned__(x)))
  52. #define __aligned_largest __attribute__((__aligned__))
  53. /*
  54. * Note: users of __always_inline currently do not write "inline" themselves,
  55. * which seems to be required by gcc to apply the attribute according
  56. * to its docs (and also "warning: always_inline function might not be
  57. * inlinable [-Wattributes]" is emitted).
  58. *
  59. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attributes.html#index-always_005finline-function-attribute
  60. * clang: mentioned
  61. */
  62. #define __always_inline inline __attribute__((__always_inline__))
  63. /*
  64. * The second argument is optional (default 0), so we use a variadic macro
  65. * to make the shorthand.
  66. *
  67. * Beware: Do not apply this to functions which may return
  68. * ERR_PTRs. Also, it is probably unwise to apply it to functions
  69. * returning extra information in the low bits (but in that case the
  70. * compiler should see some alignment anyway, when the return value is
  71. * massaged by 'flags = ptr & 3; ptr &= ~3;').
  72. *
  73. * Optional: only supported since gcc >= 4.9
  74. * Optional: not supported by icc
  75. *
  76. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attributes.html#index-assume_005faligned-function-attribute
  77. * clang: https://clang.llvm.org/docs/AttributeReference.html#assume-aligned
  78. */
  79. #if __has_attribute(__assume_aligned__)
  80. # define __assume_aligned(a, ...) __attribute__((__assume_aligned__(a, ## __VA_ARGS__)))
  81. #else
  82. # define __assume_aligned(a, ...)
  83. #endif
  84. /*
  85. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attributes.html#index-cold-function-attribute
  86. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Label-Attributes.html#index-cold-label-attribute
  87. */
  88. #define __cold __attribute__((__cold__))
  89. /*
  90. * Note the long name.
  91. *
  92. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attributes.html#index-const-function-attribute
  93. */
  94. #define __attribute_const__ __attribute__((__const__))
  95. /*
  96. * Don't. Just don't. See commit 771c035372a0 ("deprecate the '__deprecated'
  97. * attribute warnings entirely and for good") for more information.
  98. *
  99. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attributes.html#index-deprecated-function-attribute
  100. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Type-Attributes.html#index-deprecated-type-attribute
  101. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Variable-Attributes.html#index-deprecated-variable-attribute
  102. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Enumerator-Attributes.html#index-deprecated-enumerator-attribute
  103. * clang: https://clang.llvm.org/docs/AttributeReference.html#deprecated
  104. */
  105. #define __deprecated
  106. /*
  107. * Optional: only supported since gcc >= 5.1
  108. * Optional: not supported by clang
  109. * Optional: not supported by icc
  110. *
  111. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Type-Attributes.html#index-designated_005finit-type-attribute
  112. */
  113. #if __has_attribute(__designated_init__)
  114. # define __designated_init __attribute__((__designated_init__))
  115. #else
  116. # define __designated_init
  117. #endif
  118. /*
  119. * Optional: not supported by clang
  120. *
  121. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attributes.html#index-externally_005fvisible-function-attribute
  122. */
  123. #if __has_attribute(__externally_visible__)
  124. # define __visible __attribute__((__externally_visible__))
  125. #else
  126. # define __visible
  127. #endif
  128. /*
  129. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attributes.html#index-format-function-attribute
  130. * clang: https://clang.llvm.org/docs/AttributeReference.html#format
  131. */
  132. #define __printf(a, b) __attribute__((__format__(printf, a, b)))
  133. #define __scanf(a, b) __attribute__((__format__(scanf, a, b)))
  134. /*
  135. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attributes.html#index-gnu_005finline-function-attribute
  136. * clang: https://clang.llvm.org/docs/AttributeReference.html#gnu-inline
  137. */
  138. #define __gnu_inline __attribute__((__gnu_inline__))
  139. /*
  140. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attributes.html#index-malloc-function-attribute
  141. */
  142. #define __malloc __attribute__((__malloc__))
  143. /*
  144. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Type-Attributes.html#index-mode-type-attribute
  145. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Variable-Attributes.html#index-mode-variable-attribute
  146. */
  147. #define __mode(x) __attribute__((__mode__(x)))
  148. /*
  149. * Optional: not supported by clang
  150. * Note: icc does not recognize gcc's no-tracer
  151. *
  152. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attributes.html#index-noclone-function-attribute
  153. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attributes.html#index-optimize-function-attribute
  154. */
  155. #if __has_attribute(__noclone__)
  156. # if __has_attribute(__optimize__)
  157. # define __noclone __attribute__((__noclone__, __optimize__("no-tracer")))
  158. # else
  159. # define __noclone __attribute__((__noclone__))
  160. # endif
  161. #else
  162. # define __noclone
  163. #endif
  164. /*
  165. * Note the missing underscores.
  166. *
  167. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attributes.html#index-noinline-function-attribute
  168. * clang: mentioned
  169. */
  170. #define noinline __attribute__((__noinline__))
  171. /*
  172. * Optional: only supported since gcc >= 8
  173. * Optional: not supported by clang
  174. * Optional: not supported by icc
  175. *
  176. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Variable-Attributes.html#index-nonstring-variable-attribute
  177. */
  178. #if __has_attribute(__nonstring__)
  179. # define __nonstring __attribute__((__nonstring__))
  180. #else
  181. # define __nonstring
  182. #endif
  183. /*
  184. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attributes.html#index-noreturn-function-attribute
  185. * clang: https://clang.llvm.org/docs/AttributeReference.html#noreturn
  186. * clang: https://clang.llvm.org/docs/AttributeReference.html#id1
  187. */
  188. #define __noreturn __attribute__((__noreturn__))
  189. /*
  190. * Optional: only supported since gcc >= 4.8
  191. * Optional: not supported by icc
  192. *
  193. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attributes.html#index-no_005fsanitize_005faddress-function-attribute
  194. * clang: https://clang.llvm.org/docs/AttributeReference.html#no-sanitize-address-no-address-safety-analysis
  195. */
  196. #if __has_attribute(__no_sanitize_address__)
  197. # define __no_sanitize_address __attribute__((__no_sanitize_address__))
  198. #else
  199. # define __no_sanitize_address
  200. #endif
  201. /*
  202. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Type-Attributes.html#index-packed-type-attribute
  203. * clang: https://gcc.gnu.org/onlinedocs/gcc/Common-Variable-Attributes.html#index-packed-variable-attribute
  204. */
  205. #define __packed __attribute__((__packed__))
  206. /*
  207. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attributes.html#index-pure-function-attribute
  208. */
  209. #define __pure __attribute__((__pure__))
  210. /*
  211. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attributes.html#index-section-function-attribute
  212. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Variable-Attributes.html#index-section-variable-attribute
  213. * clang: https://clang.llvm.org/docs/AttributeReference.html#section-declspec-allocate
  214. */
  215. #define __section(S) __attribute__((__section__(#S)))
  216. /*
  217. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attributes.html#index-unused-function-attribute
  218. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Type-Attributes.html#index-unused-type-attribute
  219. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Variable-Attributes.html#index-unused-variable-attribute
  220. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Label-Attributes.html#index-unused-label-attribute
  221. * clang: https://clang.llvm.org/docs/AttributeReference.html#maybe-unused-unused
  222. */
  223. #define __always_unused __attribute__((__unused__))
  224. #define __maybe_unused __attribute__((__unused__))
  225. /*
  226. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attributes.html#index-used-function-attribute
  227. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Variable-Attributes.html#index-used-variable-attribute
  228. */
  229. #define __used __attribute__((__used__))
  230. /*
  231. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Function-Attributes.html#index-weak-function-attribute
  232. * gcc: https://gcc.gnu.org/onlinedocs/gcc/Common-Variable-Attributes.html#index-weak-variable-attribute
  233. */
  234. #define __weak __attribute__((__weak__))
  235. #endif /* __LINUX_COMPILER_ATTRIBUTES_H */