2014-02-12 11:10:38 +01:00
|
|
|
/*
|
2015-05-09 18:02:39 +02:00
|
|
|
* Copyright (C) 2014, 2015 INRIA
|
2014-02-12 11:10:38 +01:00
|
|
|
*
|
2014-08-23 15:43:13 +02:00
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
2014-02-12 11:10:38 +01:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2019-01-07 15:36:14 +01:00
|
|
|
* @ingroup core_util
|
2014-02-12 11:10:38 +01:00
|
|
|
* @{
|
|
|
|
*
|
2015-05-09 18:02:39 +02:00
|
|
|
* @file
|
2014-02-12 11:10:38 +01:00
|
|
|
* @brief Crash handling header
|
|
|
|
*
|
2015-05-09 18:02:39 +02:00
|
|
|
* Define a ::core_panic function that allows to stop/reboot the system
|
2014-04-01 11:46:21 +02:00
|
|
|
* when an unrecoverable problem has occurred.
|
2014-02-12 11:10:38 +01:00
|
|
|
*
|
|
|
|
* @author Kévin Roussel <Kevin.Roussel@inria.fr>
|
|
|
|
*/
|
|
|
|
|
2015-05-09 18:02:39 +02:00
|
|
|
#ifndef PANIC_H
|
|
|
|
#define PANIC_H
|
2014-02-12 11:10:38 +01:00
|
|
|
|
2016-03-09 01:27:23 +01:00
|
|
|
#include "kernel_defines.h"
|
2014-10-13 14:44:28 +02:00
|
|
|
|
2014-10-09 01:18:16 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2015-08-26 16:01:04 +02:00
|
|
|
/**
|
|
|
|
* @brief Definition of available panic modes
|
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
PANIC_GENERAL_ERROR,
|
|
|
|
PANIC_SOFT_REBOOT,
|
|
|
|
PANIC_HARD_REBOOT,
|
|
|
|
PANIC_ASSERT_FAIL,
|
|
|
|
#ifdef MODULE_CORTEXM_COMMON
|
|
|
|
PANIC_NMI_HANDLER, /**< non maskable interrupt */
|
|
|
|
PANIC_HARD_FAULT, /**< hard fault */
|
|
|
|
#if defined(CPU_ARCH_CORTEX_M3) || defined(CPU_ARCH_CORTEX_M4) || \
|
2017-04-13 14:30:28 +02:00
|
|
|
defined(CPU_ARCH_CORTEX_M4F) || defined(CPU_ARCH_CORTEX_M7)
|
2015-08-26 16:01:04 +02:00
|
|
|
PANIC_MEM_MANAGE, /**< memory controller interrupt */
|
|
|
|
PANIC_BUS_FAULT, /**< bus fault */
|
|
|
|
PANIC_USAGE_FAULT, /**< undefined instruction or unaligned access */
|
|
|
|
PANIC_DEBUG_MON, /**< debug interrupt */
|
|
|
|
#endif
|
|
|
|
PANIC_DUMMY_HANDLER, /**< unhandled interrupt */
|
|
|
|
#endif
|
2016-12-04 11:04:40 +01:00
|
|
|
PANIC_SSP, /**< stack smashing protector failure */
|
2015-08-26 16:01:04 +02:00
|
|
|
PANIC_UNDEFINED
|
|
|
|
} core_panic_t;
|
|
|
|
|
2014-04-01 11:46:21 +02:00
|
|
|
/**
|
|
|
|
* @brief Handle an unrecoverable error by halting or rebooting the system
|
|
|
|
*
|
|
|
|
* A numeric code indicating the failure reason can be given
|
|
|
|
* as the *crash_code* parameter.
|
|
|
|
*
|
|
|
|
* Detailing the failure is possible using the *message* parameter.
|
|
|
|
* This function should serve a similar purpose as the panic()
|
|
|
|
* function of Unix/Linux kernels.
|
|
|
|
*
|
|
|
|
* If the DEVELHELP macro is defined, the system will be halted;
|
|
|
|
* the system will be rebooted otherwise.
|
|
|
|
*
|
|
|
|
* @warning this function NEVER returns!
|
|
|
|
*
|
|
|
|
* @param[in] crash_code a unique code for identifying the crash reason
|
|
|
|
* @param[in] message a human readable reason for the crash
|
|
|
|
*
|
|
|
|
* @return this function never returns
|
|
|
|
* */
|
2015-08-26 16:01:04 +02:00
|
|
|
NORETURN void core_panic(core_panic_t crash_code, const char *message);
|
2014-02-12 11:10:38 +01:00
|
|
|
|
2017-10-20 17:03:46 +02:00
|
|
|
/**
|
2017-10-20 22:23:33 +02:00
|
|
|
* @brief architecture dependent handling of a panic case
|
2017-10-20 17:03:46 +02:00
|
|
|
*
|
|
|
|
* This function gives the CPU the possibility to execute architecture
|
2017-10-20 22:23:33 +02:00
|
|
|
* dependent code in case of a severe error.
|
2017-10-20 17:03:46 +02:00
|
|
|
*/
|
|
|
|
void panic_arch(void);
|
|
|
|
|
2014-10-09 01:18:16 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2015-05-09 18:02:39 +02:00
|
|
|
#endif /* PANIC_H */
|
2014-04-01 11:46:21 +02:00
|
|
|
/** @} */
|