blob: f462d8c65bc4875b7b2699e9a5dce4d3d8cde159 [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 Lindgren1dbae812005-11-10 14:26:51 +000072 omap_serial_init();
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 Cousson8d616492011-09-20 21:24:47 +020094#if defined(CONFIG_SOC_OMAP2420)
95static 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)")
Nicolas Pitre5e52b432011-07-05 22:38:15 -0400101 .atag_offset = 0x100,
Russell King71ee7da2010-05-23 10:18:16 +0100102 .reserve = omap_reserve,
Benoit Cousson8d616492011-09-20 21:24:47 +0200103 .map_io = omap242x_map_io,
104 .init_early = omap2420_init_early,
Tony Lindgren741e3a82011-05-17 03:51:26 -0700105 .init_irq = omap2_init_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
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,
125 .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