|
@@ -7,12 +7,6 @@
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
* published by the Free Software Foundation.
|
|
* published by the Free Software Foundation.
|
|
*/
|
|
*/
|
|
-#include <linux/io.h>
|
|
|
|
-#include <asm/hardware/dec21285.h>
|
|
|
|
-#include <mach/hardware.h>
|
|
|
|
-#include <asm/leds.h>
|
|
|
|
-#include <asm/mach-types.h>
|
|
|
|
-
|
|
|
|
static inline void arch_idle(void)
|
|
static inline void arch_idle(void)
|
|
{
|
|
{
|
|
cpu_do_idle();
|
|
cpu_do_idle();
|
|
@@ -20,50 +14,4 @@ static inline void arch_idle(void)
|
|
|
|
|
|
static inline void arch_reset(char mode, const char *cmd)
|
|
static inline void arch_reset(char mode, const char *cmd)
|
|
{
|
|
{
|
|
- if (mode == 's') {
|
|
|
|
- /*
|
|
|
|
- * Jump into the ROM
|
|
|
|
- */
|
|
|
|
- soft_restart(0x41000000);
|
|
|
|
- } else {
|
|
|
|
- if (machine_is_netwinder()) {
|
|
|
|
- /* open up the SuperIO chip
|
|
|
|
- */
|
|
|
|
- outb(0x87, 0x370);
|
|
|
|
- outb(0x87, 0x370);
|
|
|
|
-
|
|
|
|
- /* aux function group 1 (logical device 7)
|
|
|
|
- */
|
|
|
|
- outb(0x07, 0x370);
|
|
|
|
- outb(0x07, 0x371);
|
|
|
|
-
|
|
|
|
- /* set GP16 for WD-TIMER output
|
|
|
|
- */
|
|
|
|
- outb(0xe6, 0x370);
|
|
|
|
- outb(0x00, 0x371);
|
|
|
|
-
|
|
|
|
- /* set a RED LED and toggle WD_TIMER for rebooting
|
|
|
|
- */
|
|
|
|
- outb(0xc4, 0x338);
|
|
|
|
- } else {
|
|
|
|
- /*
|
|
|
|
- * Force the watchdog to do a CPU reset.
|
|
|
|
- *
|
|
|
|
- * After making sure that the watchdog is disabled
|
|
|
|
- * (so we can change the timer registers) we first
|
|
|
|
- * enable the timer to autoreload itself. Next, the
|
|
|
|
- * timer interval is set really short and any
|
|
|
|
- * current interrupt request is cleared (so we can
|
|
|
|
- * see an edge transition). Finally, TIMER4 is
|
|
|
|
- * enabled as the watchdog.
|
|
|
|
- */
|
|
|
|
- *CSR_SA110_CNTL &= ~(1 << 13);
|
|
|
|
- *CSR_TIMER4_CNTL = TIMER_CNTL_ENABLE |
|
|
|
|
- TIMER_CNTL_AUTORELOAD |
|
|
|
|
- TIMER_CNTL_DIV16;
|
|
|
|
- *CSR_TIMER4_LOAD = 0x2;
|
|
|
|
- *CSR_TIMER4_CLR = 0;
|
|
|
|
- *CSR_SA110_CNTL |= (1 << 13);
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
}
|
|
}
|