| /* |
| * 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/init.h> |
| #include <linux/io.h> |
| #include <linux/jiffies.h> |
| #include <linux/leds.h> |
| |
| #include <cobalt.h> |
| |
| #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(); |
| } |