| Igor Grinberg | d04b620 | 2010-09-21 16:03:09 +0000 | [diff] [blame] | 1 | /* | 
 | 2 |  * linux/arch/arm/mach-omap2/board-cm-t3517.c | 
 | 3 |  * | 
 | 4 |  * Support for the CompuLab CM-T3517 modules | 
 | 5 |  * | 
 | 6 |  * Copyright (C) 2010 CompuLab, Ltd. | 
 | 7 |  * Author: Igor Grinberg <grinberg@compulab.co.il> | 
 | 8 |  * | 
 | 9 |  * This program is free software; you can redistribute it and/or | 
 | 10 |  * modify it under the terms of the GNU General Public License | 
 | 11 |  * version 2 as published by the Free Software Foundation. | 
 | 12 |  * | 
 | 13 |  * This program is distributed in the hope that it will be useful, but | 
 | 14 |  * WITHOUT ANY WARRANTY; without even the implied warranty of | 
 | 15 |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | 
 | 16 |  * General Public License for more details. | 
 | 17 |  * | 
 | 18 |  * You should have received a copy of the GNU General Public License | 
 | 19 |  * along with this program; if not, write to the Free Software | 
 | 20 |  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA | 
 | 21 |  * 02110-1301 USA | 
 | 22 |  * | 
 | 23 |  */ | 
 | 24 |  | 
 | 25 | #include <linux/kernel.h> | 
 | 26 | #include <linux/init.h> | 
 | 27 | #include <linux/platform_device.h> | 
| Igor Grinberg | 525d75b | 2010-09-21 16:03:11 +0000 | [diff] [blame] | 28 | #include <linux/delay.h> | 
| Igor Grinberg | d04b620 | 2010-09-21 16:03:09 +0000 | [diff] [blame] | 29 | #include <linux/gpio.h> | 
 | 30 | #include <linux/leds.h> | 
| Igor Grinberg | 46893a5 | 2010-09-21 16:03:10 +0000 | [diff] [blame] | 31 | #include <linux/rtc-v3020.h> | 
| Igor Grinberg | ec34fcc | 2010-09-21 16:03:12 +0000 | [diff] [blame] | 32 | #include <linux/mtd/mtd.h> | 
 | 33 | #include <linux/mtd/nand.h> | 
 | 34 | #include <linux/mtd/partitions.h> | 
| Igor Grinberg | b6a26b4 | 2010-09-21 16:03:13 +0000 | [diff] [blame] | 35 | #include <linux/can/platform/ti_hecc.h> | 
| Igor Grinberg | d04b620 | 2010-09-21 16:03:09 +0000 | [diff] [blame] | 36 |  | 
 | 37 | #include <asm/mach-types.h> | 
 | 38 | #include <asm/mach/arch.h> | 
 | 39 | #include <asm/mach/map.h> | 
 | 40 |  | 
 | 41 | #include <plat/board.h> | 
 | 42 | #include <plat/common.h> | 
| Igor Grinberg | 525d75b | 2010-09-21 16:03:11 +0000 | [diff] [blame] | 43 | #include <plat/usb.h> | 
| Igor Grinberg | ec34fcc | 2010-09-21 16:03:12 +0000 | [diff] [blame] | 44 | #include <plat/nand.h> | 
 | 45 | #include <plat/gpmc.h> | 
| Igor Grinberg | d04b620 | 2010-09-21 16:03:09 +0000 | [diff] [blame] | 46 |  | 
| Igor Grinberg | b6a26b4 | 2010-09-21 16:03:13 +0000 | [diff] [blame] | 47 | #include <mach/am35xx.h> | 
 | 48 |  | 
