/* * 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 #include #include #include #include #define RESET_PORT ((void __iomem *)CKSEG1ADDR(0x1c000000)) #define RESET 0x0f DEFINE_LED_TRIGGER(power_off_led_trigger); static int __init ledtrig_power_off_init(void) { led_trigger_register_simple("power-off", &power_off_led_trigger); return 0; } device_initcall(ledtrig_power_off_init); void cobalt_machine_halt(void) { int state, last, diff; unsigned long mark; /* * turn on power off LED on RaQ * * restart if ENTER and SELECT are pressed */ last = COBALT_KEY_PORT; led_trigger_event(power_off_led_trigger, LED_FULL); for (state = 0;;) { diff = COBALT_KEY_PORT ^ last; last ^= diff; if((diff & (COBALT_KEY_ENTER | COBALT_KEY_SELECT)) && !(~last & (COBALT_KEY_ENTER | COBALT_KEY_SELECT))) writeb(RESET, RESET_PORT); for (mark = jiffies; jiffies - mark < HZ;) ; } } void cobalt_machine_restart(char *command) { writeb(RESET, RESET_PORT); /* we should never get here */ cobalt_machine_halt(); }