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();
}
传入函数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();
}
相关文章推荐
- printStackTrace()方法的意思是:在命令行打印异常信息在程序中出错的位置及原因
- shell 调试技术,伪信号打印程序出错位置
- 【调试中非常重要的技巧】如何从错误堆栈的输出判断程序出错的准确位置?
- C语言中变量的位置与程序优化
- C语言实现的linux中打印程序
- 如何在android系统上运行C语言的程序
- 如何控制Linux终端打印字符颜色和位置
- 在Java程序,如何实现自适应位置的快捷菜单
- exe程序运行出错退出,使用windbg查找出错位置
- 打印月历的程序(C语言)
- **如何让程序运行更快时间更短C语言代码(程序员必看)
- C语言中程序以及各类型数据存储位置 (转载)
- 如何将多个C语言模块组合成一个程序
- 在Java程序,如何实现自适应位置的快捷菜单
- 用C语言,如何写十进制转换十六进制的程序,要注意十六进制有ABCDEF。
- socket应用(一)如何利用C语言写文件传输的程序
- 用C语言写打印自己的程序
- 技术QA:如何更改用户配置文件和程序设置的默认位置?
- 如何在程序打开时窗口恢复上次关闭的大小和位置?
- Winform窗体程序如何从上次关闭时的位置重新打开新窗体