/* call abort(), it will generate a coredump if enabled */ void __rte_panic(const char *funcname, const char *format, ...) { va_list ap; rte_log(RTE_LOG_CRIT, RTE_LOGTYPE_EAL, "PANIC in %s():\n", funcname); va_start(ap, format); rte_vlog(RTE_LOG_CRIT, RTE_LOGTYPE_EAL, format, ap); va_end(ap); rte_dump_stack(); rte_dump_registers(); abort(); }
int test_debug(void) { rte_dump_stack(); rte_dump_registers(); if (test_panic() < 0) return -1; if (test_exit() < 0) return -1; if (test_usage() < 0) return -1; return 0; }
/* * Like rte_panic this terminates the application. However, no traceback is * provided and no core-dump is generated. */ void rte_exit(int exit_code, const char *format, ...) { va_list ap; if (exit_code != 0) RTE_LOG(CRIT, EAL, "Error - exiting with code: %d\n" " Cause: ", exit_code); va_start(ap, format); rte_vlog(RTE_LOG_CRIT, RTE_LOGTYPE_EAL, format, ap); va_end(ap); #ifndef RTE_EAL_ALWAYS_PANIC_ON_ERROR exit(exit_code); #else rte_dump_stack(); rte_dump_registers(); abort(); #endif }