They're stricter. The GNU attributes are too lazy, and can be misused more easily. Also, mixing both has its own problems. Link: <https://gcc.gnu.org/bugzilla/show_bug.cgi?id=108796> Signed-off-by: Alejandro Colomar <alx@kernel.org>
36 lines
904 B
C
36 lines
904 B
C
#ifndef SHADOW_INCLUDE_LIB_ATTR_H_
|
|
#define SHADOW_INCLUDE_LIB_ATTR_H_
|
|
|
|
|
|
#include "config.h"
|
|
|
|
|
|
#if defined(__GNUC__)
|
|
# define MAYBE_UNUSED [[gnu::unused]]
|
|
# define NORETURN [[gnu::__noreturn__]]
|
|
# define format_attr(type, fmt, va) [[gnu::format(type, fmt, va)]]
|
|
# define ATTR_ACCESS(...) [[gnu::access(__VA_ARGS__)]]
|
|
# define ATTR_ALLOC_SIZE(...) [[gnu::alloc_size(__VA_ARGS__)]]
|
|
#else
|
|
# define MAYBE_UNUSED
|
|
# define NORETURN
|
|
# define format_attr(type, fmt, va)
|
|
# define ATTR_ACCESS(...)
|
|
# define ATTR_ALLOC_SIZE(...)
|
|
#endif
|
|
|
|
#if (__GNUC__ >= 11) && !defined(__clang__)
|
|
# define ATTR_MALLOC(deallocator) [[gnu::malloc(deallocator)]]
|
|
#else
|
|
# define ATTR_MALLOC(deallocator)
|
|
#endif
|
|
|
|
#if (__GNUC__ >= 14)
|
|
# define ATTR_STRING(...) [[gnu::null_terminated_string_arg(__VA_ARGS__)]]
|
|
#else
|
|
# define ATTR_STRING(...)
|
|
#endif
|
|
|
|
|
|
#endif // include guard
|