Blame view

arch/arm/mach-omap2/board-omap3stalker.c 11.3 KB
9cbc34939   Jason   omap3: Add suppor...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
  /*
   * linux/arch/arm/mach-omap2/board-omap3evm.c
   *
   * Copyright (C) 2008 Guangzhou EMA-Tech
   *
   * Modified from mach-omap2/board-omap3evm.c
   *
   * Initial code: Syed Mohammed Khasim
   *
   * This program is free software; you can redistribute it and/or modify
   * it under the terms of the GNU General Public License version 2 as
   * published by the Free Software Foundation.
   */
  
  #include <linux/kernel.h>
  #include <linux/init.h>
  #include <linux/platform_device.h>
  #include <linux/delay.h>
  #include <linux/err.h>
  #include <linux/clk.h>
  #include <linux/io.h>
  #include <linux/leds.h>
  #include <linux/gpio.h>
  #include <linux/input.h>
  #include <linux/gpio_keys.h>
  
  #include <linux/regulator/machine.h>
  #include <linux/i2c/twl.h>
3a63833ec   Sukumar Ghorai   omap: mmc: extend...
29
  #include <linux/mmc/host.h>
9cbc34939   Jason   omap3: Add suppor...
30
31
32
33
34
35
36
37
  
  #include <mach/hardware.h>
  #include <asm/mach-types.h>
  #include <asm/mach/arch.h>
  #include <asm/mach/map.h>
  #include <asm/mach/flash.h>
  
  #include <plat/board.h>
4e65331c6   Tony Lindgren   ARM: 7159/1: OMAP...
38
  #include "common.h"
9cbc34939   Jason   omap3: Add suppor...
39
40
41
  #include <plat/gpmc.h>
  #include <plat/nand.h>
  #include <plat/usb.h>
a0b38cc4d   Tomi Valkeinen   OMAP: DSS2: Move ...
42
  #include <video/omapdss.h>
f8ae2f08d   Tomi Valkeinen   OMAP: DSS2: Move ...
43
  #include <video/omap-panel-generic-dpi.h>
1d7a8654e   Tomi Valkeinen   OMAP: use dvi pan...
44
  #include <video/omap-panel-dvi.h>
9cbc34939   Jason   omap3: Add suppor...
45
46
47
48
  
  #include <plat/mcspi.h>
  #include <linux/input/matrix_keypad.h>
  #include <linux/spi/spi.h>
9cbc34939   Jason   omap3: Add suppor...
49
50
51
52
53
54
55
  #include <linux/interrupt.h>
  #include <linux/smsc911x.h>
  #include <linux/i2c/at24.h>
  
  #include "sdram-micron-mt46h32m32lf-6.h"
  #include "mux.h"
  #include "hsmmc.h"
96974a249   Mike Rapoport   omap: consolidate...
56
  #include "common-board-devices.h"
9cbc34939   Jason   omap3: Add suppor...
57
58
  
  #if defined(CONFIG_SMSC911X) || defined(CONFIG_SMSC911X_MODULE)
21b42731e   Mike Rapoport   omap: convert boa...
59
  #include <plat/gpmc-smsc911x.h>
9cbc34939   Jason   omap3: Add suppor...
60
61
62
63
  #define OMAP3STALKER_ETHR_START	0x2c000000
  #define OMAP3STALKER_ETHR_SIZE	1024
  #define OMAP3STALKER_ETHR_GPIO_IRQ	19
  #define OMAP3STALKER_SMC911X_CS	5
21b42731e   Mike Rapoport   omap: convert boa...
64
65
66
67
  static struct omap_smsc911x_platform_data smsc911x_cfg = {
  	.cs             = OMAP3STALKER_SMC911X_CS,
  	.gpio_irq       = OMAP3STALKER_ETHR_GPIO_IRQ,
  	.gpio_reset     = -EINVAL,
9cbc34939   Jason   omap3: Add suppor...
68
69
  	.flags		= (SMSC911X_USE_32BIT | SMSC911X_SAVE_MAC_ADDRESS),
  };
