blob: 02d7e828a14b70ce3d5419a0c6604601477bf6bb [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>
Benoit Coussonb7557062011-12-07 11:47:40 -080020#include <asm/hardware/gic.h>
Tony Lindgren1dbae812005-11-10 14:26:51 +000021#include <asm/mach/arch.h>
Tony Lindgren1dbae812005-11-10 14:26:51 +000022
Tony Lindgrence491cf2009-10-20 09:40:47 -070023#include <plat/board.h>
Tony Lindgren4e653312011-11-10 22:45:17 +010024#include "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)
Grant Likely6b783f72012-01-10 17:09:30 -070071 irq_domain_add_legacy(node, 32, 0, 0, &irq_domain_simple_ops, NULL);
Benoit Cousson8d616492011-09-20 21:24:47 +020072
Tony Lindgrena4ca9db2011-08-22 23:57:23 -070073 omap_sdrc_init(NULL, NULL);
Benoit Cousson8d616492011-09-20 21:24:47 +020074
75 of_platform_populate(NULL, omap_dt_match_table, NULL, NULL);
Tony Lindgren1dbae812005-11-10 14:26:51 +000076}
77
Sanjeev Premic4e2d242011-10-13 21:44:10 +053078#ifdef CONFIG_ARCH_OMAP4
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020079static void __init omap4_init(void)
80{
81 omap4_i2c_init();
82 omap_generic_init();
83}
Sanjeev Premic4e2d242011-10-13 21:44:10 +053084#endif
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020085
Sanjeev Premic4e2d242011-10-13 21:44:10 +053086#ifdef CONFIG_ARCH_OMAP3
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020087static void __init omap3_init(void)
88{
89 omap3_i2c_init();
90 omap_generic_init();
91}
Sanjeev Premic4e2d242011-10-13 21:44:10 +053092#endif
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020093
Benoit Cousson0e02a8c2011-12-01 11:05:17 +010094#ifdef CONFIG_SOC_OMAP2420
Benoit Cousson8d616492011-09-20 21:24:47 +020095static const char *omap242x_boards_compat[] __initdata = {
96 "ti,omap2420",
97 NULL,
98};
Tony Lindgren1dbae812005-11-10 14:26:51 +000099
Benoit Cousson8d616492011-09-20 21:24:47 +0200100DT_MACHINE_START(OMAP242X_DT, "Generic OMAP2420 (Flattened Device Tree)")
Russell King71ee7da2010-05-23 10:18:16 +0100101 .reserve = omap_reserve,
Benoit Cousson8d616492011-09-20 21:24:47 +0200102 .map_io = omap242x_map_io,
103 .init_early = omap2420_init_early,
Tony Lindgren741e3a82011-05-17 03:51:26 -0700104 .init_irq = omap2_init_irq,
Benoit Coussonb7557062011-12-07 11:47:40 -0800105 .handle_irq = omap2_intc_handle_irq,
Tony Lindgren1dbae812005-11-10 14:26:51 +0000106 .init_machine = omap_generic_init,
Arnd Bergmann13340b22011-06-30 12:58:01 +0000107 .timer = &omap2_timer,
Benoit Cousson8d616492011-09-20 21:24:47 +0200108 .dt_compat = omap242x_boards_compat,
Russell Kingbaa95882011-11-05 17:06:28 +0000109 .restart = omap_prcm_restart,
Tony Lindgren1dbae812005-11-10 14:26:51 +0000110MACHINE_END
Benoit Cousson8d616492011-09-20 21:24:47 +0200111#endif
112
Benoit Cousson0e02a8c2011-12-01 11:05:17 +0100113#ifdef CONFIG_SOC_OMAP2430
Benoit Cousson8d616492011-09-20 21:24:47 +0200114static const char *omap243x_boards_compat[] __initdata = {
115 "ti,omap2430",
116 NULL,
117};
118
119DT_MACHINE_START(OMAP243X_DT, "Generic OMAP2430 (Flattened Device Tree)")
120 .reserve = omap_reserve,
121 .map_io = omap243x_map_io,
122 .init_early = omap2430_init_early,
123 .init_irq = omap2_init_irq,
Marc Zyngier6b2f55d2011-09-06 10:23:45 +0100124 .handle_irq = omap2_intc_handle_irq,
Benoit Cousson8d616492011-09-20 21:24:47 +0200125 .init_machine = omap_generic_init,
126 .timer = &omap2_timer,
127 .dt_compat = omap243x_boards_compat,
Russell Kingbaa95882011-11-05 17:06:28 +0000128 .restart = omap_prcm_restart,
Benoit Cousson8d616492011-09-20 21:24:47 +0200129MACHINE_END
130#endif
131
Benoit Cousson0e02a8c2011-12-01 11:05:17 +0100132#ifdef CONFIG_ARCH_OMAP3
Benoit Cousson8d616492011-09-20 21:24:47 +0200133static const char *omap3_boards_compat[] __initdata = {
134 "ti,omap3",
135 NULL,
136};
137
138DT_MACHINE_START(OMAP3_DT, "Generic OMAP3 (Flattened Device Tree)")
139 .reserve = omap_reserve,
140 .map_io = omap3_map_io,
141 .init_early = omap3430_init_early,
142 .init_irq = omap3_init_irq,
Benoit Coussonb7557062011-12-07 11:47:40 -0800143 .handle_irq = omap3_intc_handle_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,
Russell Kingbaa95882011-11-05 17:06:28 +0000147 .restart = omap_prcm_restart,
Benoit Cousson8d616492011-09-20 21:24:47 +0200148MACHINE_END
149#endif
150
Benoit Cousson0e02a8c2011-12-01 11:05:17 +0100151#ifdef CONFIG_ARCH_OMAP4
Benoit Cousson8d616492011-09-20 21:24:47 +0200152static const char *omap4_boards_compat[] __initdata = {
153 "ti,omap4",
154 NULL,
155};
156
157DT_MACHINE_START(OMAP4_DT, "Generic OMAP4 (Flattened Device Tree)")
158 .reserve = omap_reserve,
159 .map_io = omap4_map_io,
160 .init_early = omap4430_init_early,
161 .init_irq = gic_init_irq,
Benoit Coussonb7557062011-12-07 11:47:40 -0800162 .handle_irq = gic_handle_irq,
Benoit Coussona7cbb9b2011-09-22 21:52:02 +0200163 .init_machine = omap4_init,
Benoit Cousson8d616492011-09-20 21:24:47 +0200164 .timer = &omap4_timer,
165 .dt_compat = omap4_boards_compat,
Russell Kingbaa95882011-11-05 17:06:28 +0000166 .restart = omap_prcm_restart,
Benoit Cousson8d616492011-09-20 21:24:47 +0200167MACHINE_END
168#endif