mach-w90p910evb.c 4.5 KB
Newer Older
1 2 3 4 5
/*
 * linux/arch/arm/mach-w90x900/mach-w90p910evb.c
 *
 * Based on mach-s3c2410/mach-smdk2410.c by Jonas Dietsche
 *
6
 * Copyright (C) 2008 Nuvoton technology corporation.
7 8 9 10 11
 *
 * Wan ZongShun <mcuos.com@gmail.com>
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License as
12
 * published by the Free Software Foundation;version 2 of the License.
13 14 15 16 17 18 19 20 21 22
 *
 */

#include <linux/kernel.h>
#include <linux/types.h>
#include <linux/interrupt.h>
#include <linux/list.h>
#include <linux/timer.h>
#include <linux/init.h>
#include <linux/platform_device.h>
23
#include <linux/mtd/physmap.h>
24 25 26 27 28 29 30

#include <asm/mach/arch.h>
#include <asm/mach/map.h>
#include <asm/mach/irq.h>
#include <asm/mach-types.h>

#include <mach/regs-serial.h>
31
#include <mach/map.h>
32 33

#include "cpu.h"
34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79
/*w90p910 evb norflash driver data */

#define W90P910_FLASH_BASE	0xA0000000
#define W90P910_FLASH_SIZE	0x400000

static struct mtd_partition w90p910_flash_partitions[] = {
	{
		.name	=	"NOR Partition 1 for kernel (960K)",
		.size	=	0xF0000,
		.offset	=	0x10000,
	},
	{
		.name	=	"NOR Partition 2 for image (1M)",
		.size	=	0x100000,
		.offset	=	0x100000,
	},
	{
		.name	=	"NOR Partition 3 for user (2M)",
		.size	=	0x200000,
		.offset	=	0x00200000,
	}
};

static struct physmap_flash_data w90p910_flash_data = {
	.width		=	2,
	.parts		=	w90p910_flash_partitions,
	.nr_parts	=	ARRAY_SIZE(w90p910_flash_partitions),
};

static struct resource w90p910_flash_resources[] = {
	{
		.start	=	W90P910_FLASH_BASE,
		.end	=	W90P910_FLASH_BASE + W90P910_FLASH_SIZE - 1,
		.flags	=	IORESOURCE_MEM,
	}
};

static struct platform_device w90p910_flash_device = {
	.name		=	"physmap-flash",
	.id		=	0,
	.dev		= {
				.platform_data = &w90p910_flash_data,
			},
	.resource	=	w90p910_flash_resources,
	.num_resources	=	ARRAY_SIZE(w90p910_flash_resources),
};
80

81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137
/* USB EHCI Host Controller */

static struct resource w90x900_usb_ehci_resource[] = {
	[0] = {
		.start = W90X900_PA_USBEHCIHOST,
		.end   = W90X900_PA_USBEHCIHOST + W90X900_SZ_USBEHCIHOST - 1,
		.flags = IORESOURCE_MEM,
	},
	[1] = {
		.start = IRQ_USBH,
		.end   = IRQ_USBH,
		.flags = IORESOURCE_IRQ,
	}
};

static u64 w90x900_device_usb_ehci_dmamask = 0xffffffffUL;

struct platform_device w90x900_device_usb_ehci = {
	.name		  = "w90x900-ehci",
	.id		  = -1,
	.num_resources	  = ARRAY_SIZE(w90x900_usb_ehci_resource),
	.resource	  = w90x900_usb_ehci_resource,
	.dev              = {
		.dma_mask = &w90x900_device_usb_ehci_dmamask,
		.coherent_dma_mask = 0xffffffffUL
	}
};
EXPORT_SYMBOL(w90x900_device_usb_ehci);

/* USB OHCI Host Controller */

static struct resource w90x900_usb_ohci_resource[] = {
	[0] = {
		.start = W90X900_PA_USBOHCIHOST,
		.end   = W90X900_PA_USBOHCIHOST + W90X900_SZ_USBOHCIHOST - 1,
		.flags = IORESOURCE_MEM,
	},
	[1] = {
		.start = IRQ_USBH,
		.end   = IRQ_USBH,
		.flags = IORESOURCE_IRQ,
	}
};

static u64 w90x900_device_usb_ohci_dmamask = 0xffffffffUL;
struct platform_device w90x900_device_usb_ohci = {
	.name		  = "w90x900-ohci",
	.id		  = -1,
	.num_resources	  = ARRAY_SIZE(w90x900_usb_ohci_resource),
	.resource	  = w90x900_usb_ohci_resource,
	.dev              = {
		.dma_mask = &w90x900_device_usb_ohci_dmamask,
		.coherent_dma_mask = 0xffffffffUL
	}
};
EXPORT_SYMBOL(w90x900_device_usb_ohci);

138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160
/*TouchScreen controller*/

static struct resource w90x900_ts_resource[] = {
	[0] = {
		.start = W90X900_PA_ADC,
		.end   = W90X900_PA_ADC + W90X900_SZ_ADC-1,
		.flags = IORESOURCE_MEM,
	},
	[1] = {
		.start = IRQ_ADC,
		.end   = IRQ_ADC,
		.flags = IORESOURCE_IRQ,
	},
};

struct platform_device w90x900_device_ts = {
	.name		= "w90x900-ts",
	.id		= -1,
	.resource	= w90x900_ts_resource,
	.num_resources	= ARRAY_SIZE(w90x900_ts_resource),
};
EXPORT_SYMBOL(w90x900_device_ts);

161 162 163 164 165 166
static struct map_desc w90p910_iodesc[] __initdata = {
};

/*Here should be your evb resourse,such as LCD*/

static struct platform_device *w90p910evb_dev[] __initdata = {
167
	&w90p910_serial_device,
168
	&w90p910_flash_device,
169 170
	&w90x900_device_usb_ehci,
	&w90x900_device_usb_ohci,
171
	&w90x900_device_ts,
172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194
};

static void __init w90p910evb_map_io(void)
{
	w90p910_map_io(w90p910_iodesc, ARRAY_SIZE(w90p910_iodesc));
	w90p910_init_clocks(0);
}

static void __init w90p910evb_init(void)
{
	platform_add_devices(w90p910evb_dev, ARRAY_SIZE(w90p910evb_dev));
}

MACHINE_START(W90P910EVB, "W90P910EVB")
	/* Maintainer: Wan ZongShun */
	.phys_io	= W90X900_PA_UART,
	.io_pg_offst	= (((u32)W90X900_VA_UART) >> 18) & 0xfffc,
	.boot_params	= 0,
	.map_io		= w90p910evb_map_io,
	.init_irq	= w90x900_init_irq,
	.init_machine	= w90p910evb_init,
	.timer		= &w90x900_timer,
MACHINE_END