2014-08-29 07:52:33 -07:00
|
|
|
/**
|
|
|
|
* @file error_handling.h
|
|
|
|
*
|
|
|
|
* @date Mar 6, 2014
|
|
|
|
* @author Andrey Belomutskiy, (c) 2012-2014
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef ERROR_HANDLING_H_
|
|
|
|
#define ERROR_HANDLING_H_
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C"
|
|
|
|
{
|
|
|
|
#endif /* __cplusplus */
|
|
|
|
|
|
|
|
#include "obd_error_codes.h"
|
2014-11-11 09:03:20 -08:00
|
|
|
#include "efifeatures.h"
|
2014-08-29 07:52:33 -07:00
|
|
|
#include "stdbool.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Something is wrong, but we can live with it: some minor sensor is disconnected
|
|
|
|
* or something like that
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
int warning(obd_code_e code, const char *fmt, ...);
|
|
|
|
/**
|
|
|
|
* Something really bad had happened - firmware cannot function
|
|
|
|
*
|
|
|
|
* todo: better method name?
|
|
|
|
*/
|
|
|
|
void firmwareError(const char *fmt, ...);
|
|
|
|
bool hasFirmwareError(void);
|
|
|
|
char *getFirmwareError(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* declared as a macro so that this code does not use stack
|
|
|
|
* so that it would not crash the error handler in case of stack issues
|
|
|
|
*/
|
|
|
|
#if CH_DBG_SYSTEM_STATE_CHECK
|
|
|
|
#define hasFatalError() (dbg_panic_msg != NULL)
|
|
|
|
#else
|
|
|
|
#define hasFatalError() (FALSE)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
void chDbgPanic3(const char *msg, const char * file, int line);
|
|
|
|
|
|
|
|
void initErrorHandling(void);
|
|
|
|
char *getWarninig(void);
|
|
|
|
|
|
|
|
// todo: better place for this shared declaration?
|
|
|
|
int getRusEfiVersion(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @deprecated Global panic is inconvenient because it's hard to deliver the error message while whole instance
|
|
|
|
* is stopped. Please use firmwareWarning() instead
|
|
|
|
*/
|
2014-11-11 09:03:20 -08:00
|
|
|
#if EFI_ENABLE_ASSERTS
|
|
|
|
#define efiAssert(condition, message, result) { if (!(condition)) { firmwareError(message); return result; } }
|
|
|
|
#define efiAssertVoid(condition, message) { if (!(condition)) { firmwareError(message); return; } }
|
|
|
|
#else /* EFI_ENABLE_ASSERTS */
|
|
|
|
#define efiAssert(condition, message, result) { (void)(condition); }
|
|
|
|
#define efiAssertVoid(condition, message) { (void)(condition); }
|
|
|
|
#endif /* EFI_ENABLE_ASSERTS */
|
2014-08-29 07:52:33 -07:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif /* __cplusplus */
|
|
|
|
|
|
|
|
#endif /* ERROR_HANDLING_H_ */
|