| Igor Grinberg | d04b620 | 2010-09-21 16:03:09 +0000 | [diff] [blame] | 49 | #include "mux.h" | 
| Paul Walmsley | 4814ced | 2010-10-08 11:40:20 -0600 | [diff] [blame] | 50 | #include "control.h" | 
| Igor Grinberg | 1704bf1 | 2011-05-30 00:11:45 -0700 | [diff] [blame] | 51 | #include "common-board-devices.h" | 
| Igor Grinberg | d04b620 | 2010-09-21 16:03:09 +0000 | [diff] [blame] | 52 |  | 
 | 53 | #if defined(CONFIG_LEDS_GPIO) || defined(CONFIG_LEDS_GPIO_MODULE) | 
 | 54 | static struct gpio_led cm_t3517_leds[] = { | 
 | 55 | 	[0] = { | 
 | 56 | 		.gpio			= 186, | 
 | 57 | 		.name			= "cm-t3517:green", | 
 | 58 | 		.default_trigger	= "heartbeat", | 
 | 59 | 		.active_low		= 0, | 
 | 60 | 	}, | 
 | 61 | }; | 
 | 62 |  | 
 | 63 | static struct gpio_led_platform_data cm_t3517_led_pdata = { | 
 | 64 | 	.num_leds	= ARRAY_SIZE(cm_t3517_leds), | 
 | 65 | 	.leds		= cm_t3517_leds, | 
 | 66 | }; | 
 | 67 |  | 
 | 68 | static struct platform_device cm_t3517_led_device = { | 
 | 69 | 	.name		= "leds-gpio", | 
 | 70 | 	.id		= -1, | 
 | 71 | 	.dev		= { | 
 | 72 | 		.platform_data	= &cm_t3517_led_pdata, | 
 | 73 | 	}, | 
 | 74 | }; | 
 | 75 |  | 
 | 76 | static void __init cm_t3517_init_leds(void) | 
 | 77 | { | 
 | 78 | 	platform_device_register(&cm_t3517_led_device); | 
 | 79 | } | 
 | 80 | #else | 
 | 81 | static inline void cm_t3517_init_leds(void) {} | 
 | 82 | #endif | 
 | 83 |  | 
| Igor Grinberg | b6a26b4 | 2010-09-21 16:03:13 +0000 | [diff] [blame] | 84 | #if defined(CONFIG_CAN_TI_HECC) || defined(CONFIG_CAN_TI_HECC_MODULE) | 
 | 85 | static struct resource cm_t3517_hecc_resources[] = { | 
 | 86 | 	{ | 
 | 87 | 		.start	= AM35XX_IPSS_HECC_BASE, | 
 | 88 | 		.end	= AM35XX_IPSS_HECC_BASE + SZ_16K - 1, | 
 | 89 | 		.flags	= IORESOURCE_MEM, | 
 | 90 | 	}, | 
 | 91 | 	{ | 
 | 92 | 		.start	= INT_35XX_HECC0_IRQ, | 
 | 93 | 		.end	= INT_35XX_HECC0_IRQ, | 
 | 94 | 		.flags	= IORESOURCE_IRQ, | 
 | 95 | 	}, | 
 | 96 | }; | 
 | 97 |  | 
 | 98 | static struct ti_hecc_platform_data cm_t3517_hecc_pdata = { | 
 | 99 | 	.scc_hecc_offset	= AM35XX_HECC_SCC_HECC_OFFSET, | 
 | 100 | 	.scc_ram_offset		= AM35XX_HECC_SCC_RAM_OFFSET, | 
 | 101 | 	.hecc_ram_offset	= AM35XX_HECC_RAM_OFFSET, | 
 | 102 | 	.mbx_offset		= AM35XX_HECC_MBOX_OFFSET, | 
 | 103 | 	.int_line		= AM35XX_HECC_INT_LINE, | 
 | 104 | 	.version		= AM35XX_HECC_VERSION, | 
 | 105 | }; | 
 | 106 |  | 
 | 107 | static struct platform_device cm_t3517_hecc_device = { | 
 | 108 | 	.name		= "ti_hecc", | 
 | 109 | 	.id		= 1, | 
 | 110 | 	.num_resources	= ARRAY_SIZE(cm_t3517_hecc_resources), | 
 | 111 | 	.resource	= cm_t3517_hecc_resources, | 
 | 112 | 	.dev		= { | 
 | 113 | 		.platform_data	= &cm_t3517_hecc_pdata, | 
 | 114 | 	}, | 
 | 115 | }; | 
 | 116 |  | 
 | 117 | static void cm_t3517_init_hecc(void) | 
 | 118 | { | 
 | 119 | 	platform_device_register(&cm_t3517_hecc_device); | 
 | 120 | } | 
 | 121 | #else | 
 | 122 | static inline void cm_t3517_init_hecc(void) {} | 
 | 123 | #endif | 
 | 124 |  | 
| Igor Grinberg | 46893a5 | 2010-09-21 16:03:10 +0000 | [diff] [blame] | 125 | #if defined(CONFIG_RTC_DRV_V3020) || defined(CONFIG_RTC_DRV_V3020_MODULE) | 
 | 126 | #define RTC_IO_GPIO		(153) | 
 | 127 | #define RTC_WR_GPIO		(154) | 
