blob: 95b384d54f8aa847ff2c07b0cb33d3c94a2b1e64 [file] [log] [blame]
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -08001/*
2 * linux/arch/arm/mach-omap2/board-2430sdp.c
3 *
4 * Copyright (C) 2006 Texas Instruments
5 *
6 * Modified from mach-omap2/board-generic.c
7 *
8 * Initial Code : Based on a patch from Komal Shah and Richard Woodruff
9 * Updated the Code for 2430 SDP : Syed Mohammed Khasim
10 *
11 * This program is free software; you can redistribute it and/or modify
12 * it under the terms of the GNU General Public License version 2 as
13 * published by the Free Software Foundation.
14 */
15
16#include <linux/kernel.h>
17#include <linux/init.h>
18#include <linux/platform_device.h>
19#include <linux/mtd/mtd.h>
20#include <linux/mtd/partitions.h>
Ladislav Michl561b0362010-02-15 10:03:32 -080021#include <linux/mtd/physmap.h>
Sukumar Ghorai3a638332010-09-15 14:49:23 +000022#include <linux/mmc/host.h>
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -080023#include <linux/delay.h>
Santosh Shilimkarb07682b2009-12-13 20:05:51 +010024#include <linux/i2c/twl.h>
Balaji T Kd3f02fc2011-02-07 16:08:47 +000025#include <linux/regulator/machine.h>
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -080026#include <linux/err.h>
27#include <linux/clk.h>
Russell Kingfced80c2008-09-06 12:10:45 +010028#include <linux/io.h>
Axel Linf9fa1bb2011-05-31 20:55:44 +080029#include <linux/gpio.h>
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -080030
Russell Kinga09e64f2008-08-05 16:14:15 +010031#include <mach/hardware.h>
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -080032#include <asm/mach-types.h>
33#include <asm/mach/arch.h>
34#include <asm/mach/map.h>
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -080035
Tony Lindgren4e653312011-11-10 22:45:17 +010036#include "common.h"
Tony Lindgrence491cf2009-10-20 09:40:47 -070037#include <plat/gpmc.h>
38#include <plat/usb.h>
Tony Lindgren60628152012-09-20 11:41:43 -070039#include "gpmc-smc91x.h"
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -080040
Tomi Valkeinen6e896ff2011-04-19 19:23:05 +030041#include <video/omapdss.h>
42#include <video/omap-panel-generic-dpi.h>
43
Tony Lindgren369ed782010-07-05 16:31:38 +030044#include "mux.h"
Adrian Hunterd02a900b2010-02-15 10:03:34 -080045#include "hsmmc.h"
Mike Rapoportfbd80712011-04-25 01:09:06 +030046#include "common-board-devices.h"
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -080047
Tony Lindgrena362fdb2009-03-23 18:07:35 -070048#define SDP2430_CS0_BASE 0x04000000
Imre Deak7d8e9672009-05-28 13:23:53 -070049#define SECONDARY_LCD_GPIO 147
Tony Lindgrena362fdb2009-03-23 18:07:35 -070050
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -080051static struct mtd_partition sdp2430_partitions[] = {
52 /* bootloader (U-Boot, etc) in first sector */
53 {
54 .name = "bootloader",
55 .offset = 0,
56 .size = SZ_256K,
57 .mask_flags = MTD_WRITEABLE, /* force read-only */
58 },
59 /* bootloader params in the next sector */
60 {
61 .name = "params",
62 .offset = MTDPART_OFS_APPEND,
63 .size = SZ_128K,
64 .mask_flags = 0,
65 },
66 /* kernel */
67 {
68 .name = "kernel",
69 .offset = MTDPART_OFS_APPEND,
70 .size = SZ_2M,
71 .mask_flags = 0
72 },
73 /* file system */
74 {
75 .name = "filesystem",
76 .offset = MTDPART_OFS_APPEND,
77 .size = MTDPART_SIZ_FULL,
78 .mask_flags = 0
79 }
80};
81
Ladislav Michl561b0362010-02-15 10:03:32 -080082static struct physmap_flash_data sdp2430_flash_data = {
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -080083 .width = 2,
84 .parts = sdp2430_partitions,
85 .nr_parts = ARRAY_SIZE(sdp2430_partitions),
86};
87
88static struct resource sdp2430_flash_resource = {
89 .start = SDP2430_CS0_BASE,
90 .end = SDP2430_CS0_BASE + SZ_64M - 1,
91 .flags = IORESOURCE_MEM,
92};
93
94static struct platform_device sdp2430_flash_device = {
Ladislav Michl561b0362010-02-15 10:03:32 -080095 .name = "physmap-flash",
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -080096 .id = 0,
97 .dev = {
98 .platform_data = &sdp2430_flash_data,
99 },
100 .num_resources = 1,
101 .resource = &sdp2430_flash_resource,
102};
103
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -0800104static struct platform_device *sdp2430_devices[] __initdata = {
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -0800105 &sdp2430_flash_device,
Tomi Valkeinen6e896ff2011-04-19 19:23:05 +0300106};
107
108/* LCD */
109#define SDP2430_LCD_PANEL_BACKLIGHT_GPIO 91
110#define SDP2430_LCD_PANEL_ENABLE_GPIO 154
111
112static int sdp2430_panel_enable_lcd(struct omap_dss_device *dssdev)
113{
114 gpio_direction_output(SDP2430_LCD_PANEL_ENABLE_GPIO, 1);
115 gpio_direction_output(SDP2430_LCD_PANEL_BACKLIGHT_GPIO, 1);
116
117 return 0;
118}
119
120static void sdp2430_panel_disable_lcd(struct omap_dss_device *dssdev)
121{
122 gpio_direction_output(SDP2430_LCD_PANEL_ENABLE_GPIO, 0);
123 gpio_direction_output(SDP2430_LCD_PANEL_BACKLIGHT_GPIO, 0);
124}
125
126static struct panel_generic_dpi_data sdp2430_panel_data = {
127 .name = "nec_nl2432dr22-11b",
128 .platform_enable = sdp2430_panel_enable_lcd,
129 .platform_disable = sdp2430_panel_disable_lcd,
130};
131
132static struct omap_dss_device sdp2430_lcd_device = {
133 .name = "lcd",
134 .driver_name = "generic_dpi_panel",
135 .type = OMAP_DISPLAY_TYPE_DPI,
136 .phy.dpi.data_lines = 16,
137 .data = &sdp2430_panel_data,
138};
139
140static struct omap_dss_device *sdp2430_dss_devices[] = {
Imre Deak7d8e9672009-05-28 13:23:53 -0700141 &sdp2430_lcd_device,
142};
143
Tomi Valkeinen6e896ff2011-04-19 19:23:05 +0300144static struct omap_dss_board_info sdp2430_dss_data = {
145 .num_devices = ARRAY_SIZE(sdp2430_dss_devices),
146 .devices = sdp2430_dss_devices,
147 .default_device = &sdp2430_lcd_device,
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -0800148};
149
Tomi Valkeinen6e896ff2011-04-19 19:23:05 +0300150static void __init sdp2430_display_init(void)
151{
152 int r;
153
154 static struct gpio gpios[] __initdata = {
155 { SDP2430_LCD_PANEL_ENABLE_GPIO, GPIOF_OUT_INIT_LOW,
156 "LCD reset" },
157 { SDP2430_LCD_PANEL_BACKLIGHT_GPIO, GPIOF_OUT_INIT_LOW,
158 "LCD Backlight" },
159 };
160
161 r = gpio_request_array(gpios, ARRAY_SIZE(gpios));
162 if (r) {
163 pr_err("Cannot request LCD GPIOs, error %d\n", r);
164 return;
165 }
166
167 omap_display_init(&sdp2430_dss_data);
168}
169
Tony Lindgren1a48e152009-05-28 13:23:52 -0700170#if defined(CONFIG_SMC91X) || defined(CONFIG_SMC91x_MODULE)
171
172static struct omap_smc91x_platform_data board_smc91x_data = {
173 .cs = 5,
174 .gpio_irq = 149,
175 .flags = GPMC_MUX_ADD_DATA | GPMC_TIMINGS_SMC91C96 |
176 IORESOURCE_IRQ_LOWLEVEL,
177
178};
179
180static void __init board_smc91x_init(void)
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -0800181{
Tony Lindgren25d6f632010-08-02 14:21:39 +0300182 omap_mux_init_gpio(149, OMAP_PIN_INPUT);
Tony Lindgren1a48e152009-05-28 13:23:52 -0700183 gpmc_smc91x_init(&board_smc91x_data);
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -0800184}
185
Tony Lindgren1a48e152009-05-28 13:23:52 -0700186#else
187
188static inline void board_smc91x_init(void)
189{
190}
191
192#endif
193
Balaji T Kd3f02fc2011-02-07 16:08:47 +0000194static struct regulator_consumer_supply sdp2430_vmmc1_supplies[] = {
Kishore Kadiyala0005ae72011-02-28 20:48:05 +0530195 REGULATOR_SUPPLY("vmmc", "omap_hsmmc.0"),
Balaji T Kd3f02fc2011-02-07 16:08:47 +0000196};
197
198/* VMMC1 for OMAP VDD_MMC1 (i/o) and MMC1 card */
199static struct regulator_init_data sdp2430_vmmc1 = {
200 .constraints = {
201 .min_uV = 1850000,
202 .max_uV = 3150000,
203 .valid_modes_mask = REGULATOR_MODE_NORMAL
204 | REGULATOR_MODE_STANDBY,
205 .valid_ops_mask = REGULATOR_CHANGE_VOLTAGE
206 | REGULATOR_CHANGE_MODE
207 | REGULATOR_CHANGE_STATUS,
208 },
209 .num_consumer_supplies = ARRAY_SIZE(sdp2430_vmmc1_supplies),
210 .consumer_supplies = &sdp2430_vmmc1_supplies[0],
211};
212
Tony Lindgren90c62bf2008-12-10 17:37:17 -0800213static struct twl4030_gpio_platform_data sdp2430_gpio_data = {
Tony Lindgren90c62bf2008-12-10 17:37:17 -0800214};
215
216static struct twl4030_platform_data sdp2430_twldata = {
Tony Lindgren90c62bf2008-12-10 17:37:17 -0800217 /* platform_data for children goes here */
218 .gpio = &sdp2430_gpio_data,
Balaji T Kd3f02fc2011-02-07 16:08:47 +0000219 .vmmc1 = &sdp2430_vmmc1,
Tony Lindgren90c62bf2008-12-10 17:37:17 -0800220};
221
Viral Mehta39ecc702010-05-10 14:29:15 -0700222static struct i2c_board_info __initdata sdp2430_i2c1_boardinfo[] = {
223 {
224 I2C_BOARD_INFO("isp1301_omap", 0x2D),
225 .flags = I2C_CLIENT_WAKE,
Viral Mehta39ecc702010-05-10 14:29:15 -0700226 },
227};
228
Tony Lindgren90c62bf2008-12-10 17:37:17 -0800229static int __init omap2430_i2c_init(void)
230{
Tarun Kanti DebBarma46a0a542012-03-29 08:41:01 -0700231 sdp2430_i2c1_boardinfo[0].irq = gpio_to_irq(78);
Viral Mehta39ecc702010-05-10 14:29:15 -0700232 omap_register_i2c_bus(1, 100, sdp2430_i2c1_boardinfo,
233 ARRAY_SIZE(sdp2430_i2c1_boardinfo));
Tony Lindgren7d7e1eb2012-08-27 17:43:01 -0700234 omap_pmic_init(2, 100, "twl4030", 7 + OMAP_INTC_START,
Tony Lindgrenbfd46a52011-09-30 11:05:55 -0700235 &sdp2430_twldata);
Tony Lindgren90c62bf2008-12-10 17:37:17 -0800236 return 0;
237}
238
Adrian Hunter68ff0422010-02-15 10:03:34 -0800239static struct omap2_hsmmc_info mmc[] __initdata = {
Tony Lindgren90c62bf2008-12-10 17:37:17 -0800240 {
241 .mmc = 1,
Sukumar Ghorai3a638332010-09-15 14:49:23 +0000242 .caps = MMC_CAP_4_BIT_DATA,
Tony Lindgren90c62bf2008-12-10 17:37:17 -0800243 .gpio_cd = -EINVAL,
244 .gpio_wp = -EINVAL,
245 .ext_clock = 1,
246 },
247 {} /* Terminator */
248};
249
Tony Lindgren369ed782010-07-05 16:31:38 +0300250#ifdef CONFIG_OMAP_MUX
251static struct omap_board_mux board_mux[] __initdata = {
252 { .reg_offset = OMAP_MUX_TERMINATOR },
253};
Tony Lindgren369ed782010-07-05 16:31:38 +0300254#endif
255
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -0800256static void __init omap_2430sdp_init(void)
257{
Tony Lindgren369ed782010-07-05 16:31:38 +0300258 omap2430_mux_init(board_mux, OMAP_PACKAGE_ZAC);
259
Tony Lindgren90c62bf2008-12-10 17:37:17 -0800260 omap2430_i2c_init();
261
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -0800262 platform_add_devices(sdp2430_devices, ARRAY_SIZE(sdp2430_devices));
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -0800263 omap_serial_init();
Tony Lindgrena4ca9db2011-08-22 23:57:23 -0700264 omap_sdrc_init(NULL, NULL);
Tony Lindgren3b972bf2012-02-20 09:43:29 -0800265 omap_hsmmc_init(mmc);
Tony Lindgren58310ac2010-07-05 16:31:39 +0300266
267 omap_mux_init_signal("usb0hs_stp", OMAP_PULL_ENA | OMAP_PULL_UP);
Mike Rapoport9e186302011-04-27 11:56:12 +0300268 usb_musb_init(NULL);
Tony Lindgren58310ac2010-07-05 16:31:39 +0300269
Tony Lindgren1a48e152009-05-28 13:23:52 -0700270 board_smc91x_init();
Imre Deak7d8e9672009-05-28 13:23:53 -0700271
272 /* Turn off secondary LCD backlight */
Igor Grinbergbc593f52011-05-03 18:22:09 +0300273 gpio_request_one(SECONDARY_LCD_GPIO, GPIOF_OUT_INIT_LOW,
274 "Secondary LCD backlight");
Tomi Valkeinen6e896ff2011-04-19 19:23:05 +0300275
276 sdp2430_display_init();
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -0800277}
278
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -0800279MACHINE_START(OMAP_2430SDP, "OMAP2430 sdp2430 board")
280 /* Maintainer: Syed Khasim - Texas Instruments Inc */
Nicolas Pitre5e52b432011-07-05 22:38:15 -0400281 .atag_offset = 0x100,
Russell King71ee7da2010-05-23 10:18:16 +0100282 .reserve = omap_reserve,
Tony Lindgrene990a402011-09-26 14:52:55 -0700283 .map_io = omap243x_map_io,
Tony Lindgren8f5b5a42011-08-22 23:57:24 -0700284 .init_early = omap2430_init_early,
Tony Lindgren741e3a82011-05-17 03:51:26 -0700285 .init_irq = omap2_init_irq,
Marc Zyngier6b2f55d2011-09-06 10:23:45 +0100286 .handle_irq = omap2_intc_handle_irq,
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -0800287 .init_machine = omap_2430sdp_init,
Shawn Guobbd707a2012-04-26 16:06:50 +0800288 .init_late = omap2430_init_late,
Tony Lindgrene74984e2011-03-29 15:54:48 -0700289 .timer = &omap2_timer,
Russell Kingbaa95882011-11-05 17:06:28 +0000290 .restart = omap_prcm_restart,
Syed Mohammed Khasim72d0f1c2006-12-06 17:14:05 -0800291MACHINE_END