11dbae815STony Lindgren /*
21dbae815STony Lindgren  * Copyright (C) 2005 Nokia Corporation
31dbae815STony Lindgren  * Author: Paul Mundt <paul.mundt@nokia.com>
41dbae815STony Lindgren  *
58d61649dSBenoit Cousson  * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/
61dbae815STony Lindgren  *
78d61649dSBenoit Cousson  * Modified from the original mach-omap/omap2/board-generic.c did by Paul
88d61649dSBenoit Cousson  * to support the OMAP2+ device tree boards with an unique board file.
91dbae815STony Lindgren  *
101dbae815STony Lindgren  * This program is free software; you can redistribute it and/or modify
111dbae815STony Lindgren  * it under the terms of the GNU General Public License version 2 as
121dbae815STony Lindgren  * published by the Free Software Foundation.
131dbae815STony Lindgren  */
141dbae815STony Lindgren 
158d61649dSBenoit Cousson #include <linux/io.h>
168d61649dSBenoit Cousson #include <linux/of_platform.h>
178d61649dSBenoit Cousson #include <linux/irqdomain.h>
18a7cbb9b1SBenoit Cousson #include <linux/i2c/twl.h>
191dbae815STony Lindgren 
20a09e64fbSRussell King #include <mach/hardware.h>
211dbae815STony Lindgren #include <asm/mach/arch.h>
221dbae815STony Lindgren 
23ce491cf8STony Lindgren #include <plat/board.h>
24ce491cf8STony Lindgren #include <plat/common.h>
258d61649dSBenoit Cousson #include <mach/omap4-common.h>
26a7cbb9b1SBenoit Cousson #include "common-board-devices.h"
271dbae815STony Lindgren 
28a7cbb9b1SBenoit Cousson /*
29a7cbb9b1SBenoit Cousson  * XXX: Still needed to boot until the i2c & twl driver is adapted to
30a7cbb9b1SBenoit Cousson  * device-tree
31a7cbb9b1SBenoit Cousson  */
32a7cbb9b1SBenoit Cousson static struct twl4030_platform_data sdp4430_twldata = {
33a7cbb9b1SBenoit Cousson 	.irq_base	= TWL6030_IRQ_BASE,
34a7cbb9b1SBenoit Cousson 	.irq_end	= TWL6030_IRQ_END,
35a7cbb9b1SBenoit Cousson };
36a7cbb9b1SBenoit Cousson 
37a7cbb9b1SBenoit Cousson static void __init omap4_i2c_init(void)
38a7cbb9b1SBenoit Cousson {
39a7cbb9b1SBenoit Cousson 	omap4_pmic_init("twl6030", &sdp4430_twldata);
40a7cbb9b1SBenoit Cousson }
41a7cbb9b1SBenoit Cousson 
42a7cbb9b1SBenoit Cousson static struct twl4030_platform_data beagle_twldata = {
43a7cbb9b1SBenoit Cousson 	.irq_base	= TWL4030_IRQ_BASE,
44a7cbb9b1SBenoit Cousson 	.irq_end	= TWL4030_IRQ_END,
45a7cbb9b1SBenoit Cousson };
46a7cbb9b1SBenoit Cousson 
47a7cbb9b1SBenoit Cousson static void __init omap3_i2c_init(void)
48a7cbb9b1SBenoit Cousson {
49a7cbb9b1SBenoit Cousson 	omap3_pmic_init("twl4030", &beagle_twldata);
50a7cbb9b1SBenoit Cousson }
518d61649dSBenoit Cousson 
528d61649dSBenoit Cousson static struct of_device_id omap_dt_match_table[] __initdata = {
538d61649dSBenoit Cousson 	{ .compatible = "simple-bus", },
548d61649dSBenoit Cousson 	{ .compatible = "ti,omap-infra", },
558d61649dSBenoit Cousson 	{ }
56b3c6df3aSPaul Walmsley };
57b3c6df3aSPaul Walmsley 
588d61649dSBenoit Cousson static struct of_device_id intc_match[] __initdata = {
598d61649dSBenoit Cousson 	{ .compatible = "ti,omap3-intc", },
608d61649dSBenoit Cousson 	{ .compatible = "arm,cortex-a9-gic", },
618d61649dSBenoit Cousson 	{ }
628d61649dSBenoit Cousson };
631dbae815STony Lindgren 
641dbae815STony Lindgren static void __init omap_generic_init(void)
651dbae815STony Lindgren {
668d61649dSBenoit Cousson 	struct device_node *node = of_find_matching_node(NULL, intc_match);
678d61649dSBenoit Cousson 	if (node)
688d61649dSBenoit Cousson 		irq_domain_add_simple(node, 0);
698d61649dSBenoit Cousson 
701dbae815STony Lindgren 	omap_serial_init();
71a4ca9dbeSTony Lindgren 	omap_sdrc_init(NULL, NULL);
728d61649dSBenoit Cousson 
738d61649dSBenoit Cousson 	of_platform_populate(NULL, omap_dt_match_table, NULL, NULL);
741dbae815STony Lindgren }
751dbae815STony Lindgren 
76a7cbb9b1SBenoit Cousson static void __init omap4_init(void)
77a7cbb9b1SBenoit Cousson {
78a7cbb9b1SBenoit Cousson 	omap4_i2c_init();
79a7cbb9b1SBenoit Cousson 	omap_generic_init();
80a7cbb9b1SBenoit Cousson }
81a7cbb9b1SBenoit Cousson 
82a7cbb9b1SBenoit Cousson static void __init omap3_init(void)
83a7cbb9b1SBenoit Cousson {
84a7cbb9b1SBenoit Cousson 	omap3_i2c_init();
85a7cbb9b1SBenoit Cousson 	omap_generic_init();
86a7cbb9b1SBenoit Cousson }
87a7cbb9b1SBenoit Cousson 
888d61649dSBenoit Cousson #if defined(CONFIG_SOC_OMAP2420)
898d61649dSBenoit Cousson static const char *omap242x_boards_compat[] __initdata = {
908d61649dSBenoit Cousson 	"ti,omap2420",
918d61649dSBenoit Cousson 	NULL,
928d61649dSBenoit Cousson };
931dbae815STony Lindgren 
948d61649dSBenoit Cousson DT_MACHINE_START(OMAP242X_DT, "Generic OMAP2420 (Flattened Device Tree)")
9571ee7dadSRussell King 	.reserve	= omap_reserve,
968d61649dSBenoit Cousson 	.map_io		= omap242x_map_io,
978d61649dSBenoit Cousson 	.init_early	= omap2420_init_early,
98741e3a89STony Lindgren 	.init_irq	= omap2_init_irq,
991dbae815STony Lindgren 	.init_machine	= omap_generic_init,
10013340b2aSArnd Bergmann 	.timer		= &omap2_timer,
1018d61649dSBenoit Cousson 	.dt_compat	= omap242x_boards_compat,
1021dbae815STony Lindgren MACHINE_END
1038d61649dSBenoit Cousson #endif
1048d61649dSBenoit Cousson 
1058d61649dSBenoit Cousson #if defined(CONFIG_SOC_OMAP2430)
1068d61649dSBenoit Cousson static const char *omap243x_boards_compat[] __initdata = {
1078d61649dSBenoit Cousson 	"ti,omap2430",
1088d61649dSBenoit Cousson 	NULL,
1098d61649dSBenoit Cousson };
1108d61649dSBenoit Cousson 
1118d61649dSBenoit Cousson DT_MACHINE_START(OMAP243X_DT, "Generic OMAP2430 (Flattened Device Tree)")
1128d61649dSBenoit Cousson 	.reserve	= omap_reserve,
1138d61649dSBenoit Cousson 	.map_io		= omap243x_map_io,
1148d61649dSBenoit Cousson 	.init_early	= omap2430_init_early,
1158d61649dSBenoit Cousson 	.init_irq	= omap2_init_irq,
1168d61649dSBenoit Cousson 	.init_machine	= omap_generic_init,
1178d61649dSBenoit Cousson 	.timer		= &omap2_timer,
1188d61649dSBenoit Cousson 	.dt_compat	= omap243x_boards_compat,
1198d61649dSBenoit Cousson MACHINE_END
1208d61649dSBenoit Cousson #endif
1218d61649dSBenoit Cousson 
1228d61649dSBenoit Cousson #if defined(CONFIG_ARCH_OMAP3)
1238d61649dSBenoit Cousson static const char *omap3_boards_compat[] __initdata = {
1248d61649dSBenoit Cousson 	"ti,omap3",
1258d61649dSBenoit Cousson 	NULL,
1268d61649dSBenoit Cousson };
1278d61649dSBenoit Cousson 
1288d61649dSBenoit Cousson DT_MACHINE_START(OMAP3_DT, "Generic OMAP3 (Flattened Device Tree)")
1298d61649dSBenoit Cousson 	.reserve	= omap_reserve,
1308d61649dSBenoit Cousson 	.map_io		= omap3_map_io,
1318d61649dSBenoit Cousson 	.init_early	= omap3430_init_early,
1328d61649dSBenoit Cousson 	.init_irq	= omap3_init_irq,
133a7cbb9b1SBenoit Cousson 	.init_machine	= omap3_init,
1348d61649dSBenoit Cousson 	.timer		= &omap3_timer,
1358d61649dSBenoit Cousson 	.dt_compat	= omap3_boards_compat,
1368d61649dSBenoit Cousson MACHINE_END
1378d61649dSBenoit Cousson #endif
1388d61649dSBenoit Cousson 
1398d61649dSBenoit Cousson #if defined(CONFIG_ARCH_OMAP4)
1408d61649dSBenoit Cousson static const char *omap4_boards_compat[] __initdata = {
1418d61649dSBenoit Cousson 	"ti,omap4",
1428d61649dSBenoit Cousson 	NULL,
1438d61649dSBenoit Cousson };
1448d61649dSBenoit Cousson 
1458d61649dSBenoit Cousson DT_MACHINE_START(OMAP4_DT, "Generic OMAP4 (Flattened Device Tree)")
1468d61649dSBenoit Cousson 	.reserve	= omap_reserve,
1478d61649dSBenoit Cousson 	.map_io		= omap4_map_io,
1488d61649dSBenoit Cousson 	.init_early	= omap4430_init_early,
1498d61649dSBenoit Cousson 	.init_irq	= gic_init_irq,
150a7cbb9b1SBenoit Cousson 	.init_machine	= omap4_init,
1518d61649dSBenoit Cousson 	.timer		= &omap4_timer,
1528d61649dSBenoit Cousson 	.dt_compat	= omap4_boards_compat,
1538d61649dSBenoit Cousson MACHINE_END
1548d61649dSBenoit Cousson #endif
155