9cbc34939   Jason   omap3: Add suppor...
70
71
  static inline void __init omap3stalker_init_eth(void)
  {
9cbc34939   Jason   omap3: Add suppor...
72
73
  	struct clk *l3ck;
  	unsigned int rate;
9cbc34939   Jason   omap3: Add suppor...
74
75
76
77
78
79
80
  	l3ck = clk_get(NULL, "l3_ck");
  	if (IS_ERR(l3ck))
  		rate = 100000000;
  	else
  		rate = clk_get_rate(l3ck);
  
  	omap_mux_init_gpio(19, OMAP_PIN_INPUT_PULLUP);
21b42731e   Mike Rapoport   omap: convert boa...
81
  	gpmc_smsc911x_init(&smsc911x_cfg);
9cbc34939   Jason   omap3: Add suppor...
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
  }
  
  #else
  static inline void __init omap3stalker_init_eth(void)
  {
  	return;
  }
  #endif
  
  /*
   * OMAP3 DSS control signals
   */
  
  #define DSS_ENABLE_GPIO	199
  #define LCD_PANEL_BKLIGHT_GPIO	210
  #define ENABLE_VPLL2_DEV_GRP	0xE0
  
  static int lcd_enabled;
  static int dvi_enabled;
  
  static void __init omap3_stalker_display_init(void)
  {
  	return;
  }