| Igor Grinberg | fec5568cb | 2011-01-13 16:24:49 +0000 | [diff] [blame] | 128 | #define RTC_RD_GPIO		(53) | 
| Igor Grinberg | 46893a5 | 2010-09-21 16:03:10 +0000 | [diff] [blame] | 129 | #define RTC_CS_GPIO		(163) | 
| Igor Grinberg | fec5568cb | 2011-01-13 16:24:49 +0000 | [diff] [blame] | 130 | #define RTC_CS_EN_GPIO		(160) | 
| Igor Grinberg | 46893a5 | 2010-09-21 16:03:10 +0000 | [diff] [blame] | 131 |  | 
 | 132 | struct v3020_platform_data cm_t3517_v3020_pdata = { | 
 | 133 | 	.use_gpio	= 1, | 
 | 134 | 	.gpio_cs	= RTC_CS_GPIO, | 
 | 135 | 	.gpio_wr	= RTC_WR_GPIO, | 
 | 136 | 	.gpio_rd	= RTC_RD_GPIO, | 
 | 137 | 	.gpio_io	= RTC_IO_GPIO, | 
 | 138 | }; | 
 | 139 |  | 
 | 140 | static struct platform_device cm_t3517_rtc_device = { | 
 | 141 | 	.name		= "v3020", | 
 | 142 | 	.id		= -1, | 
 | 143 | 	.dev		= { | 
 | 144 | 		.platform_data = &cm_t3517_v3020_pdata, | 
 | 145 | 	} | 
 | 146 | }; | 
 | 147 |  | 
 | 148 | static void __init cm_t3517_init_rtc(void) | 
 | 149 | { | 
| Igor Grinberg | fec5568cb | 2011-01-13 16:24:49 +0000 | [diff] [blame] | 150 | 	int err; | 
 | 151 |  | 
| Igor Grinberg | bc593f5 | 2011-05-03 18:22:09 +0300 | [diff] [blame] | 152 | 	err = gpio_request_one(RTC_CS_EN_GPIO, GPIOF_OUT_INIT_HIGH, | 
 | 153 | 			       "rtc cs en"); | 
| Igor Grinberg | fec5568cb | 2011-01-13 16:24:49 +0000 | [diff] [blame] | 154 | 	if (err) { | 
 | 155 | 		pr_err("CM-T3517: rtc cs en gpio request failed: %d\n", err); | 
 | 156 | 		return; | 
 | 157 | 	} | 
 | 158 |  | 
| Igor Grinberg | 46893a5 | 2010-09-21 16:03:10 +0000 | [diff] [blame] | 159 | 	platform_device_register(&cm_t3517_rtc_device); | 
 | 160 | } | 
 | 161 | #else | 
 | 162 | static inline void cm_t3517_init_rtc(void) {} | 
 | 163 | #endif | 
| Igor Grinberg | d04b620 | 2010-09-21 16:03:09 +0000 | [diff] [blame] | 164 |  | 
| Igor Grinberg | 525d75b | 2010-09-21 16:03:11 +0000 | [diff] [blame] | 165 | #if defined(CONFIG_USB_EHCI_HCD) || defined(CONFIG_USB_EHCI_HCD_MODULE) | 
 | 166 | #define HSUSB1_RESET_GPIO	(146) | 
 | 167 | #define HSUSB2_RESET_GPIO	(147) | 
 | 168 | #define USB_HUB_RESET_GPIO	(152) | 
 | 169 |  | 
| Keshava Munegowda | 181b250 | 2011-03-01 20:08:16 +0530 | [diff] [blame] | 170 | static struct usbhs_omap_board_data cm_t3517_ehci_pdata __initdata = { | 
 | 171 | 	.port_mode[0] = OMAP_EHCI_PORT_MODE_PHY, | 
 | 172 | 	.port_mode[1] = OMAP_EHCI_PORT_MODE_PHY, | 
 | 173 | 	.port_mode[2] = OMAP_USBHS_PORT_MODE_UNUSED, | 
| Igor Grinberg | 525d75b | 2010-09-21 16:03:11 +0000 | [diff] [blame] | 174 |  | 
 | 175 | 	.phy_reset  = true, | 
 | 176 | 	.reset_gpio_port[0]  = HSUSB1_RESET_GPIO, | 
 | 177 | 	.reset_gpio_port[1]  = HSUSB2_RESET_GPIO, | 
 | 178 | 	.reset_gpio_port[2]  = -EINVAL, | 
 | 179 | }; | 
 | 180 |  | 
