1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/core/include/panic.h

93 lines
2.5 KiB
C
Raw Normal View History

/*
2015-05-09 18:02:39 +02:00
* Copyright (C) 2014, 2015 INRIA
*
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.
*/
/**
* @ingroup core_util
* @{
*
2015-05-09 18:02:39 +02:00
* @file
* @brief Crash handling header
*
2015-05-09 18:02:39 +02:00
* Define a ::core_panic function that allows to stop/reboot the system
* when an unrecoverable problem has occurred.
*
* @author Kévin Roussel <Kevin.Roussel@inria.fr>
*/
2015-05-09 18:02:39 +02:00
#ifndef PANIC_H
#define PANIC_H
#include "kernel_defines.h"
#ifdef __cplusplus
2020-03-30 17:02:08 +02:00
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,
2020-02-03 10:58:25 +01:00
PANIC_EXPECT_FAIL,
2015-08-26 16:01:04 +02:00
#ifdef MODULE_CORTEXM_COMMON
2020-03-30 17:02:08 +02:00
PANIC_NMI_HANDLER, /**< non maskable interrupt */
PANIC_HARD_FAULT, /**< hard fault */
#if defined(CPU_CORE_CORTEX_M3) || defined(CPU_CORE_CORTEX_M33) || \
defined(CPU_CORE_CORTEX_M4) || defined(CPU_CORE_CORTEX_M4F) || \
defined(CPU_CORE_CORTEX_M7)
2020-03-30 17:02:08 +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 */
2015-08-26 16:01:04 +02:00
#endif
2020-03-30 17:02:08 +02:00
PANIC_DUMMY_HANDLER, /**< unhandled interrupt */
2015-08-26 16:01:04 +02:00
#endif
2020-03-30 17:02:08 +02:00
PANIC_SSP, /**< stack smashing protector failure */
2015-08-26 16:01:04 +02:00
PANIC_UNDEFINED
} core_panic_t;
/**
* @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);
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);
#ifdef __cplusplus
}
#endif
2015-05-09 18:02:39 +02:00
#endif /* PANIC_H */
/** @} */