2 * Board support file for OMAP4430 SDP.
4 * Copyright (C) 2009 Texas Instruments
6 * Author: Santosh Shilimkar <santosh.shilimkar@ti.com>
8 * Based on mach-omap2/board-3430sdp.c
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License version 2 as
12 * published by the Free Software Foundation.
15 #include <linux/kernel.h>
16 #include <linux/init.h>
17 #include <linux/platform_device.h>
19 #include <linux/gpio.h>
20 #include <linux/usb/otg.h>
22 #include <mach/hardware.h>
23 #include <asm/mach-types.h>
24 #include <asm/mach/arch.h>
25 #include <asm/mach/map.h>
27 #include <plat/board.h>
28 #include <plat/common.h>
29 #include <plat/control.h>
30 #include <plat/timer-gp.h>
32 #include <asm/hardware/gic.h>
33 #include <asm/hardware/cache-l2x0.h>
35 static struct platform_device sdp4430_lcd_device
= {
36 .name
= "sdp4430_lcd",
40 static struct platform_device
*sdp4430_devices
[] __initdata
= {
44 static struct omap_lcd_config sdp4430_lcd_config __initdata
= {
45 .ctrl_name
= "internal",
48 static struct omap_board_config_kernel sdp4430_config
[] __initdata
= {
49 { OMAP_TAG_LCD
, &sdp4430_lcd_config
},
52 #ifdef CONFIG_CACHE_L2X0
53 static int __init
omap_l2_cache_init(void)
55 extern void omap_smc1(u32 fn
, u32 arg
);
56 void __iomem
*l2cache_base
;
58 /* To avoid code running on other OMAPs in
61 if (!cpu_is_omap44xx())
64 /* Static mapping, never released */
65 l2cache_base
= ioremap(OMAP44XX_L2CACHE_BASE
, SZ_4K
);
66 BUG_ON(!l2cache_base
);
68 /* Enable PL310 L2 Cache controller */
69 omap_smc1(0x102, 0x1);
71 /* 32KB way size, 16-way associativity,
74 l2x0_init(l2cache_base
, 0x0e050000, 0xc0000fff);
78 early_initcall(omap_l2_cache_init
);
81 static void __init
gic_init_irq(void)
85 /* Static mapping, never released */
86 base
= ioremap(OMAP44XX_GIC_DIST_BASE
, SZ_4K
);
88 gic_dist_init(0, base
, 29);
90 /* Static mapping, never released */
91 gic_cpu_base_addr
= ioremap(OMAP44XX_GIC_CPU_BASE
, SZ_512
);
92 BUG_ON(!gic_cpu_base_addr
);
93 gic_cpu_init(0, gic_cpu_base_addr
);
96 static void __init
omap_4430sdp_init_irq(void)
98 omap_board_config
= sdp4430_config
;
99 omap_board_config_size
= ARRAY_SIZE(sdp4430_config
);
100 omap2_init_common_hw(NULL
, NULL
);
101 #ifdef CONFIG_OMAP_32K_TIMER
102 omap2_gp_clockevent_set_gptimer(1);
108 static struct omap_musb_board_data musb_board_data
= {
109 .interface_type
= MUSB_INTERFACE_UTMI
,
110 .mode
= MUSB_PERIPHERAL
,
114 static void __init
omap_4430sdp_init(void)
116 platform_add_devices(sdp4430_devices
, ARRAY_SIZE(sdp4430_devices
));
118 /* OMAP4 SDP uses internal transceiver so register nop transceiver */
119 usb_nop_xceiv_register();
120 /* FIXME: allow multi-omap to boot until musb is updated for omap4 */
121 if (!cpu_is_omap44xx())
122 usb_musb_init(&musb_board_data
);
125 static void __init
omap_4430sdp_map_io(void)
127 omap2_set_globals_443x();
128 omap44xx_map_common_io();
131 MACHINE_START(OMAP_4430SDP
, "OMAP4430 4430SDP board")
132 /* Maintainer: Santosh Shilimkar - Texas Instruments Inc */
133 .phys_io
= 0x48000000,
134 .io_pg_offst
= ((0xfa000000) >> 18) & 0xfffc,
135 .boot_params
= 0x80000100,
136 .map_io
= omap_4430sdp_map_io
,
137 .init_irq
= omap_4430sdp_init_irq
,
138 .init_machine
= omap_4430sdp_init
,
139 .timer
= &omap_timer
,