| Igor Grinberg | 026fe79 | 2011-05-30 00:11:45 -0700 | [diff] [blame] | 181 | static int __init cm_t3517_init_usbh(void) | 
| Igor Grinberg | 525d75b | 2010-09-21 16:03:11 +0000 | [diff] [blame] | 182 | { | 
 | 183 | 	int err; | 
 | 184 |  | 
| Igor Grinberg | bc593f5 | 2011-05-03 18:22:09 +0300 | [diff] [blame] | 185 | 	err = gpio_request_one(USB_HUB_RESET_GPIO, GPIOF_OUT_INIT_LOW, | 
 | 186 | 			       "usb hub rst"); | 
| Igor Grinberg | 525d75b | 2010-09-21 16:03:11 +0000 | [diff] [blame] | 187 | 	if (err) { | 
 | 188 | 		pr_err("CM-T3517: usb hub rst gpio request failed: %d\n", err); | 
 | 189 | 	} else { | 
| Igor Grinberg | 525d75b | 2010-09-21 16:03:11 +0000 | [diff] [blame] | 190 | 		udelay(10); | 
 | 191 | 		gpio_set_value(USB_HUB_RESET_GPIO, 1); | 
 | 192 | 		msleep(1); | 
 | 193 | 	} | 
 | 194 |  | 
| Keshava Munegowda | 9e64bb1 | 2011-03-01 20:08:19 +0530 | [diff] [blame] | 195 | 	usbhs_init(&cm_t3517_ehci_pdata); | 
| Igor Grinberg | 525d75b | 2010-09-21 16:03:11 +0000 | [diff] [blame] | 196 |  | 
 | 197 | 	return 0; | 
 | 198 | } | 
 | 199 | #else | 
 | 200 | static inline int cm_t3517_init_usbh(void) | 
 | 201 | { | 
 | 202 | 	return 0; | 
 | 203 | } | 
 | 204 | #endif | 
 | 205 |  | 
| Igor Grinberg | ec34fcc | 2010-09-21 16:03:12 +0000 | [diff] [blame] | 206 | #if defined(CONFIG_MTD_NAND_OMAP2) || defined(CONFIG_MTD_NAND_OMAP2_MODULE) | 
| Igor Grinberg | ec34fcc | 2010-09-21 16:03:12 +0000 | [diff] [blame] | 207 | static struct mtd_partition cm_t3517_nand_partitions[] = { | 
 | 208 | 	{ | 
 | 209 | 		.name           = "xloader", | 
 | 210 | 		.offset         = 0,			/* Offset = 0x00000 */ | 
 | 211 | 		.size           = 4 * NAND_BLOCK_SIZE, | 
 | 212 | 		.mask_flags     = MTD_WRITEABLE | 
 | 213 | 	}, | 
 | 214 | 	{ | 
 | 215 | 		.name           = "uboot", | 
 | 216 | 		.offset         = MTDPART_OFS_APPEND,	/* Offset = 0x80000 */ | 
 | 217 | 		.size           = 15 * NAND_BLOCK_SIZE, | 
 | 218 | 	}, | 
 | 219 | 	{ | 
 | 220 | 		.name           = "uboot environment", | 
 | 221 | 		.offset         = MTDPART_OFS_APPEND,	/* Offset = 0x260000 */ | 
 | 222 | 		.size           = 2 * NAND_BLOCK_SIZE, | 
 | 223 | 	}, | 
 | 224 | 	{ | 
 | 225 | 		.name           = "linux", | 
| Igor Grinberg | 2216b43 | 2011-01-13 16:24:50 +0000 | [diff] [blame] | 226 | 		.offset         = MTDPART_OFS_APPEND,	/* Offset = 0x2A0000 */ | 
| Igor Grinberg | ec34fcc | 2010-09-21 16:03:12 +0000 | [diff] [blame] | 227 | 		.size           = 32 * NAND_BLOCK_SIZE, | 
 | 228 | 	}, | 
 | 229 | 	{ | 
 | 230 | 		.name           = "rootfs", | 
| Igor Grinberg | 2216b43 | 2011-01-13 16:24:50 +0000 | [diff] [blame] | 231 | 		.offset         = MTDPART_OFS_APPEND,	/* Offset = 0x6A0000 */ | 
| Igor Grinberg | ec34fcc | 2010-09-21 16:03:12 +0000 | [diff] [blame] | 232 | 		.size           = MTDPART_SIZ_FULL, | 
 | 233 | 	}, | 
 | 234 | }; | 
 | 235 |  | 
 | 236 | static struct omap_nand_platform_data cm_t3517_nand_data = { | 
 | 237 | 	.parts			= cm_t3517_nand_partitions, | 
 | 238 | 	.nr_parts		= ARRAY_SIZE(cm_t3517_nand_partitions), | 
 | 239 | 	.dma_channel		= -1,	/* disable DMA in OMAP NAND driver */ | 
 | 240 | 	.cs			= 0, | 
 | 241 | }; | 
 | 242 |  | 
 | 243 | static void __init cm_t3517_init_nand(void) | 
 | 244 | { | 
 | 245 | 	if (gpmc_nand_init(&cm_t3517_nand_data) < 0) | 
 | 246 | 		pr_err("CM-T3517: NAND initialization failed\n"); | 
 | 247 | } | 
 | 248 | #else | 
 | 249 | static inline void cm_t3517_init_nand(void) {} | 
 | 250 | #endif | 
 | 251 |  | 
