2005-04-16 15:20:36 -07: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.
|
|
|
|
*
|
|
|
|
* Miscellaneous ARCS PROM routines.
|
|
|
|
*
|
2011-04-04 14:15:29 -07:00
|
|
|
* Copyright (C) 1996 David S. Miller (davem@davemloft.net)
|
2005-04-16 15:20:36 -07:00
|
|
|
* Copyright (C) 1999 Ralf Baechle (ralf@gnu.org)
|
|
|
|
* Copyright (C) 1999 Silicon Graphics, Inc.
|
|
|
|
*/
|
2015-01-02 17:16:24 +01:00
|
|
|
#include <linux/compiler.h>
|
2005-04-16 15:20:36 -07:00
|
|
|
#include <linux/init.h>
|
|
|
|
#include <linux/kernel.h>
|
2012-11-16 14:14:52 -08:00
|
|
|
#include <linux/irqflags.h>
|
2005-04-16 15:20:36 -07:00
|
|
|
|
|
|
|
#include <asm/bcache.h>
|
|
|
|
|
2007-09-05 08:59:34 +02:00
|
|
|
#include <asm/fw/arc/types.h>
|
2005-04-16 15:20:36 -07:00
|
|
|
#include <asm/sgialib.h>
|
|
|
|
#include <asm/bootinfo.h>
|
|
|
|
|
2015-01-02 17:16:24 +01:00
|
|
|
VOID __noreturn
|
2005-04-16 15:20:36 -07:00
|
|
|
ArcHalt(VOID)
|
|
|
|
{
|
|
|
|
bc_disable();
|
|
|
|
local_irq_disable();
|
|
|
|
ARC_CALL0(halt);
|
2015-01-02 17:16:24 +01:00
|
|
|
|
|
|
|
unreachable();
|
2005-04-16 15:20:36 -07:00
|
|
|
}
|
|
|
|
|
2015-01-02 17:16:24 +01:00
|
|
|
VOID __noreturn
|
2005-04-16 15:20:36 -07:00
|
|
|
ArcPowerDown(VOID)
|
|
|
|
{
|
|
|
|
bc_disable();
|
|
|
|
local_irq_disable();
|
|
|
|
ARC_CALL0(pdown);
|
2015-01-02 17:16:24 +01:00
|
|
|
|
|
|
|
unreachable();
|
2005-04-16 15:20:36 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
/* XXX is this a soft reset basically? XXX */
|
2015-01-02 17:16:24 +01:00
|
|
|
VOID __noreturn
|
2005-04-16 15:20:36 -07:00
|
|
|
ArcRestart(VOID)
|
|
|
|
{
|
|
|
|
bc_disable();
|
|
|
|
local_irq_disable();
|
|
|
|
ARC_CALL0(restart);
|
2015-01-02 17:16:24 +01:00
|
|
|
|
|
|
|
unreachable();
|
2005-04-16 15:20:36 -07:00
|
|
|
}
|
|
|
|
|
2015-01-02 17:16:24 +01:00
|
|
|
VOID __noreturn
|
2005-04-16 15:20:36 -07:00
|
|
|
ArcReboot(VOID)
|
|
|
|
{
|
|
|
|
bc_disable();
|
|
|
|
local_irq_disable();
|
|
|
|
ARC_CALL0(reboot);
|
2015-01-02 17:16:24 +01:00
|
|
|
|
|
|
|
unreachable();
|
2005-04-16 15:20:36 -07:00
|
|
|
}
|
|
|
|
|
2015-01-02 17:16:24 +01:00
|
|
|
VOID __noreturn
|
2005-04-16 15:20:36 -07:00
|
|
|
ArcEnterInteractiveMode(VOID)
|
|
|
|
{
|
|
|
|
bc_disable();
|
|
|
|
local_irq_disable();
|
|
|
|
ARC_CALL0(imode);
|
2015-01-02 17:16:24 +01:00
|
|
|
|
|
|
|
unreachable();
|
2005-04-16 15:20:36 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
LONG
|
|
|
|
ArcSaveConfiguration(VOID)
|
|
|
|
{
|
|
|
|
return ARC_CALL0(cfg_save);
|
|
|
|
}
|
|
|
|
|
|
|
|
struct linux_sysid *
|
|
|
|
ArcGetSystemId(VOID)
|
|
|
|
{
|
|
|
|
return (struct linux_sysid *) ARC_CALL0(get_sysid);
|
|
|
|
}
|
|
|
|
|
|
|
|
VOID __init
|
|
|
|
ArcFlushAllCaches(VOID)
|
|
|
|
{
|
|
|
|
ARC_CALL0(cache_flush);
|
|
|
|
}
|
|
|
|
|
|
|
|
DISPLAY_STATUS * __init ArcGetDisplayStatus(ULONG FileID)
|
|
|
|
{
|
|
|
|
return (DISPLAY_STATUS *) ARC_CALL1(GetDisplayStatus, FileID);
|
|
|
|
}
|