rusefi/firmware/controllers/algo/error_handling.h

72 lines
1.8 KiB
C
Raw Normal View History

2014-08-29 07:52:33 -07:00
/**
* @file error_handling.h
*
* @date Mar 6, 2014
2015-01-12 15:04:10 -08:00
* @author Andrey Belomutskiy, (c) 2012-2015
2014-08-29 07:52:33 -07:00
*/
#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, ...);
2014-11-24 09:03:09 -08:00
#define hasFirmwareError() hasFirmwareErrorFlag
2014-08-29 07:52:33 -07:00
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_ */