Commit c17a4dc3 authored by Sandrine Bailleux's avatar Sandrine Bailleux
Browse files

Make CASSERT() macro callable from anywhere

The CASSERT() macro introduces a typedef for the sole purpose of
triggering a compilation error if the condition to check is false.
This typedef is not used afterwards. As a consequence, when the
CASSERT() macro is called from withing a function block, the compiler
complains and outputs the following error message:

  error: typedef 'msg' locally defined but not used [-Werror=unused-local-typedefs]

This patch adds the "unused" attribute for the aforementioned
typedef. This silences the compiler warning and thus makes the
CASSERT() macro callable from within function blocks as well.

Change-Id: Ie36b58fcddae01a21584c48bb6ef43ec85590479
parent a3a34899
...@@ -34,9 +34,12 @@ ...@@ -34,9 +34,12 @@
/******************************************************************************* /*******************************************************************************
* Macro to flag a compile time assertion. It uses the preprocessor to generate * Macro to flag a compile time assertion. It uses the preprocessor to generate
* an invalid C construct if 'cond' evaluates to false. * an invalid C construct if 'cond' evaluates to false.
* The following compilation error is triggered if the assertion fails: * The following compilation error is triggered if the assertion fails:
* "error: size of array 'msg' is negative" * "error: size of array 'msg' is negative"
* The 'unused' attribute ensures that the unused typedef does not emit a
* compiler warning.
******************************************************************************/ ******************************************************************************/
#define CASSERT(cond, msg) typedef char msg[(cond) ? 1 : -1] #define CASSERT(cond, msg) \
typedef char msg[(cond) ? 1 : -1] __attribute__((unused))
#endif /* __CASSERT_H__ */ #endif /* __CASSERT_H__ */
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment