minix/kernel/arch/earm/arch_reset.c

84 lines
1.2 KiB
C
Raw Normal View History

2012-10-08 03:38:03 +02:00
#include "kernel/kernel.h"
#include <unistd.h>
#include <ctype.h>
#include <string.h>
#include <machine/cpu.h>
#include <assert.h>
#include <signal.h>
#include <machine/vm.h>
#include <io.h>
2012-10-08 03:38:03 +02:00
#include <minix/reboot.h>
#include <minix/board.h>
2012-10-08 03:38:03 +02:00
#include <minix/u64.h>
#include "archconst.h"
#include "arch_proto.h"
#include "bsp_reset.h"
#include "bsp_serial.h"
2012-10-08 03:38:03 +02:00
#include "kernel/proc.h"
#include "kernel/debug.h"
#include "direct_utils.h"
#include <machine/multiboot.h>
void
halt_cpu(void)
2012-10-08 03:38:03 +02:00
{
asm volatile("dsb");
asm volatile("cpsie i");
asm volatile("wfi");
asm volatile("cpsid i");
2012-10-08 03:38:03 +02:00
}
void
reset(void)
{
bsp_reset(); /* should not exit */
direct_print("Reset not supported.");
while (1);
2012-10-08 03:38:03 +02:00
}
void
poweroff(void)
{
bsp_poweroff();
/* fallback option: hang */
direct_print("Unable to power-off this device.");
while (1);
}
__dead void
arch_shutdown(int how)
2012-10-08 03:38:03 +02:00
{
switch (how) {
case RBT_HALT:
/* Hang */
for (; ; ) halt_cpu();
NOT_REACHABLE;
case RBT_POWEROFF:
/* Power off if possible, hang otherwise */
poweroff();
NOT_REACHABLE;
default:
case RBT_DEFAULT:
case RBT_REBOOT:
case RBT_RESET:
/* Reset the system */
reset();
NOT_REACHABLE;
}
while (1);
2012-10-08 03:38:03 +02:00
}
#ifdef DEBUG_SERIAL
void
ser_putc(char c)
2012-10-08 03:38:03 +02:00
{
bsp_ser_putc(c);
2012-10-08 03:38:03 +02:00
}
#endif