9cbc34939   Jason   omap3: Add suppor...
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
138
139
140
141
142
143
144
  static int omap3_stalker_enable_tv(struct omap_dss_device *dssdev)
  {
  	return 0;
  }
  
  static void omap3_stalker_disable_tv(struct omap_dss_device *dssdev)
  {
  }
  
  static struct omap_dss_device omap3_stalker_tv_device = {
  	.name			= "tv",
  	.driver_name		= "venc",
  	.type			= OMAP_DISPLAY_TYPE_VENC,
  #if defined(CONFIG_OMAP2_VENC_OUT_TYPE_SVIDEO)
  	.phy.venc.type		= OMAP_DSS_VENC_TYPE_SVIDEO,
  #elif defined(CONFIG_OMAP2_VENC_OUT_TYPE_COMPOSITE)
  	.u.venc.type		= OMAP_DSS_VENC_TYPE_COMPOSITE,
  #endif
  	.platform_enable	= omap3_stalker_enable_tv,
  	.platform_disable	= omap3_stalker_disable_tv,
  };
  
  static int omap3_stalker_enable_dvi(struct omap_dss_device *dssdev)
  {
  	if (lcd_enabled) {
  		printk(KERN_ERR "cannot enable DVI, LCD is enabled
  ");
  		return -EINVAL;
  	}
  	gpio_set_value(DSS_ENABLE_GPIO, 1);
  	dvi_enabled = 1;
  	return 0;
  }
  
  static void omap3_stalker_disable_dvi(struct omap_dss_device *dssdev)
  {
  	gpio_set_value(DSS_ENABLE_GPIO, 0);
  	dvi_enabled = 0;
  }
1d7a8654e   Tomi Valkeinen   OMAP: use dvi pan...
145
  static struct panel_dvi_platform_data dvi_panel = {
89747c914   Bryan Wu   OMAP: use generic...
146
147
148
  	.platform_enable	= omap3_stalker_enable_dvi,
  	.platform_disable	= omap3_stalker_disable_dvi,
  };
9cbc34939   Jason   omap3: Add suppor...
149
150
  static struct omap_dss_device omap3_stalker_dvi_device = {
  	.name			= "dvi",
9cbc34939   Jason   omap3: Add suppor...
151
  	.type			= OMAP_DISPLAY_TYPE_DPI,
1d7a8654e   Tomi Valkeinen   OMAP: use dvi pan...
152
  	.driver_name		= "dvi",
89747c914   Bryan Wu   OMAP: use generic...
153
  	.data			= &dvi_panel,
9cbc34939   Jason   omap3: Add suppor...
154
  	.phy.dpi.data_lines	= 24,
9cbc34939   Jason   omap3: Add suppor...
155
156
157
  };
  
  static struct omap_dss_device *omap3_stalker_dss_devices[] = {
9cbc34939   Jason   omap3: Add suppor...
158
159
160
161
162
163
164
165
166
  	&omap3_stalker_tv_device,
  	&omap3_stalker_dvi_device,
  };
  
  static struct omap_dss_board_info omap3_stalker_dss_data = {
  	.num_devices	= ARRAY_SIZE(omap3_stalker_dss_devices),
  	.devices	= omap3_stalker_dss_devices,
  	.default_device	= &omap3_stalker_dvi_device,
  };
786b01a8c   Oleg Drokin   cleanup regulator...
167
168
  static struct regulator_consumer_supply omap3stalker_vmmc1_supply[] = {
  	REGULATOR_SUPPLY("vmmc", "omap_hsmmc.0"),
9cbc34939   Jason   omap3: Add suppor...
169
  };
786b01a8c   Oleg Drokin   cleanup regulator...
170
171
  static struct regulator_consumer_supply omap3stalker_vsim_supply[] = {
  	REGULATOR_SUPPLY("vmmc_aux", "omap_hsmmc.0"),
9cbc34939   Jason   omap3: Add suppor...
172
173
174
175
176
177
178
179
180
181
182
183
  };
  
  /* VMMC1 for MMC1 pins CMD, CLK, DAT0..DAT3 (20 mA, plus card == max 220 mA) */
  static struct regulator_init_data omap3stalker_vmmc1 = {
  	.constraints		= {
  		.min_uV			= 1850000,
  		.max_uV			= 3150000,
  		.valid_modes_mask	= REGULATOR_MODE_NORMAL
  		| REGULATOR_MODE_STANDBY,
  		.valid_ops_mask		= REGULATOR_CHANGE_VOLTAGE
  		| REGULATOR_CHANGE_MODE | REGULATOR_CHANGE_STATUS,
  	},
786b01a8c   Oleg Drokin   cleanup regulator...
184
185
  	.num_consumer_supplies	= ARRAY_SIZE(omap3stalker_vmmc1_supply),
  	.consumer_supplies	= omap3stalker_vmmc1_supply,
9cbc34939   Jason   omap3: Add suppor...
186
187
188
189
190
191
192
193
194
195
196
197
  };
  
  /* VSIM for MMC1 pins DAT4..DAT7 (2 mA, plus card == max 50 mA) */
  static struct regulator_init_data omap3stalker_vsim = {
  	.constraints		= {
  		.min_uV			= 1800000,
  		.max_uV			= 3000000,
  		.valid_modes_mask	= REGULATOR_MODE_NORMAL
  		| REGULATOR_MODE_STANDBY,
  		.valid_ops_mask		= REGULATOR_CHANGE_VOLTAGE
  		| REGULATOR_CHANGE_MODE | REGULATOR_CHANGE_STATUS,
  	},
786b01a8c   Oleg Drokin   cleanup regulator...
198
199
  	.num_consumer_supplies	= ARRAY_SIZE(omap3stalker_vsim_supply),
  	.consumer_supplies	= omap3stalker_vsim_supply,
9cbc34939   Jason   omap3: Add suppor...
200
201
202
203
204
  };
  
  static struct omap2_hsmmc_info mmc[] = {
  	{
  	 .mmc		= 1,
3a63833ec   Sukumar Ghorai   omap: mmc: extend...
205
  	 .caps		= MMC_CAP_4_BIT_DATA,
9cbc34939   Jason   omap3: Add suppor...
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
  	 .gpio_cd	= -EINVAL,
  	 .gpio_wp	= 23,
  	 },
  	{}			/* Terminator */
  };
  
  static struct gpio_keys_button gpio_buttons[] = {
  	{
  	 .code		= BTN_EXTRA,
  	 .gpio		= 18,
  	 .desc		= "user",
  	 .wakeup	= 1,
  	 },
  };
  
  static struct gpio_keys_platform_data gpio_key_info = {
  	.buttons	= gpio_buttons,
  	.nbuttons	= ARRAY_SIZE(gpio_buttons),
  };
  
  static struct platform_device keys_gpio = {
  	.name		= "gpio-keys",
  	.id		= -1,
  	.dev		= {
  		.platform_data	= &gpio_key_info,
  	},
  };
  
  static struct gpio_led gpio_leds[] = {
  	{
  	 .name			= "stalker:D8:usr0",
  	 .default_trigger	= "default-on",
  	 .gpio			= 126,
  	 },
  	{
  	 .name			= "stalker:D9:usr1",
  	 .default_trigger	= "default-on",
  	 .gpio			= 127,
  	 },
  	{
  	 .name			= "stalker:D3:mmc0",
  	 .gpio			= -EINVAL,	/* gets replaced */
  	 .active_low		= true,
  	 .default_trigger	= "mmc0",
  	 },
  	{
  	 .name			= "stalker:D4:heartbeat",
  	 .gpio			= -EINVAL,	/* gets replaced */
  	 .active_low		= true,
  	 .default_trigger	= "heartbeat",
  	 },
  };
  
  static struct gpio_led_platform_data gpio_led_info = {
  	.leds		= gpio_leds,
  	.num_leds	= ARRAY_SIZE(gpio_leds),
  };
  
  static struct platform_device leds_gpio = {
  	.name	= "leds-gpio",
  	.id	= -1,
  	.dev	= {
  		.platform_data	= &gpio_led_info,
  	},
  };
  
  static int
  omap3stalker_twl_gpio_setup(struct device *dev,
  			    unsigned gpio, unsigned ngpio)
  {
  	/* gpio + 0 is "mmc0_cd" (input/IRQ) */
  	omap_mux_init_gpio(23, OMAP_PIN_INPUT);
  	mmc[0].gpio_cd = gpio + 0;
  	omap2_hsmmc_init(mmc);
9cbc34939   Jason   omap3: Add suppor...
280
281
282
283
284
285
  	/*
  	 * Most GPIOs are for USB OTG.  Some are mostly sent to
  	 * the P2 connector; notably LEDA for the LCD backlight.
  	 */
  
  	/* TWL4030_GPIO_MAX + 0 == ledA, LCD Backlight control */
bc593f5d7   Igor Grinberg   arm: omap2plus: G...
286
287
  	gpio_request_one(gpio + TWL4030_GPIO_MAX, GPIOF_OUT_INIT_LOW,
  			 "EN_LCD_BKL");
9cbc34939   Jason   omap3: Add suppor...
288
289
  
  	/* gpio + 7 == DVI Enable */
bc593f5d7   Igor Grinberg   arm: omap2plus: G...
290
  	gpio_request_one(gpio + 7, GPIOF_OUT_INIT_LOW, "EN_DVI");
9cbc34939   Jason   omap3: Add suppor...
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
  
  	/* TWL4030_GPIO_MAX + 1 == ledB (out, mmc0) */
  	gpio_leds[2].gpio = gpio + TWL4030_GPIO_MAX + 1;
  	/* GPIO + 13 == ledsync (out, heartbeat) */
  	gpio_leds[3].gpio = gpio + 13;
  
  	platform_device_register(&leds_gpio);
  	return 0;
  }
  
  static struct twl4030_gpio_platform_data omap3stalker_gpio_data = {
  	.gpio_base	= OMAP_MAX_GPIO_LINES,
  	.irq_base	= TWL4030_GPIO_IRQ_BASE,
  	.irq_end	= TWL4030_GPIO_IRQ_END,
  	.use_leds	= true,
  	.setup		= omap3stalker_twl_gpio_setup,
  };
bead43757   Manjunath Kondaiah G   OMAP3: Keypad: Fi...
308
  static uint32_t board_keymap[] = {
9cbc34939   Jason   omap3: Add suppor...
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
  	KEY(0, 0, KEY_LEFT),
  	KEY(0, 1, KEY_DOWN),
  	KEY(0, 2, KEY_ENTER),
  	KEY(0, 3, KEY_M),
  
  	KEY(1, 0, KEY_RIGHT),
  	KEY(1, 1, KEY_UP),
  	KEY(1, 2, KEY_I),
  	KEY(1, 3, KEY_N),
  
  	KEY(2, 0, KEY_A),
  	KEY(2, 1, KEY_E),
  	KEY(2, 2, KEY_J),
  	KEY(2, 3, KEY_O),
  
  	KEY(3, 0, KEY_B),
  	KEY(3, 1, KEY_F),
  	KEY(3, 2, KEY_K),
  	KEY(3, 3, KEY_P)
  };
  
  static struct matrix_keymap_data board_map_data = {
  	.keymap		= board_keymap,
  	.keymap_size	= ARRAY_SIZE(board_keymap),
  };
  
  static struct twl4030_keypad_data omap3stalker_kp_data = {
  	.keymap_data	= &board_map_data,
  	.rows		= 4,
  	.cols		= 4,
  	.rep		= 1,
  };
9cbc34939   Jason   omap3: Add suppor...
341
  static struct twl4030_platform_data omap3stalker_twldata = {
9cbc34939   Jason   omap3: Add suppor...
342
343
  	/* platform_data for children goes here */
  	.keypad		= &omap3stalker_kp_data,
9cbc34939   Jason   omap3: Add suppor...
344
  	.gpio		= &omap3stalker_gpio_data,
fbd8071c1   Mike Rapoport   omap: use common ...
345
346
  	.vmmc1		= &omap3stalker_vmmc1,
  	.vsim		= &omap3stalker_vsim,
9cbc34939   Jason   omap3: Add suppor...
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
  };
  
  static struct at24_platform_data fram_info = {
  	.byte_len	= (64 * 1024) / 8,
  	.page_size	= 8192,
  	.flags		= AT24_FLAG_ADDR16 | AT24_FLAG_IRUGO,
  };
  
  static struct i2c_board_info __initdata omap3stalker_i2c_boardinfo3[] = {
  	{
  	 I2C_BOARD_INFO("24c64", 0x50),
  	 .flags		= I2C_CLIENT_WAKE,
  	 .platform_data	= &fram_info,
  	 },
  };
  
  static int __init omap3_stalker_i2c_init(void)
  {
827ed9aef   Peter Ujfalusi   OMAP3: Move commo...
365
366
  	omap3_pmic_get_config(&omap3stalker_twldata,
  			TWL_COMMON_PDATA_USB | TWL_COMMON_PDATA_MADC |
b252b0efb   Peter Ujfalusi   OMAP3: Move commo...
367
368
369
370
371
372
  			TWL_COMMON_PDATA_AUDIO,
  			TWL_COMMON_REGULATOR_VDAC | TWL_COMMON_REGULATOR_VPLL2);
  
  	omap3stalker_twldata.vdac->constraints.apply_uV = true;
  	omap3stalker_twldata.vpll2->constraints.apply_uV = true;
  	omap3stalker_twldata.vpll2->constraints.name = "VDVI";
fbd8071c1   Mike Rapoport   omap: use common ...
373
  	omap3_pmic_init("twl4030", &omap3stalker_twldata);
9cbc34939   Jason   omap3: Add suppor...
374
375
376
377
378
379
380
  	omap_register_i2c_bus(2, 400, NULL, 0);
  	omap_register_i2c_bus(3, 400, omap3stalker_i2c_boardinfo3,
  			      ARRAY_SIZE(omap3stalker_i2c_boardinfo3));
  	return 0;
  }
  
  #define OMAP3_STALKER_TS_GPIO	175
9cbc34939   Jason   omap3: Add suppor...
381
382
383
  
  static struct omap_board_config_kernel omap3_stalker_config[] __initdata = {
  };
9cbc34939   Jason   omap3: Add suppor...
384
  static struct platform_device *omap3_stalker_devices[] __initdata = {
9cbc34939   Jason   omap3: Add suppor...
385
386
  	&keys_gpio,
  };
181b250cf   Keshava Munegowda   arm: omap: usb: c...
387
388
389
390
  static struct usbhs_omap_board_data usbhs_bdata __initconst = {
  	.port_mode[0] = OMAP_USBHS_PORT_MODE_UNUSED,
  	.port_mode[1] = OMAP_EHCI_PORT_MODE_PHY,
  	.port_mode[2] = OMAP_USBHS_PORT_MODE_UNUSED,
9cbc34939   Jason   omap3: Add suppor...
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
  
  	.phy_reset = true,
  	.reset_gpio_port[0] = -EINVAL,
  	.reset_gpio_port[1] = 21,
  	.reset_gpio_port[2] = -EINVAL,
  };
  
  #ifdef CONFIG_OMAP_MUX
  static struct omap_board_mux board_mux[] __initdata = {
  	OMAP3_MUX(SYS_NIRQ, OMAP_MUX_MODE0 | OMAP_PIN_INPUT_PULLUP |
  		  OMAP_PIN_OFF_INPUT_PULLUP | OMAP_PIN_OFF_WAKEUPENABLE),
  	OMAP3_MUX(MCSPI1_CS1, OMAP_MUX_MODE4 | OMAP_PIN_INPUT_PULLUP |
  		  OMAP_PIN_OFF_INPUT_PULLUP | OMAP_PIN_OFF_WAKEUPENABLE),
  	{.reg_offset = OMAP_MUX_TERMINATOR},
  };
9cbc34939   Jason   omap3: Add suppor...
406
  #endif
9cbc34939   Jason   omap3: Add suppor...
407
408
409
  static void __init omap3_stalker_init(void)
  {
  	omap3_mux_init(board_mux, OMAP_PACKAGE_CUS);
e41cccfe7   Tony Lindgren   omap2+: Minimize ...
410
411
  	omap_board_config = omap3_stalker_config;
  	omap_board_config_size = ARRAY_SIZE(omap3_stalker_config);
9cbc34939   Jason   omap3: Add suppor...
412
413
414
415
416
  
  	omap3_stalker_i2c_init();
  
  	platform_add_devices(omap3_stalker_devices,
  			     ARRAY_SIZE(omap3_stalker_devices));
d5e13227c   Senthilvadivu Guruswamy   OMAP2, 3: DSS2: b...
417
  	omap_display_init(&omap3_stalker_dss_data);
9cbc34939   Jason   omap3: Add suppor...
418
419
  
  	omap_serial_init();
a4ca9dbe4   Tony Lindgren   ARM: OMAP: Move o...
420
  	omap_sdrc_init(mt46h32m32lf6_sdrc_params, NULL);
9e18630b6   Mike Rapoport   omap: musb: intro...
421
  	usb_musb_init(NULL);
9e64bb1e9   Keshava Munegowda   arm: omap: usb: I...
422
  	usbhs_init(&usbhs_bdata);
96974a249   Mike Rapoport   omap: consolidate...
423
  	omap_ads7846_init(1, OMAP3_STALKER_TS_GPIO, 310, NULL);
9cbc34939   Jason   omap3: Add suppor...
424
425
426
427
428
429
430
431
432
433
  
  	omap_mux_init_gpio(21, OMAP_PIN_OUTPUT);
  	omap_mux_init_gpio(18, OMAP_PIN_INPUT_PULLUP);
  
  	omap3stalker_init_eth();
  	omap3_stalker_display_init();
  /* Ensure SDRC pins are mux'd for self-refresh */
  	omap_mux_init_signal("sdr_cke0", OMAP_PIN_OUTPUT);
  	omap_mux_init_signal("sdr_cke1", OMAP_PIN_OUTPUT);
  }
9cbc34939   Jason   omap3: Add suppor...
434
435
  MACHINE_START(SBC3530, "OMAP3 STALKER")
  	/* Maintainer: Jason Lam -lzg@ema-tech.com */
5e52b435b   Nicolas Pitre   ARM: mach-omap2: ...
436
  	.atag_offset		= 0x100,
869fef415   Mike Rapoport   omap3: introduce ...
437
  	.map_io			= omap3_map_io,
8f5b5a41e   Tony Lindgren   ARM: OMAP: Introd...
438
  	.init_early		= omap35xx_init_early,
be7324605   Tony Lindgren   ARM: OMAP2+: Remo...
439
  	.init_irq		= omap3_init_irq,
6b2f55d78   Marc Zyngier   ARM: omap2plus: c...
440
  	.handle_irq		= omap3_intc_handle_irq,
9cbc34939   Jason   omap3: Add suppor...
441
  	.init_machine		= omap3_stalker_init,
e74984e46   Tony Lindgren   omap: Set separat...
442
  	.timer			= &omap3_secure_timer,
baa958834   Russell King   ARM: restart: oma...
443
  	.restart		= omap_prcm_restart,
9cbc34939   Jason   omap3: Add suppor...
444
  MACHINE_END