diff options
author | Kuninori Morimoto <morimoto.kuninori@renesas.com> | 2010-03-29 02:31:36 -0400 |
---|---|---|
committer | Paul Mundt <lethal@linux-sh.org> | 2010-04-07 03:26:53 -0400 |
commit | 819ee86796ae263cd76dd734085dab70d1250cdb (patch) | |
tree | 8828864aa56406f1e7391453dfd130483f0cb1fa /arch | |
parent | 4eea423a4567937dc5e0abdc72bd21b546180459 (diff) |
ARM: mach-shmobile: Add SDHI support
This patch add SDHI support for G4 board.
Current gpio frame work doesn't have
the method to control only pull-up/down/free.
So, it have special gpio_pull_up function for SDHI.
It is quick hack, so this function should be replaced
by correct gpio frame work in future.
Signed-off-by: Kuninori Morimoto <morimoto.kuninori@renesas.com>
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/arm/mach-shmobile/board-g4evm.c | 127 |
1 files changed, 127 insertions, 0 deletions
diff --git a/arch/arm/mach-shmobile/board-g4evm.c b/arch/arm/mach-shmobile/board-g4evm.c index 10673a90be52..33441d58cfa6 100644 --- a/arch/arm/mach-shmobile/board-g4evm.c +++ b/arch/arm/mach-shmobile/board-g4evm.c | |||
@@ -30,6 +30,7 @@ | |||
30 | #include <linux/io.h> | 30 | #include <linux/io.h> |
31 | #include <linux/input.h> | 31 | #include <linux/input.h> |
32 | #include <linux/input/sh_keysc.h> | 32 | #include <linux/input/sh_keysc.h> |
33 | #include <linux/mfd/sh_mobile_sdhi.h> | ||
33 | #include <linux/gpio.h> | 34 | #include <linux/gpio.h> |
34 | #include <mach/sh7377.h> | 35 | #include <mach/sh7377.h> |
35 | #include <mach/common.h> | 36 | #include <mach/common.h> |
@@ -37,6 +38,31 @@ | |||
37 | #include <asm/mach/arch.h> | 38 | #include <asm/mach/arch.h> |
38 | #include <asm/mach/map.h> | 39 | #include <asm/mach/map.h> |
39 | 40 | ||
41 | /* | ||
42 | * SDHI | ||
43 | * | ||
44 | * SDHI0 : card detection is possible | ||
45 | * SDHI1 : card detection is impossible | ||
46 | * | ||
47 | * [G4-MAIN-BOARD] | ||
48 | * JP74 : short # DBG_2V8A for SDHI0 | ||
49 | * JP75 : NC # DBG_3V3A for SDHI0 | ||
50 | * JP76 : NC # DBG_3V3A_SD for SDHI0 | ||
51 | * JP77 : NC # 3V3A_SDIO for SDHI1 | ||
52 | * JP78 : short # DBG_2V8A for SDHI1 | ||
53 | * JP79 : NC # DBG_3V3A for SDHI1 | ||
54 | * JP80 : NC # DBG_3V3A_SD for SDHI1 | ||
55 | * | ||
56 | * [G4-CORE-BOARD] | ||
57 | * S32 : all off # to dissever from G3-CORE_DBG board | ||
58 | * S33 : all off # to dissever from G3-CORE_DBG board | ||
59 | * | ||
60 | * [G3-CORE_DBG-BOARD] | ||
61 | * S1 : all off # to dissever from G3-CORE_DBG board | ||
62 | * S3 : all off # to dissever from G3-CORE_DBG board | ||
63 | * S4 : all off # to dissever from G3-CORE_DBG board | ||
64 | */ | ||
65 | |||
40 | static struct mtd_partition nor_flash_partitions[] = { | 66 | static struct mtd_partition nor_flash_partitions[] = { |
41 | { | 67 | { |
42 | .name = "loader", | 68 | .name = "loader", |
@@ -169,10 +195,53 @@ static struct platform_device keysc_device = { | |||
169 | }, | 195 | }, |
170 | }; | 196 | }; |
171 | 197 | ||
198 | /* SDHI */ | ||
199 | static struct resource sdhi0_resources[] = { | ||
200 | [0] = { | ||
201 | .name = "SDHI0", | ||
202 | .start = 0xe6d50000, | ||
203 | .end = 0xe6d501ff, | ||
204 | .flags = IORESOURCE_MEM, | ||
205 | }, | ||
206 | [1] = { | ||
207 | .start = 96, | ||
208 | .flags = IORESOURCE_IRQ, | ||
209 | }, | ||
210 | }; | ||
211 | |||
212 | static struct platform_device sdhi0_device = { | ||
213 | .name = "sh_mobile_sdhi", | ||
214 | .num_resources = ARRAY_SIZE(sdhi0_resources), | ||
215 | .resource = sdhi0_resources, | ||
216 | .id = 0, | ||
217 | }; | ||
218 | |||
219 | static struct resource sdhi1_resources[] = { | ||
220 | [0] = { | ||
221 | .name = "SDHI1", | ||
222 | .start = 0xe6d60000, | ||
223 | .end = 0xe6d601ff, | ||
224 | .flags = IORESOURCE_MEM, | ||
225 | }, | ||
226 | [1] = { | ||
227 | .start = 100, | ||
228 | .flags = IORESOURCE_IRQ, | ||
229 | }, | ||
230 | }; | ||
231 | |||
232 | static struct platform_device sdhi1_device = { | ||
233 | .name = "sh_mobile_sdhi", | ||
234 | .num_resources = ARRAY_SIZE(sdhi1_resources), | ||
235 | .resource = sdhi1_resources, | ||
236 | .id = 1, | ||
237 | }; | ||
238 | |||
172 | static struct platform_device *g4evm_devices[] __initdata = { | 239 | static struct platform_device *g4evm_devices[] __initdata = { |
173 | &nor_flash_device, | 240 | &nor_flash_device, |
174 | &usb_host_device, | 241 | &usb_host_device, |
175 | &keysc_device, | 242 | &keysc_device, |
243 | &sdhi0_device, | ||
244 | &sdhi1_device, | ||
176 | }; | 245 | }; |
177 | 246 | ||
178 | static struct map_desc g4evm_io_desc[] __initdata = { | 247 | static struct map_desc g4evm_io_desc[] __initdata = { |
@@ -197,6 +266,36 @@ static void __init g4evm_map_io(void) | |||
197 | shmobile_setup_console(); | 266 | shmobile_setup_console(); |
198 | } | 267 | } |
199 | 268 | ||
269 | #define GPIO_SDHID0_D0 0xe60520fc | ||
270 | #define GPIO_SDHID0_D1 0xe60520fd | ||
271 | #define GPIO_SDHID0_D2 0xe60520fe | ||
272 | #define GPIO_SDHID0_D3 0xe60520ff | ||
273 | #define GPIO_SDHICMD0 0xe6052100 | ||
274 | |||
275 | #define GPIO_SDHID1_D0 0xe6052103 | ||
276 | #define GPIO_SDHID1_D1 0xe6052104 | ||
277 | #define GPIO_SDHID1_D2 0xe6052105 | ||
278 | #define GPIO_SDHID1_D3 0xe6052106 | ||
279 | #define GPIO_SDHICMD1 0xe6052107 | ||
280 | |||
281 | /* | ||
282 | * FIXME !! | ||
283 | * | ||
284 | * gpio_pull_up is quick_hack. | ||
285 | * | ||
286 | * current gpio frame work doesn't have | ||
287 | * the method to control only pull up/down/free. | ||
288 | * this function should be replaced by correct gpio function | ||
289 | */ | ||
290 | static void __init gpio_pull_up(u32 addr) | ||
291 | { | ||
292 | u8 data = __raw_readb(addr); | ||
293 | |||
294 | data &= 0x0F; | ||
295 | data |= 0xC0; | ||
296 | __raw_writeb(data, addr); | ||
297 | } | ||
298 | |||
200 | static void __init g4evm_init(void) | 299 | static void __init g4evm_init(void) |
201 | { | 300 | { |
202 | sh7377_pinmux_init(); | 301 | sh7377_pinmux_init(); |
@@ -253,6 +352,34 @@ static void __init g4evm_init(void) | |||
253 | gpio_request(GPIO_FN_PORT71_KEYIN5_PU, NULL); | 352 | gpio_request(GPIO_FN_PORT71_KEYIN5_PU, NULL); |
254 | gpio_request(GPIO_FN_PORT72_KEYIN6_PU, NULL); | 353 | gpio_request(GPIO_FN_PORT72_KEYIN6_PU, NULL); |
255 | 354 | ||
355 | /* SDHI0 */ | ||
356 | gpio_request(GPIO_FN_SDHICLK0, NULL); | ||
357 | gpio_request(GPIO_FN_SDHICD0, NULL); | ||
358 | gpio_request(GPIO_FN_SDHID0_0, NULL); | ||
359 | gpio_request(GPIO_FN_SDHID0_1, NULL); | ||
360 | gpio_request(GPIO_FN_SDHID0_2, NULL); | ||
361 | gpio_request(GPIO_FN_SDHID0_3, NULL); | ||
362 | gpio_request(GPIO_FN_SDHICMD0, NULL); | ||
363 | gpio_request(GPIO_FN_SDHIWP0, NULL); | ||
364 | gpio_pull_up(GPIO_SDHID0_D0); | ||
365 | gpio_pull_up(GPIO_SDHID0_D1); | ||
366 | gpio_pull_up(GPIO_SDHID0_D2); | ||
367 | gpio_pull_up(GPIO_SDHID0_D3); | ||
368 | gpio_pull_up(GPIO_SDHICMD0); | ||
369 | |||
370 | /* SDHI1 */ | ||
371 | gpio_request(GPIO_FN_SDHICLK1, NULL); | ||
372 | gpio_request(GPIO_FN_SDHID1_0, NULL); | ||
373 | gpio_request(GPIO_FN_SDHID1_1, NULL); | ||
374 | gpio_request(GPIO_FN_SDHID1_2, NULL); | ||
375 | gpio_request(GPIO_FN_SDHID1_3, NULL); | ||
376 | gpio_request(GPIO_FN_SDHICMD1, NULL); | ||
377 | gpio_pull_up(GPIO_SDHID1_D0); | ||
378 | gpio_pull_up(GPIO_SDHID1_D1); | ||
379 | gpio_pull_up(GPIO_SDHID1_D2); | ||
380 | gpio_pull_up(GPIO_SDHID1_D3); | ||
381 | gpio_pull_up(GPIO_SDHICMD1); | ||
382 | |||
256 | sh7377_add_standard_devices(); | 383 | sh7377_add_standard_devices(); |
257 | 384 | ||
258 | platform_add_devices(g4evm_devices, ARRAY_SIZE(g4evm_devices)); | 385 | platform_add_devices(g4evm_devices, ARRAY_SIZE(g4evm_devices)); |