libopencm3
A free/libre/open-source firmware library for various ARM Cortex-M3 microcontrollers.
|
Macros and functions to aid in debugging. More...
Macros | |
#define | CM3_LIKELY(expr) (__builtin_expect(!!(expr), 1)) |
#define | cm3_assert(expr) |
Check if assertion is true. More... | |
#define | cm3_assert_not_reached() cm3_assert_failed() |
Check if unreachable code is reached. More... | |
Functions | |
void | cm3_assert_failed (void) |
Called on a failed assertion. More... | |
void | cm3_assert_failed_verbose (const char *file, int line, const char *func, const char *assert_expr) |
Called on a failed assertion with verbose messages enabled. More... | |
Macros and functions to aid in debugging.
Two preprocessor defines control the behavior of assertion check macros in this module. They allow the choice between generated code size and ease of debugging.
If NDEBUG is defined, all assertion checks are disabled and macros do not generate any code.
If CM3_ASSERT_VERBOSE is defined, information regarding the position of assertion checks will be stored in the binary, allowing for more informative error messages, but also significantly increased code size. As default assertion checks do not use this information it is only useful if the application linked with libopencm3 defines its own cm3_assert_failed_verbose() implementation.
LGPL License Terms libopencm3 License
#define cm3_assert | ( | expr | ) |
Check if assertion is true.
If NDEBUG macro is defined, this macro generates no code. Otherwise cm3_assert_failed() or cm3_assert_failed_verbose() is called if assertion is false.
The purpose of this macro is to aid in debugging libopencm3 and applications using it. It can be used for example to check if function arguments are within expected ranges and stop execution in case an unexpected state is reached.
expr | expression to check |
#define cm3_assert_not_reached | ( | ) | cm3_assert_failed() |
Check if unreachable code is reached.
If NDEBUG macro is defined, this macro generates code for an infinite loop. Otherwise cm3_assert_failed() or cm3_assert_failed_verbose() is called if the macro is ever reached.
The purpose of this macro is to aid in debugging libopencm3 and applications using it. It can be used for example to stop execution if an unreachable portion of code is reached.
void cm3_assert_failed | ( | void | ) |
Called on a failed assertion.
Halts execution in an infinite loop. This function never returns.
Defined as a weak symbol, so applications can define their own implementation. Usually, a custom implementation of this function should report an error in some way (print a message to a debug console, display, LED, ...) and halt execution or reboot the device.
void cm3_assert_failed_verbose | ( | const char * | file, |
int | line, | ||
const char * | func, | ||
const char * | assert_expr | ||
) |
Called on a failed assertion with verbose messages enabled.
Halts execution in an infinite loop. This function never returns.
Defined as a weak symbol, so applications can define their own implementation. Usually, a custom implementation of this function should report an error in some way (print a message to a debug console, display, LED, ...) and halt execution or reboot the device.
file | File name where the failed assertion occurred |
line | Line number where the failed assertion occurred |
func | Name of the function where the failed assertion occurred |
assert_expr | Expression that evaluated to false (can be NULL) |