2 * Renesas System Solutions Asia Pte. Ltd - Migo-R
4 * Copyright (C) 2008 Magnus Damm
6 * This file is subject to the terms and conditions of the GNU General Public
7 * License. See the file "COPYING" in the main directory of this archive
10 #include <linux/init.h>
11 #include <linux/platform_device.h>
12 #include <linux/interrupt.h>
13 #include <linux/input.h>
14 #include <asm/machvec.h>
16 #include <asm/sh_keysc.h>
17 #include <asm/migor.h>
19 /* Address IRQ Size Bus Description
20 * 0x00000000 64MB 16 NOR Flash (SP29PL256N)
21 * 0x0c000000 64MB 64 SDRAM (2xK4M563233G)
22 * 0x10000000 IRQ0 16 Ethernet (SMC91C111)
23 * 0x14000000 IRQ4 16 USB 2.0 Host Controller (M66596)
24 * 0x18000000 8GB 8 NAND Flash (K9K8G08U0A)
27 static struct resource smc91x_eth_resources[] = {
32 .flags = IORESOURCE_MEM,
35 .start = 32, /* IRQ0 */
36 .flags = IORESOURCE_IRQ | IRQF_TRIGGER_HIGH,
40 static struct platform_device smc91x_eth_device = {
42 .num_resources = ARRAY_SIZE(smc91x_eth_resources),
43 .resource = smc91x_eth_resources,
46 static struct sh_keysc_info sh_keysc_info = {
47 .mode = SH_KEYSC_MODE_2, /* KEYOUT0->4, KEYIN1->5 */
51 0, KEY_UP, KEY_DOWN, KEY_LEFT, KEY_RIGHT, KEY_ENTER,
52 0, KEY_F, KEY_C, KEY_D, KEY_H, KEY_1,
53 0, KEY_2, KEY_3, KEY_4, KEY_5, KEY_6,
54 0, KEY_7, KEY_8, KEY_9, KEY_S, KEY_0,
55 0, KEY_P, KEY_STOP, KEY_REWIND, KEY_PLAY, KEY_FASTFORWARD,
59 static struct resource sh_keysc_resources[] = {
63 .flags = IORESOURCE_MEM,
67 .flags = IORESOURCE_IRQ,
71 static struct platform_device sh_keysc_device = {
73 .num_resources = ARRAY_SIZE(sh_keysc_resources),
74 .resource = sh_keysc_resources,
76 .platform_data = &sh_keysc_info,
80 static struct platform_device *migor_devices[] __initdata = {
85 static int __init migor_devices_setup(void)
87 return platform_add_devices(migor_devices, ARRAY_SIZE(migor_devices));
89 __initcall(migor_devices_setup);
91 static void __init migor_setup(char **cmdline_p)
93 /* SMC91C111 - Enable IRQ0 */
94 ctrl_outw(ctrl_inw(PORT_PJCR) & ~0x0003, PORT_PJCR);
97 ctrl_outw(ctrl_inw(PORT_PYCR) & ~0x0fff, PORT_PYCR);
98 ctrl_outw(ctrl_inw(PORT_PZCR) & ~0x0ff0, PORT_PZCR);
99 ctrl_outw(ctrl_inw(PORT_PSELA) & ~0x4100, PORT_PSELA);
100 ctrl_outw(ctrl_inw(PORT_HIZCRA) & ~0x4000, PORT_HIZCRA);
101 ctrl_outw(ctrl_inw(PORT_HIZCRC) & ~0xc000, PORT_HIZCRC);
102 ctrl_outl(ctrl_inl(MSTPCR2) & ~0x00004000, MSTPCR2);
105 static struct sh_machine_vector mv_migor __initmv = {
107 .mv_setup = migor_setup,