| Igor Grinberg | d04b620 | 2010-09-21 16:03:09 +0000 | [diff] [blame] | 252 | static struct omap_board_config_kernel cm_t3517_config[] __initdata = { | 
 | 253 | }; | 
 | 254 |  | 
| Russell King - ARM Linux | 3dc3bad | 2011-02-14 15:40:20 -0800 | [diff] [blame] | 255 | static void __init cm_t3517_init_early(void) | 
| Igor Grinberg | d04b620 | 2010-09-21 16:03:09 +0000 | [diff] [blame] | 256 | { | 
| Paul Walmsley | 4805734 | 2010-12-21 15:25:10 -0700 | [diff] [blame] | 257 | 	omap2_init_common_infrastructure(); | 
 | 258 | 	omap2_init_common_devices(NULL, NULL); | 
| Igor Grinberg | d04b620 | 2010-09-21 16:03:09 +0000 | [diff] [blame] | 259 | } | 
 | 260 |  | 
| Tony Lindgren | c7ecea2 | 2011-03-11 11:39:51 -0800 | [diff] [blame] | 261 | #ifdef CONFIG_OMAP_MUX | 
| Igor Grinberg | d04b620 | 2010-09-21 16:03:09 +0000 | [diff] [blame] | 262 | static struct omap_board_mux board_mux[] __initdata = { | 
 | 263 | 	/* GPIO186 - Green LED */ | 
 | 264 | 	OMAP3_MUX(SYS_CLKOUT2, OMAP_MUX_MODE4 | OMAP_PIN_OUTPUT), | 
| Igor Grinberg | fec5568cb | 2011-01-13 16:24:49 +0000 | [diff] [blame] | 265 |  | 
 | 266 | 	/* RTC GPIOs: */ | 
 | 267 | 	/* IO - GPIO153 */ | 
| Igor Grinberg | 46893a5 | 2010-09-21 16:03:10 +0000 | [diff] [blame] | 268 | 	OMAP3_MUX(MCBSP4_DR, OMAP_MUX_MODE4 | OMAP_PIN_INPUT), | 
| Igor Grinberg | fec5568cb | 2011-01-13 16:24:49 +0000 | [diff] [blame] | 269 | 	/* WR# - GPIO154 */ | 
| Igor Grinberg | 46893a5 | 2010-09-21 16:03:10 +0000 | [diff] [blame] | 270 | 	OMAP3_MUX(MCBSP4_DX, OMAP_MUX_MODE4 | OMAP_PIN_INPUT), | 
| Igor Grinberg | fec5568cb | 2011-01-13 16:24:49 +0000 | [diff] [blame] | 271 | 	/* RD# - GPIO53 */ | 
 | 272 | 	OMAP3_MUX(GPMC_NCS2, OMAP_MUX_MODE4 | OMAP_PIN_INPUT), | 
 | 273 | 	/* CS# - GPIO163 */ | 
| Igor Grinberg | 46893a5 | 2010-09-21 16:03:10 +0000 | [diff] [blame] | 274 | 	OMAP3_MUX(UART3_CTS_RCTX, OMAP_MUX_MODE4 | OMAP_PIN_INPUT), | 
| Igor Grinberg | fec5568cb | 2011-01-13 16:24:49 +0000 | [diff] [blame] | 275 | 	/* CS EN - GPIO160 */ | 
 | 276 | 	OMAP3_MUX(MCBSP_CLKS, OMAP_MUX_MODE4 | OMAP_PIN_INPUT), | 
 | 277 |  | 
| Igor Grinberg | 525d75b | 2010-09-21 16:03:11 +0000 | [diff] [blame] | 278 | 	/* HSUSB1 RESET */ | 
 | 279 | 	OMAP3_MUX(UART2_TX, OMAP_MUX_MODE4 | OMAP_PIN_OUTPUT), | 
 | 280 | 	/* HSUSB2 RESET */ | 
 | 281 | 	OMAP3_MUX(UART2_RX, OMAP_MUX_MODE4 | OMAP_PIN_OUTPUT), | 
 | 282 | 	/* CM-T3517 USB HUB nRESET */ | 
 | 283 | 	OMAP3_MUX(MCBSP4_CLKX, OMAP_MUX_MODE4 | OMAP_PIN_OUTPUT), | 
| Igor Grinberg | d04b620 | 2010-09-21 16:03:09 +0000 | [diff] [blame] | 284 |  | 
 | 285 | 	{ .reg_offset = OMAP_MUX_TERMINATOR }, | 
 | 286 | }; | 
