blob: b9e71db33b927fd55629d8470f640f05f8ef7dae [file] [log] [blame]
Tony Lindgren1dbae812005-11-10 14:26:51 +00001/*
Tony Lindgren1dbae812005-11-10 14:26:51 +00002 * Copyright (C) 2005 Nokia Corporation
3 * Author: Paul Mundt <paul.mundt@nokia.com>
4 *
Benoit Cousson8d616492011-09-20 21:24:47 +02005 * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/
Tony Lindgren1dbae812005-11-10 14:26:51 +00006 *
Benoit Cousson8d616492011-09-20 21:24:47 +02007 * Modified from the original mach-omap/omap2/board-generic.c did by Paul
8 * to support the OMAP2+ device tree boards with an unique board file.
Tony Lindgren1dbae812005-11-10 14:26:51 +00009 *
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.
13 */
Benoit Cousson8d616492011-09-20 21:24:47 +020014#include <linux/io.h>
15#include <linux/of_platform.h>
16#include <linux/irqdomain.h>
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020017#include <linux/i2c/twl.h>
Tony Lindgren1dbae812005-11-10 14:26:51 +000018
Russell Kinga09e64f2008-08-05 16:14:15 +010019#include <mach/hardware.h>
Tony Lindgren1dbae812005-11-10 14:26:51 +000020#include <asm/mach/arch.h>
Tony Lindgren1dbae812005-11-10 14:26:51 +000021
Tony Lindgrence491cf2009-10-20 09:40:47 -070022#include <plat/board.h>
23#include <plat/common.h>
Benoit Cousson8d616492011-09-20 21:24:47 +020024#include <mach/omap4-common.h>
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020025#include "common-board-devices.h"
Tony Lindgren1dbae812005-11-10 14:26:51 +000026
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020027/*
28 * XXX: Still needed to boot until the i2c & twl driver is adapted to
29 * device-tree
30 */
Sanjeev Premic4e2d242011-10-13 21:44:10 +053031#ifdef CONFIG_ARCH_OMAP4
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020032static struct twl4030_platform_data sdp4430_twldata = {
33 .irq_base = TWL6030_IRQ_BASE,
34 .irq_end = TWL6030_IRQ_END,
35};
36
37static void __init omap4_i2c_init(void)
38{
39 omap4_pmic_init("twl6030", &sdp4430_twldata);
40}
Sanjeev Premic4e2d242011-10-13 21:44:10 +053041#endif
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020042
Sanjeev Premic4e2d242011-10-13 21:44:10 +053043#ifdef CONFIG_ARCH_OMAP3
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020044static struct twl4030_platform_data beagle_twldata = {
45 .irq_base = TWL4030_IRQ_BASE,
46 .irq_end = TWL4030_IRQ_END,
47};
48
49static void __init omap3_i2c_init(void)
50{
51 omap3_pmic_init("twl4030", &beagle_twldata);
52}
Sanjeev Premic4e2d242011-10-13 21:44:10 +053053#endif
Benoit Cousson8d616492011-09-20 21:24:47 +020054
55static struct of_device_id omap_dt_match_table[] __initdata = {
56 { .compatible = "simple-bus", },
57 { .compatible = "ti,omap-infra", },
58 { }
Paul Walmsleyb3c6df32009-09-03 20:14:02 +030059};
60
Benoit Cousson8d616492011-09-20 21:24:47 +020061static struct of_device_id intc_match[] __initdata = {
62 { .compatible = "ti,omap3-intc", },
63 { .compatible = "arm,cortex-a9-gic", },
64 { }
65};
Tony Lindgren1dbae812005-11-10 14:26:51 +000066
Tony Lindgren1dbae812005-11-10 14:26:51 +000067static void __init omap_generic_init(void)
68{
Benoit Cousson8d616492011-09-20 21:24:47 +020069 struct device_node *node = of_find_matching_node(NULL, intc_match);
70 if (node)
71 irq_domain_add_simple(node, 0);
72
Tony Lindgren1dbae812005-11-10 14:26:51 +000073 omap_serial_init();
Tony Lindgrena4ca9db2011-08-22 23:57:23 -070074 omap_sdrc_init(NULL, NULL);
Benoit Cousson8d616492011-09-20 21:24:47 +020075
76 of_platform_populate(NULL, omap_dt_match_table, NULL, NULL);
Tony Lindgren1dbae812005-11-10 14:26:51 +000077}
78
Sanjeev Premic4e2d242011-10-13 21:44:10 +053079#ifdef CONFIG_ARCH_OMAP4
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020080static void __init omap4_init(void)
81{
82 omap4_i2c_init();
83 omap_generic_init();
84}
Sanjeev Premic4e2d242011-10-13 21:44:10 +053085#endif
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020086
Sanjeev Premic4e2d242011-10-13 21:44:10 +053087#ifdef CONFIG_ARCH_OMAP3
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020088static void __init omap3_init(void)
89{
90 omap3_i2c_init();
91 omap_generic_init();
92}
Sanjeev Premic4e2d242011-10-13 21:44:10 +053093#endif
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020094
Benoit Cousson8d616492011-09-20 21:24:47 +020095#if defined(CONFIG_SOC_OMAP2420)
96static const char *omap242x_boards_compat[] __initdata = {
97 "ti,omap2420",
98 NULL,
99};
Tony Lindgren1dbae812005-11-10 14:26:51 +0000100
Benoit Cousson8d616492011-09-20 21:24:47 +0200101DT_MACHINE_START(OMAP242X_DT, "Generic OMAP2420 (Flattened Device Tree)")
Nicolas Pitre5e52b432011-07-05 22:38:15 -0400102 .atag_offset = 0x100,
Russell King71ee7da2010-05-23 10:18:16 +0100103 .reserve = omap_reserve,
Benoit Cousson8d616492011-09-20 21:24:47 +0200104 .map_io = omap242x_map_io,
105 .init_early = omap2420_init_early,
Tony Lindgren741e3a82011-05-17 03:51:26 -0700106 .init_irq = omap2_init_irq,
Tony Lindgren1dbae812005-11-10 14:26:51 +0000107 .init_machine = omap_generic_init,
Arnd Bergmann13340b22011-06-30 12:58:01 +0000108 .timer = &omap2_timer,
Benoit Cousson8d616492011-09-20 21:24:47 +0200109 .dt_compat = omap242x_boards_compat,
Tony Lindgren1dbae812005-11-10 14:26:51 +0000110MACHINE_END
Benoit Cousson8d616492011-09-20 21:24:47 +0200111#endif
112
113#if defined(CONFIG_SOC_OMAP2430)
114static const char *omap243x_boards_compat[] __initdata = {
115 "ti,omap2430",
116 NULL,
117};
118
119DT_MACHINE_START(OMAP243X_DT, "Generic OMAP2430 (Flattened Device Tree)")
Arnd Bergmanndf804422011-11-01 13:47:27 +0100120 .atag_offset = 0x100,
Benoit Cousson8d616492011-09-20 21:24:47 +0200121 .reserve = omap_reserve,
122 .map_io = omap243x_map_io,
123 .init_early = omap2430_init_early,
124 .init_irq = omap2_init_irq,
Marc Zyngier6b2f55d2011-09-06 10:23:45 +0100125 .handle_irq = omap2_intc_handle_irq,
Benoit Cousson8d616492011-09-20 21:24:47 +0200126 .init_machine = omap_generic_init,
127 .timer = &omap2_timer,
128 .dt_compat = omap243x_boards_compat,
129MACHINE_END
130#endif
131
132#if defined(CONFIG_ARCH_OMAP3)
133static const char *omap3_boards_compat[] __initdata = {
134 "ti,omap3",
135 NULL,
136};
137
138DT_MACHINE_START(OMAP3_DT, "Generic OMAP3 (Flattened Device Tree)")
Arnd Bergmanndf804422011-11-01 13:47:27 +0100139 .atag_offset = 0x100,
Benoit Cousson8d616492011-09-20 21:24:47 +0200140 .reserve = omap_reserve,
141 .map_io = omap3_map_io,
142 .init_early = omap3430_init_early,
143 .init_irq = omap3_init_irq,
Benoit Coussona7cbb9b2011-09-22 21:52:02 +0200144 .init_machine = omap3_init,
Benoit Cousson8d616492011-09-20 21:24:47 +0200145 .timer = &omap3_timer,
146 .dt_compat = omap3_boards_compat,
147MACHINE_END
148#endif
149
150#if defined(CONFIG_ARCH_OMAP4)
151static const char *omap4_boards_compat[] __initdata = {
152 "ti,omap4",
153 NULL,
154};
155
156DT_MACHINE_START(OMAP4_DT, "Generic OMAP4 (Flattened Device Tree)")
Arnd Bergmanndf804422011-11-01 13:47:27 +0100157 .atag_offset = 0x100,
Benoit Cousson8d616492011-09-20 21:24:47 +0200158 .reserve = omap_reserve,
159 .map_io = omap4_map_io,
160 .init_early = omap4430_init_early,
161 .init_irq = gic_init_irq,
Benoit Coussona7cbb9b2011-09-22 21:52:02 +0200162 .init_machine = omap4_init,
Benoit Cousson8d616492011-09-20 21:24:47 +0200163 .timer = &omap4_timer,
164 .dt_compat = omap4_boards_compat,
165MACHINE_END
166#endif