2005-04-17 02:20:36 +04:00
/*
* 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 .
*
* Reset an IP27 .
*
2006-01-18 20:37:07 +03:00
* Copyright ( C ) 1997 , 1998 , 1999 , 2000 , 06 by Ralf Baechle
2005-04-17 02:20:36 +04:00
* Copyright ( C ) 1999 , 2000 Silicon Graphics , Inc .
*/
2015-01-02 17:57:40 +03:00
# include <linux/compiler.h>
2005-04-17 02:20:36 +04:00
# include <linux/kernel.h>
# include <linux/sched.h>
# include <linux/timer.h>
# include <linux/smp.h>
# include <linux/mmzone.h>
# include <linux/nodemask.h>
2006-01-18 20:37:07 +03:00
# include <linux/pm.h>
2005-04-17 02:20:36 +04:00
# include <asm/io.h>
# include <asm/irq.h>
# include <asm/reboot.h>
# include <asm/sgialib.h>
# include <asm/sn/addrs.h>
# include <asm/sn/arch.h>
# include <asm/sn/gda.h>
# include <asm/sn/sn0/hub.h>
2015-01-02 17:57:40 +03:00
void machine_restart ( char * command ) __noreturn ;
void machine_halt ( void ) __noreturn ;
void machine_power_off ( void ) __noreturn ;
2005-04-17 02:20:36 +04:00
2013-01-22 15:59:30 +04:00
# define noreturn while(1); /* Silence gcc. */
2005-04-17 02:20:36 +04:00
/* XXX How to pass the reboot command to the firmware??? */
static void ip27_machine_restart ( char * command )
{
#if 0
int i ;
# endif
printk ( " Reboot started from CPU %d \n " , smp_processor_id ( ) ) ;
# ifdef CONFIG_SMP
smp_send_stop ( ) ;
# endif
#if 0
for_each_online_node ( i )
REMOTE_HUB_S ( COMPACT_TO_NASID_NODEID ( i ) , PROMOP_REG ,
PROMOP_REBOOT ) ;
# else
LOCAL_HUB_S ( NI_PORT_RESET , NPR_PORTRESET | NPR_LOCALRESET ) ;
# endif
noreturn ;
}
static void ip27_machine_halt ( void )
{
int i ;
# ifdef CONFIG_SMP
smp_send_stop ( ) ;
# endif
for_each_online_node ( i )
REMOTE_HUB_S ( COMPACT_TO_NASID_NODEID ( i ) , PROMOP_REG ,
PROMOP_RESTART ) ;
LOCAL_HUB_S ( NI_PORT_RESET , NPR_PORTRESET | NPR_LOCALRESET ) ;
noreturn ;
}
static void ip27_machine_power_off ( void )
{
/* To do ... */
noreturn ;
}
void ip27_reboot_setup ( void )
{
_machine_restart = ip27_machine_restart ;
_machine_halt = ip27_machine_halt ;
2006-01-18 20:37:07 +03:00
pm_power_off = ip27_machine_power_off ;
2005-04-17 02:20:36 +04:00
}