X-Git-Url: https://git.tcpdump.org/tcpdump/blobdiff_plain/c724af922246b23fe55947b4033abcc853b4dd47..c39d40a767a1ae36171e5bcbf6f157ff3e80fb6c:/funcattrs.h?ds=sidebyside diff --git a/funcattrs.h b/funcattrs.h index cb0678ea..dfe36629 100644 --- a/funcattrs.h +++ b/funcattrs.h @@ -35,6 +35,8 @@ #ifndef lib_funcattrs_h #define lib_funcattrs_h +#include "compiler-tests.h" + /* * Attributes to apply to functions and their arguments, using various * compiler-specific extensions. @@ -43,7 +45,7 @@ /* * This was introduced by Clang: * - * http://clang.llvm.org/docs/LanguageExtensions.html#has-attribute + * https://clang.llvm.org/docs/LanguageExtensions.html#has-attribute * * in some version (which version?); it has been picked up by GCC 5.0. */ @@ -65,10 +67,10 @@ * declaration, as the MSVC version has to go before the declaration.) */ #if __has_attribute(noreturn) \ - || (defined(__GNUC__) && ((__GNUC__ * 100 + __GNUC_MINOR__) >= 205)) \ - || (defined(__SUNPRO_C) && (__SUNPRO_C >= 0x590)) \ - || (defined(__xlC__) && __xlC__ >= 0x0A01) \ - || (defined(__HP_aCC) && __HP_aCC >= 61000) + || ND_IS_AT_LEAST_GNUC_VERSION(2,5) \ + || ND_IS_AT_LEAST_SUNC_VERSION(5,9) \ + || ND_IS_AT_LEAST_XL_C_VERSION(10,1) \ + || ND_IS_AT_LEAST_HP_C_VERSION(6,10) /* * Compiler with support for __attribute((noreturn)), or GCC 2.5 and * later, or Solaris Studio 12 (Sun C 5.9) and later, or IBM XL C 10.1 @@ -109,9 +111,9 @@ * string". */ #if __has_attribute(__format__) \ - || (defined(__GNUC__) && ((__GNUC__ * 100 + __GNUC_MINOR__) >= 203)) \ - || (defined(__xlC__) && __xlC__ >= 0x0A01) \ - || (defined(__HP_aCC) && __HP_aCC >= 61000) + || ND_IS_AT_LEAST_GNUC_VERSION(2,3) \ + || ND_IS_AT_LEAST_XL_C_VERSION(10,1) \ + || ND_IS_AT_LEAST_HP_C_VERSION(6,10) /* * Compiler with support for it, or GCC 2.3 and later, or IBM XL C 10.1 * and later (do any earlier versions of XL C support this?), @@ -122,27 +124,38 @@ /* * However, GCC didn't support that for function *pointers* until GCC * 4.1.0; see https://gcc.gnu.org/bugzilla/show_bug.cgi?id=3481. + * XL C 16.1 (and possibly some earlier versions, but not 12.1 or 13.1) has + * a similar bug, the bugfix for which was made in: + * * version 16.1.1.8 for Linux (25 June 2020), which fixes + * https://www.ibm.com/support/pages/apar/LI81402 + * * version 16.1.0.5 for AIX (5 May 2020), which fixes + * https://www.ibm.com/support/pages/apar/IJ24678 + * + * When testing versions, keep in mind that XL C 16.1 pretends to be both + * GCC 4.2 and Clang 4.0 at once. */ - #if (defined(__GNUC__) && ((__GNUC__ * 100 + __GNUC_MINOR__) < 401)) - #define PRINTFLIKE_FUNCPTR(x,y) - #else + #if (ND_IS_AT_LEAST_GNUC_VERSION(4,1) \ + && !ND_IS_AT_LEAST_XL_C_VERSION(10,1)) \ + || (ND_IS_AT_LEAST_XL_C_VERSION(16,1) \ + && (ND_IS_AT_LEAST_XL_C_MODFIX(1, 8) && defined(__linux__)) \ + || (ND_IS_AT_LEAST_XL_C_MODFIX(0, 5) && defined(_AIX))) #define PRINTFLIKE_FUNCPTR(x,y) __attribute__((__format__(__printf__,x,y))) #endif -#else - #define PRINTFLIKE(x,y) - #define PRINTFLIKE_FUNCPTR(x,y) +#endif + +#if !defined(PRINTFLIKE) +#define PRINTFLIKE(x,y) +#endif +#if !defined(PRINTFLIKE_FUNCPTR) +#define PRINTFLIKE_FUNCPTR(x,y) #endif /* * For flagging arguments as format strings in MSVC. */ -#if _MSC_VER >= 1400 +#ifdef _MSC_VER #include - #if _MSC_VER > 1400 - #define FORMAT_STRING(p) _Printf_format_string_ p - #else - #define FORMAT_STRING(p) __format_string p - #endif + #define FORMAT_STRING(p) _Printf_format_string_ p #else #define FORMAT_STRING(p) p #endif