xp860.c 1.58 KB
Newer Older
Linus Torvalds's avatar
Linus Torvalds committed
1 2 3 4 5 6 7 8 9
/*
 * linux/arch/arm/mach-sa1100/xp860.c
 */

#include <linux/init.h>
#include <linux/kernel.h>
#include <linux/delay.h>
#include <linux/pm.h>
#include <linux/tty.h>
Linus Torvalds's avatar
Linus Torvalds committed
10
#include <linux/ioport.h>
Linus Torvalds's avatar
Linus Torvalds committed
11 12 13 14 15 16 17 18 19 20 21 22 23 24

#include <asm/hardware.h>
#include <asm/setup.h>

#include <asm/mach/arch.h>
#include <asm/mach/map.h>
#include <asm/mach/serial_sa1100.h>

#include "generic.h"
#include "sa1111.h"


static void xp860_power_off(void)
{
Russell King's avatar
Russell King committed
25
	local_irq_disable();
Linus Torvalds's avatar
Linus Torvalds committed
26 27 28 29 30 31 32
	GPDR |= GPIO_GPIO20;
	GPSR = GPIO_GPIO20;
	mdelay(1000);
	GPCR = GPIO_GPIO20;
	while(1);
}

Linus Torvalds's avatar
Linus Torvalds committed
33 34 35 36 37
/*
 * Note: I replaced the sa1111_init() without the full SA1111 initialisation
 * because this machine doesn't appear to use the DMA features.  If this is
 * wrong, please look at neponset.c to fix it properly.
 */
Linus Torvalds's avatar
Linus Torvalds committed
38 39 40
static int __init xp860_init(void)
{
	pm_power_off = xp860_power_off;
Linus Torvalds's avatar
Linus Torvalds committed
41 42 43 44

	/*
	 * Probe for SA1111.
	 */
Linus Torvalds's avatar
Linus Torvalds committed
45
	ret = sa1111_probe(0x40000000);
Linus Torvalds's avatar
Linus Torvalds committed
46 47 48 49 50 51 52 53
	if (ret < 0)
		return ret;

	/*
	 * We found it.  Wake the chip up.
	 */
	sa1111_wake();

Linus Torvalds's avatar
Linus Torvalds committed
54 55 56
	return 0;
}

57
arch_initcall(xp860_init);
Linus Torvalds's avatar
Linus Torvalds committed
58 59

static struct map_desc xp860_io_desc[] __initdata = {
60 61 62 63
 /* virtual     physical    length      type */
  { 0xf0000000, 0x10000000, 0x00100000, MT_DEVICE }, /* SCSI */
  { 0xf1000000, 0x18000000, 0x00100000, MT_DEVICE }, /* LAN */
  { 0xf4000000, 0x40000000, 0x00800000, MT_DEVICE }  /* SA-1111 */
Linus Torvalds's avatar
Linus Torvalds committed
64 65 66 67 68
};

static void __init xp860_map_io(void)
{
	sa1100_map_io();
69
	iotable_init(xp860_io_desc, ARRAY_SIZE(xp860_io_desc));
Linus Torvalds's avatar
Linus Torvalds committed
70 71 72 73 74 75 76 77 78 79

	sa1100_register_uart(0, 3);
	sa1100_register_uart(1, 1);
}

MACHINE_START(XP860, "XP860")
	BOOT_MEM(0xc0000000, 0x80000000, 0xf8000000)
	MAPIO(xp860_map_io)
	INITIRQ(sa1100_init_irq)
MACHINE_END