mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
Merge pull request #2415 from haukepetersen/add_m0_crash
cpu/cortex_m0_common: added crash.c
This commit is contained in:
commit
bf730c1c60
67
cpu/cortex-m0_common/crash.c
Normal file
67
cpu/cortex-m0_common/crash.c
Normal file
@ -0,0 +1,67 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2015 INRIA
|
||||||
|
*
|
||||||
|
* 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 cortex-m0_common
|
||||||
|
* @{
|
||||||
|
*
|
||||||
|
* @file
|
||||||
|
* @brief Crash handling functions implementation for ARM Cortex-based MCUs
|
||||||
|
*
|
||||||
|
* @author Oliver Hahm <oliver.hahm@inria.fr>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <string.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
#include "cpu.h"
|
||||||
|
#include "irq.h"
|
||||||
|
#include "lpm.h"
|
||||||
|
#include "crash.h"
|
||||||
|
|
||||||
|
/* "public" variables holding the crash data */
|
||||||
|
char panic_str[80];
|
||||||
|
int panic_code;
|
||||||
|
|
||||||
|
/* flag preventing "recursive crash printing loop" */
|
||||||
|
static int crashed = 0;
|
||||||
|
|
||||||
|
/* WARNING: this function NEVER returns! */
|
||||||
|
NORETURN void core_panic(int crash_code, const char *message)
|
||||||
|
{
|
||||||
|
/* copy panic datas to "public" global variables */
|
||||||
|
panic_code = crash_code;
|
||||||
|
strncpy(panic_str, message, 80);
|
||||||
|
/* print panic message to console (if possible) */
|
||||||
|
if (crashed == 0) {
|
||||||
|
crashed = 1;
|
||||||
|
puts("******** SYSTEM FAILURE ********\n");
|
||||||
|
puts(message);
|
||||||
|
#if DEVELHELP
|
||||||
|
puts("******** RIOT HALTS HERE ********\n");
|
||||||
|
#else
|
||||||
|
puts("******** RIOT WILL REBOOT ********\n");
|
||||||
|
#endif
|
||||||
|
puts("\n\n");
|
||||||
|
}
|
||||||
|
/* disable watchdog and all possible sources of interrupts */
|
||||||
|
disableIRQ();
|
||||||
|
#if DEVELHELP
|
||||||
|
/* enter infinite loop, into deepest possible sleep mode */
|
||||||
|
while (1) {
|
||||||
|
lpm_set(LPM_OFF);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
/* DEVELHELP not set => reboot system */
|
||||||
|
(void) reboot(RB_AUTOBOOT);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* tell the compiler that we won't return from this function
|
||||||
|
(even if we actually won't even get here...) */
|
||||||
|
UNREACHABLE();
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user