| Tony Lindgren | c7ecea2 | 2011-03-11 11:39:51 -0800 | [diff] [blame] | 287 | #endif | 
| Igor Grinberg | d04b620 | 2010-09-21 16:03:09 +0000 | [diff] [blame] | 288 |  | 
 | 289 | static void __init cm_t3517_init(void) | 
 | 290 | { | 
 | 291 | 	omap3_mux_init(board_mux, OMAP_PACKAGE_CBB); | 
 | 292 | 	omap_serial_init(); | 
| Tony Lindgren | e41cccf | 2011-02-24 14:36:03 -0800 | [diff] [blame] | 293 | 	omap_board_config = cm_t3517_config; | 
 | 294 | 	omap_board_config_size = ARRAY_SIZE(cm_t3517_config); | 
| Igor Grinberg | d04b620 | 2010-09-21 16:03:09 +0000 | [diff] [blame] | 295 | 	cm_t3517_init_leds(); | 
| Igor Grinberg | ec34fcc | 2010-09-21 16:03:12 +0000 | [diff] [blame] | 296 | 	cm_t3517_init_nand(); | 
| Igor Grinberg | 46893a5 | 2010-09-21 16:03:10 +0000 | [diff] [blame] | 297 | 	cm_t3517_init_rtc(); | 
| Igor Grinberg | 525d75b | 2010-09-21 16:03:11 +0000 | [diff] [blame] | 298 | 	cm_t3517_init_usbh(); | 
| Igor Grinberg | b6a26b4 | 2010-09-21 16:03:13 +0000 | [diff] [blame] | 299 | 	cm_t3517_init_hecc(); | 
| Igor Grinberg | d04b620 | 2010-09-21 16:03:09 +0000 | [diff] [blame] | 300 | } | 
 | 301 |  | 
 | 302 | MACHINE_START(CM_T3517, "Compulab CM-T3517") | 
| Igor Grinberg | d04b620 | 2010-09-21 16:03:09 +0000 | [diff] [blame] | 303 | 	.boot_params	= 0x80000100, | 
| Igor Grinberg | d04b620 | 2010-09-21 16:03:09 +0000 | [diff] [blame] | 304 | 	.reserve        = omap_reserve, | 
| Russell King - ARM Linux | 3dc3bad | 2011-02-14 15:40:20 -0800 | [diff] [blame] | 305 | 	.map_io		= omap3_map_io, | 
 | 306 | 	.init_early	= cm_t3517_init_early, | 
 | 307 | 	.init_irq	= omap_init_irq, | 
| Igor Grinberg | d04b620 | 2010-09-21 16:03:09 +0000 | [diff] [blame] | 308 | 	.init_machine	= cm_t3517_init, | 
 | 309 | 	.timer		= &omap_timer, | 
 | 310 | MACHINE_END |