1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-17 05:32:45 +01:00

core/assert: print backtrace on failed assertion

This commit is contained in:
Benjamin Valentin 2022-10-13 17:42:49 +02:00
parent fa96d469da
commit 6b34691abe
2 changed files with 13 additions and 0 deletions

View File

@ -19,16 +19,26 @@
#include "architecture.h" #include "architecture.h"
#include "cpu.h" #include "cpu.h"
#include "panic.h" #include "panic.h"
#if IS_USED(MODULE_BACKTRACE)
#include "backtrace.h"
#endif
__NORETURN void _assert_failure(const char *file, unsigned line) __NORETURN void _assert_failure(const char *file, unsigned line)
{ {
printf("%s:%u => ", file, line); printf("%s:%u => ", file, line);
#if IS_USED(MODULE_BACKTRACE)
printf("failed assertion. Backtrace:\n");
backtrace_print();
#endif
core_panic(PANIC_ASSERT_FAIL, "FAILED ASSERTION."); core_panic(PANIC_ASSERT_FAIL, "FAILED ASSERTION.");
} }
__NORETURN void _assert_panic(void) __NORETURN void _assert_panic(void)
{ {
printf("%" PRIxTXTPTR "\n", cpu_get_caller_pc()); printf("%" PRIxTXTPTR "\n", cpu_get_caller_pc());
#if IS_USED(MODULE_BACKTRACE)
backtrace_print();
#endif
core_panic(PANIC_ASSERT_FAIL, "FAILED ASSERTION."); core_panic(PANIC_ASSERT_FAIL, "FAILED ASSERTION.");
} }

View File

@ -108,6 +108,9 @@ __NORETURN void _assert_failure(const char *file, unsigned line);
* or `gdb` (with the command `info line *(0x89abcdef)`) to identify the line * or `gdb` (with the command `info line *(0x89abcdef)`) to identify the line
* the assertion failed in. * the assertion failed in.
* *
* If the `backtrace` module is enabled (and implemented for architecture in use)
* a backtrace will be printed in addition to the location of the failed assertion.
*
* @see http://pubs.opengroup.org/onlinepubs/9699919799/functions/assert.html * @see http://pubs.opengroup.org/onlinepubs/9699919799/functions/assert.html
*/ */
#define assert(cond) ((cond) ? (void)0 : _assert_failure(RIOT_FILE_RELATIVE, \ #define assert(cond) ((cond) ? (void)0 : _assert_failure(RIOT_FILE_RELATIVE, \