blob: d587560604836f5d7ee836b773f37798c17cdf41 [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>
Tony Lindgren4e653312011-11-10 22:45:17 +010023#include "common.h"
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020024#include "common-board-devices.h"
Tony Lindgren1dbae812005-11-10 14:26:51 +000025
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020026/*
27 * XXX: Still needed to boot until the i2c & twl driver is adapted to
28 * device-tree
29 */
Sanjeev Premic4e2d242011-10-13 21:44:10 +053030#ifdef CONFIG_ARCH_OMAP4
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020031static struct twl4030_platform_data sdp4430_twldata = {
32 .irq_base = TWL6030_IRQ_BASE,
33 .irq_end = TWL6030_IRQ_END,
34};
35
36static void __init omap4_i2c_init(void)
37{
38 omap4_pmic_init("twl6030", &sdp4430_twldata);
39}
Sanjeev Premic4e2d242011-10-13 21:44:10 +053040#endif
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020041
Sanjeev Premic4e2d242011-10-13 21:44:10 +053042#ifdef CONFIG_ARCH_OMAP3
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020043static struct twl4030_platform_data beagle_twldata = {
44 .irq_base = TWL4030_IRQ_BASE,
45 .irq_end = TWL4030_IRQ_END,
46};
47
48static void __init omap3_i2c_init(void)
49{
50 omap3_pmic_init("twl4030", &beagle_twldata);
51}
Sanjeev Premic4e2d242011-10-13 21:44:10 +053052#endif
Benoit Cousson8d616492011-09-20 21:24:47 +020053
54static struct of_device_id omap_dt_match_table[] __initdata = {
55 { .compatible = "simple-bus", },
56 { .compatible = "ti,omap-infra", },
57 { }
Paul Walmsleyb3c6df32009-09-03 20:14:02 +030058};
59
Benoit Cousson8d616492011-09-20 21:24:47 +020060static struct of_device_id intc_match[] __initdata = {
61 { .compatible = "ti,omap3-intc", },
62 { .compatible = "arm,cortex-a9-gic", },
63 { }
64};
Tony Lindgren1dbae812005-11-10 14:26:51 +000065
Tony Lindgren1dbae812005-11-10 14:26:51 +000066static void __init omap_generic_init(void)
67{
Benoit Cousson8d616492011-09-20 21:24:47 +020068 struct device_node *node = of_find_matching_node(NULL, intc_match);
69 if (node)
70 irq_domain_add_simple(node, 0);
71
Tony Lindgrena4ca9db2011-08-22 23:57:23 -070072 omap_sdrc_init(NULL, NULL);
Benoit Cousson8d616492011-09-20 21:24:47 +020073
74 of_platform_populate(NULL, omap_dt_match_table, NULL, NULL);
Tony Lindgren1dbae812005-11-10 14:26:51 +000075}
76
Sanjeev Premic4e2d242011-10-13 21:44:10 +053077#ifdef CONFIG_ARCH_OMAP4
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020078static void __init omap4_init(void)
79{
80 omap4_i2c_init();
81 omap_generic_init();
82}
Sanjeev Premic4e2d242011-10-13 21:44:10 +053083#endif
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020084
Sanjeev Premic4e2d242011-10-13 21:44:10 +053085#ifdef CONFIG_ARCH_OMAP3
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020086static void __init omap3_init(void)
87{
88 omap3_i2c_init();
89 omap_generic_init();
90}
Sanjeev Premic4e2d242011-10-13 21:44:10 +053091#endif
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020092
Benoit Cousson8d616492011-09-20 21:24:47 +020093#if defined(CONFIG_SOC_OMAP2420)
94static const char *omap242x_boards_compat[] __initdata = {
95 "ti,omap2420",
96 NULL,
97};
Tony Lindgren1dbae812005-11-10 14:26:51 +000098
Benoit Cousson8d616492011-09-20 21:24:47 +020099DT_MACHINE_START(OMAP242X_DT, "Generic OMAP2420 (Flattened Device Tree)")
Nicolas Pitre5e52b432011-07-05 22:38:15 -0400100 .atag_offset = 0x100,
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,
Tony Lindgren1dbae812005-11-10 14:26:51 +0000105 .init_machine = omap_generic_init,
Arnd Bergmann13340b22011-06-30 12:58:01 +0000106 .timer = &omap2_timer,
Benoit Cousson8d616492011-09-20 21:24:47 +0200107 .dt_compat = omap242x_boards_compat,
Russell Kingbaa95882011-11-05 17:06:28 +0000108 .restart = omap_prcm_restart,
Tony Lindgren1dbae812005-11-10 14:26:51 +0000109MACHINE_END
Benoit Cousson8d616492011-09-20 21:24:47 +0200110#endif
111
112#if defined(CONFIG_SOC_OMAP2430)
113static const char *omap243x_boards_compat[] __initdata = {
114 "ti,omap2430",
115 NULL,
116};
117
118DT_MACHINE_START(OMAP243X_DT, "Generic OMAP2430 (Flattened Device Tree)")
Arnd Bergmanndf804422011-11-01 13:47:27 +0100119 .atag_offset = 0x100,
Benoit Cousson8d616492011-09-20 21:24:47 +0200120 .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
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,
Russell Kingbaa95882011-11-05 17:06:28 +0000147 .restart = omap_prcm_restart,
Benoit Cousson8d616492011-09-20 21:24:47 +0200148MACHINE_END
149#endif
150
151#if defined(CONFIG_ARCH_OMAP4)
152static const char *omap4_boards_compat[] __initdata = {
153 "ti,omap4",
154 NULL,
155};
156
157DT_MACHINE_START(OMAP4_DT, "Generic OMAP4 (Flattened Device Tree)")
Arnd Bergmanndf804422011-11-01 13:47:27 +0100158 .atag_offset = 0x100,
Benoit Cousson8d616492011-09-20 21:24:47 +0200159 .reserve = omap_reserve,
160 .map_io = omap4_map_io,
161 .init_early = omap4430_init_early,
162 .init_irq = gic_init_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