您的位置:首页 > 编程语言 > C语言/C++

C语言,如何打印出程序中出错的位置

2017-06-21 10:17 357 查看
参考ESP32

传入函数X,如果X返回值出错,将打印出对应出错的函数所在的文件,行号和对应出错的函数名

#define ESP_ERROR_CHECK(x) do { \

esp_err_t rc = (x); \

if (rc != ESP_OK) { \

_esp_error_check_failed(rc, __FILE__, __LINE__, \

__ASSERT_FUNC, #x); \

} \

} while(0);

#endif

进行对应的错误处理,中断对应的程序执行

void _esp_error_check_failed(esp_err_t rc, const char *file, int line, const char *function, const char *expression)

{

printf("ESP_ERROR_CHECK failed: esp_err_t 0x%x at %p\n", rc, __builtin_return_address(0));

printf("file: \"%s\" line %d\nfunc: %s\nexpression: %s\n", file, line, function, expression);

abort();

}

//函数执行进入死循环,指向0地址

static __attribute__((noreturn)) inline void invoke_abort()

{

abort_called = true;

#if CONFIG_ESP32_APPTRACE_ENABLE

esp_apptrace_flush_nolock(ESP_APPTRACE_DEST_TRAX, ESP_APPTRACE_TRAX_BLOCK_SIZE*CONFIG_ESP32_APPTRACE_ONPANIC_HOST_FLUSH_TRAX_THRESH/100, CONFIG_ESP32_APPTRACE_ONPANIC_HOST_FLUSH_TMO);

#endif

while(1) {

if (esp_cpu_in_ocd_debug_mode()) {

__asm__ ("break 0,0");

}

*((int*) 0) = 0;

}

}

//中断程序执行

void abort()

{

#if !CONFIG_ESP32_PANIC_SILENT_REBOOT

ets_printf("abort() was called at PC 0x%08x on core %d\r\n", (intptr_t)__builtin_return_address(0) - 3, xPortGetCoreID());

#endif

invoke_abort();

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  c语言