|
|
|
/*
|
|
|
|
* Cobalt Reset operations
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU General Public
|
|
|
|
* License. See the file "COPYING" in the main directory of this archive
|
|
|
|
* for more details.
|
|
|
|
*
|
|
|
|
* Copyright (C) 1995, 1996, 1997 by Ralf Baechle
|
|
|
|
* Copyright (C) 2001 by Liam Davies (ldavies@agile.tv)
|
|
|
|
*/
|
|
|
|
#include <linux/sched.h>
|
|
|
|
#include <linux/mm.h>
|
|
|
|
#include <asm/cacheflush.h>
|
|
|
|
#include <asm/io.h>
|
|
|
|
#include <asm/processor.h>
|
|
|
|
#include <asm/reboot.h>
|
|
|
|
#include <asm/system.h>
|
|
|
|
#include <asm/mipsregs.h>
|
|
|
|
#include <asm/cobalt/cobalt.h>
|
|
|
|
|
|
|
|
void cobalt_machine_halt(void)
|
|
|
|
{
|
|
|
|
int state, last, diff;
|
|
|
|
unsigned long mark;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* turn off bar on Qube, flash power off LED on RaQ (0.5Hz)
|
|
|
|
*
|
|
|
|
* restart if ENTER and SELECT are pressed
|
|
|
|
*/
|
|
|
|
|
|
|
|
last = COBALT_KEY_PORT;
|
|
|
|
|
|
|
|
for (state = 0;;) {
|
|
|
|
|
|
|
|
state ^= COBALT_LED_POWER_OFF;
|
|
|
|
COBALT_LED_PORT = state;
|
|
|
|
|
|
|
|
diff = COBALT_KEY_PORT ^ last;
|
|
|
|
last ^= diff;
|
|
|
|
|
|
|
|
if((diff & (COBALT_KEY_ENTER | COBALT_KEY_SELECT)) && !(~last & (COBALT_KEY_ENTER | COBALT_KEY_SELECT)))
|
|
|
|
COBALT_LED_PORT = COBALT_LED_RESET;
|
|
|
|
|
|
|
|
for (mark = jiffies; jiffies - mark < HZ;)
|
|
|
|
;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void cobalt_machine_restart(char *command)
|
|
|
|
{
|
|
|
|
COBALT_LED_PORT = COBALT_LED_RESET;
|
|
|
|
|
|
|
|
/* we should never get here */
|
|
|
|
cobalt_machine_halt();
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This triggers the luser mode device driver for the power switch ;-)
|
|
|
|
*/
|
|
|
|
void cobalt_machine_power_off(void)
|
|
|
|
{
|
|
|
|
printk("You can switch the machine off now.\n");
|
|
|
|
cobalt_machine_halt();
|
|
|
|
}
|