mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
063a15ce9b
Change from `void reboot(void)` to `int reboot(int mode)`. Move reboot definition to core, rename architecture implementations from reboot to reboot_arch. Declare reboot mode(s) in kernel.h, reboot_arch in kernel_internal.h Currently only one reboot mode is handled, its use is enforced. Rationale: A reboot function is already defined in <unistd.h> on BSD systems. (See: http://www.openbsd.org/cgi-bin/man.cgi?query=reboot&sektion=2) This patch not only allows native to build sensibly on these systems but also streamlines RIOTs compatability with existing software.
64 lines
1.5 KiB
C
64 lines
1.5 KiB
C
/*
|
|
* Copyright (C) 2014 INRIA
|
|
*
|
|
* This file is subject to the terms and conditions of the GNU Lesser General
|
|
* Public License. See the file LICENSE in the top level directory for more
|
|
* details.
|
|
*/
|
|
|
|
/**
|
|
* @ingroup core_util
|
|
* @{
|
|
*
|
|
* @file crash.c
|
|
* @brief Crash handling functions implementation for MSP430 MCUs
|
|
*
|
|
* @author Kévin Roussel <Kevin.Roussel@inria.fr>
|
|
*/
|
|
|
|
#include "cpu.h"
|
|
#include "lpm.h"
|
|
#include "crash.h"
|
|
|
|
#include <string.h>
|
|
#include <stdio.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);
|
|
/* (try to) print panic message to console */
|
|
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 */
|
|
WDTCTL = WDTPW | WDTHOLD;
|
|
dINT();
|
|
#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
|
|
}
|