X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=compiler.h;h=933a3f19977a99cdcce29b65739aaa3e9bdd01e6;hb=3c11bc1916410f8325135265b1c2e8e3c21436b8;hp=af9ae624b45acf002852ae393389585577152f57;hpb=fd3f7490acdd11c16df7530089ca18785fd63915;p=bertos.git diff --git a/compiler.h b/compiler.h index af9ae624..933a3f19 100755 --- a/compiler.h +++ b/compiler.h @@ -14,6 +14,18 @@ /*#* *#* $Log$ + *#* Revision 1.29 2004/11/16 20:34:40 bernie + *#* UNUSED_VAR, USED_VAR, USED_FUNC: New macros; UNUSED_ARG: Rename from UNUSED. + *#* + *#* Revision 1.28 2004/10/21 11:03:52 bernie + *#* Typo. + *#* + *#* Revision 1.27 2004/10/21 10:09:40 bernie + *#* Remove spurious token in preprocessor directive. + *#* + *#* Revision 1.26 2004/10/19 08:55:14 bernie + *#* UNUSED_FUNC: New function attribute. + *#* *#* Revision 1.25 2004/10/19 07:14:20 bernie *#* Add macros to test for specific compiler features. *#* @@ -166,17 +178,21 @@ /* Compiler features */ #define COMPILER_VARIADIC_MACROS 1 /* Even in C++ */ #define COMPILER_TYPEOF 1 - #define COMPILER_STAEMENT_EXPRESSIONS 1 + #define COMPILER_STATEMENT_EXPRESSIONS 1 /* GCC attributes */ #define FORMAT(type,fmt,first) __attribute__((__format__(type, fmt, first))) #define NORETURN __attribute__((__noreturn__)) - #define UNUSED(type,arg) __attribute__((__unused__)) type arg + #define UNUSED_ARG(type,arg) __attribute__((__unused__)) type arg + #define UNUSED_VAR(type,name) __attribute__((__unused__)) type name + #define USED_VAR(type,name) __attribute__((__used__)) type name #define INLINE static inline __attribute__((__always_inline__)) #define LIKELY(x) __builtin_expect(!!(x), 1) #define UNLIKELY(x) __builtin_expect(!!(x), 0) #define PURE_FUNC __attribute__((pure)) #define CONST_FUNC __attribute__((const)) + #define UNUSED_FUNC __attribute__((unused)) + #define USED_FUNC __attribute__((__used__)) #define RESTRICT __restrict__ #define MUST_CHECK __attribute__((warn_unused_result)) #if GNUC_PREREQ(3,1) @@ -221,7 +237,7 @@ /* Compiler features */ #define COMPILER_TYPEOF 1 - #define COMPILER_STAEMENT_EXPRESSIONS 1 + #define COMPILER_STATEMENT_EXPRESSIONS 1 #include #include @@ -258,7 +274,7 @@ * \def COMPILER_STATEMENT_EXPRESSIONS * Support for macros with variable arguments. */ -#ifndef COMPILER_STATEMENT_EXPRESSIONS 0 +#ifndef COMPILER_STATEMENT_EXPRESSIONS #define COMPILER_STATEMENT_EXPRESSIONS 0 #endif @@ -275,8 +291,15 @@ #ifndef DEPRECATED #define DEPRECATED /* nothing */ #endif -#ifndef UNUSED -#define UNUSED(type,arg) type arg +#ifndef UNUSED_ARG +#define UNUSED_ARG(type,arg) type arg +#endif +#define UNUSED UNUSED_ARG /* OBSOLETE */ +#ifndef UNUSED_VAR +#define UNUSED_VAR(type,name) type name +#endif +#ifndef USED_VAR +#define USED_VAR(type,name) type name #endif #ifndef REGISTER #define REGISTER /* nothing */ @@ -296,6 +319,12 @@ #ifndef CONST_FUNC #define CONST_FUNC /* nothing */ #endif +#ifndef UNUSED_FUNC +#define UNUSED_FUNC /* nothing */ +#endif +#ifndef USED_FUNC +#define USED_FUNC /* nothing */ +#endif #ifndef RESTRICT #define RESTRICT /* nothing */ #endif @@ -423,6 +452,6 @@ typedef unsigned char page_t; /*!< Type for banked memory pages */ /*! Issue a compilation error if the \a condition is false */ #define STATIC_ASSERT(condition) \ - extern char PP_CAT(CT_ASSERT___, __LINE__)[(condition) ? 1 : -1] + UNUSED_VAR(extern char,PP_CAT(CT_ASSERT___, __LINE__)[(condition) ? 1 : -1]) #endif /* DEVLIB_COMPILER_H */