blob: 25d195ff1cb1d151a48dacf5a5786da07b067ad0 [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>
Benoit Coussonfbf75da2011-09-21 23:30:31 +020015#include <linux/of_irq.h>
Benoit Cousson8d616492011-09-20 21:24:47 +020016#include <linux/of_platform.h>
17#include <linux/irqdomain.h>
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020018#include <linux/i2c/twl.h>
Tony Lindgren1dbae812005-11-10 14:26:51 +000019
Russell Kinga09e64f2008-08-05 16:14:15 +010020#include <mach/hardware.h>
Benoit Coussonb7557062011-12-07 11:47:40 -080021#include <asm/hardware/gic.h>
Tony Lindgren1dbae812005-11-10 14:26:51 +000022#include <asm/mach/arch.h>
Tony Lindgren1dbae812005-11-10 14:26:51 +000023
Tony Lindgrence491cf2009-10-20 09:40:47 -070024#include <plat/board.h>
Tony Lindgren4e653312011-11-10 22:45:17 +010025#include "common.h"
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020026#include "common-board-devices.h"
Tony Lindgren1dbae812005-11-10 14:26:51 +000027
Tony Lindgren75a57fe2012-03-05 13:47:28 -080028#if !(defined(CONFIG_ARCH_OMAP2) || defined(CONFIG_ARCH_OMAP3))
29#define omap_intc_of_init NULL
30#endif
31#ifndef CONFIG_ARCH_OMAP4
32#define gic_of_init NULL
33#endif
34
Benoit Coussonfbf75da2011-09-21 23:30:31 +020035static struct of_device_id irq_match[] __initdata = {
36 { .compatible = "ti,omap2-intc", .data = omap_intc_of_init, },
37 { .compatible = "arm,cortex-a9-gic", .data = gic_of_init, },
38 { }
39};
40
41static void __init omap_init_irq(void)
42{
43 of_irq_init(irq_match);
44}
45
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020046/*
47 * XXX: Still needed to boot until the i2c & twl driver is adapted to
48 * device-tree
49 */
Sanjeev Premic4e2d242011-10-13 21:44:10 +053050#ifdef CONFIG_ARCH_OMAP4
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020051static struct twl4030_platform_data sdp4430_twldata = {
52 .irq_base = TWL6030_IRQ_BASE,
53 .irq_end = TWL6030_IRQ_END,
54};
55
56static void __init omap4_i2c_init(void)
57{
58 omap4_pmic_init("twl6030", &sdp4430_twldata);
59}
Sanjeev Premic4e2d242011-10-13 21:44:10 +053060#endif
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020061
Sanjeev Premic4e2d242011-10-13 21:44:10 +053062#ifdef CONFIG_ARCH_OMAP3
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020063static struct twl4030_platform_data beagle_twldata = {
64 .irq_base = TWL4030_IRQ_BASE,
65 .irq_end = TWL4030_IRQ_END,
66};
67
68static void __init omap3_i2c_init(void)
69{
70 omap3_pmic_init("twl4030", &beagle_twldata);
71}
Sanjeev Premic4e2d242011-10-13 21:44:10 +053072#endif
Benoit Cousson8d616492011-09-20 21:24:47 +020073
74static struct of_device_id omap_dt_match_table[] __initdata = {
75 { .compatible = "simple-bus", },
76 { .compatible = "ti,omap-infra", },
77 { }
Paul Walmsleyb3c6df32009-09-03 20:14:02 +030078};
79
Tony Lindgren1dbae812005-11-10 14:26:51 +000080static void __init omap_generic_init(void)
81{
Tony Lindgrena4ca9db2011-08-22 23:57:23 -070082 omap_sdrc_init(NULL, NULL);
Benoit Cousson8d616492011-09-20 21:24:47 +020083
84 of_platform_populate(NULL, omap_dt_match_table, NULL, NULL);
Tony Lindgren1dbae812005-11-10 14:26:51 +000085}
86
Sanjeev Premic4e2d242011-10-13 21:44:10 +053087#ifdef CONFIG_ARCH_OMAP4
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020088static void __init omap4_init(void)
89{
90 omap4_i2c_init();
91 omap_generic_init();
92}
Sanjeev Premic4e2d242011-10-13 21:44:10 +053093#endif
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020094
Sanjeev Premic4e2d242011-10-13 21:44:10 +053095#ifdef CONFIG_ARCH_OMAP3
Benoit Coussona7cbb9b2011-09-22 21:52:02 +020096static void __init omap3_init(void)
97{
98 omap3_i2c_init();
99 omap_generic_init();
100}
Sanjeev Premic4e2d242011-10-13 21:44:10 +0530101#endif
Benoit Coussona7cbb9b2011-09-22 21:52:02 +0200102
Benoit Cousson0e02a8c12011-12-01 11:05:17 +0100103#ifdef CONFIG_SOC_OMAP2420
Benoit Cousson8d616492011-09-20 21:24:47 +0200104static const char *omap242x_boards_compat[] __initdata = {
105 "ti,omap2420",
106 NULL,
107};
Tony Lindgren1dbae812005-11-10 14:26:51 +0000108
Benoit Cousson8d616492011-09-20 21:24:47 +0200109DT_MACHINE_START(OMAP242X_DT, "Generic OMAP2420 (Flattened Device Tree)")
Russell King71ee7da2010-05-23 10:18:16 +0100110 .reserve = omap_reserve,
Benoit Cousson8d616492011-09-20 21:24:47 +0200111 .map_io = omap242x_map_io,
112 .init_early = omap2420_init_early,
Benoit Coussonfbf75da2011-09-21 23:30:31 +0200113 .init_irq = omap_init_irq,
Benoit Coussonb7557062011-12-07 11:47:40 -0800114 .handle_irq = omap2_intc_handle_irq,
Tony Lindgren1dbae812005-11-10 14:26:51 +0000115 .init_machine = omap_generic_init,
Arnd Bergmann13340b22011-06-30 12:58:01 +0000116 .timer = &omap2_timer,
Benoit Cousson8d616492011-09-20 21:24:47 +0200117 .dt_compat = omap242x_boards_compat,
Russell Kingbaa95882011-11-05 17:06:28 +0000118 .restart = omap_prcm_restart,
Tony Lindgren1dbae812005-11-10 14:26:51 +0000119MACHINE_END
Benoit Cousson8d616492011-09-20 21:24:47 +0200120#endif
121
Benoit Cousson0e02a8c12011-12-01 11:05:17 +0100122#ifdef CONFIG_SOC_OMAP2430
Benoit Cousson8d616492011-09-20 21:24:47 +0200123static const char *omap243x_boards_compat[] __initdata = {
124 "ti,omap2430",
125 NULL,
126};
127
128DT_MACHINE_START(OMAP243X_DT, "Generic OMAP2430 (Flattened Device Tree)")
129 .reserve = omap_reserve,
130 .map_io = omap243x_map_io,
131 .init_early = omap2430_init_early,
Benoit Coussonfbf75da2011-09-21 23:30:31 +0200132 .init_irq = omap_init_irq,
Marc Zyngier6b2f55d2011-09-06 10:23:45 +0100133 .handle_irq = omap2_intc_handle_irq,
Benoit Cousson8d616492011-09-20 21:24:47 +0200134 .init_machine = omap_generic_init,
135 .timer = &omap2_timer,
136 .dt_compat = omap243x_boards_compat,
Russell Kingbaa95882011-11-05 17:06:28 +0000137 .restart = omap_prcm_restart,
Benoit Cousson8d616492011-09-20 21:24:47 +0200138MACHINE_END
139#endif
140
Benoit Cousson0e02a8c12011-12-01 11:05:17 +0100141#ifdef CONFIG_ARCH_OMAP3
Benoit Cousson8d616492011-09-20 21:24:47 +0200142static const char *omap3_boards_compat[] __initdata = {
143 "ti,omap3",
144 NULL,
145};
146
147DT_MACHINE_START(OMAP3_DT, "Generic OMAP3 (Flattened Device Tree)")
148 .reserve = omap_reserve,
149 .map_io = omap3_map_io,
150 .init_early = omap3430_init_early,
Benoit Coussonfbf75da2011-09-21 23:30:31 +0200151 .init_irq = omap_init_irq,
Benoit Coussonb7557062011-12-07 11:47:40 -0800152 .handle_irq = omap3_intc_handle_irq,
Benoit Coussona7cbb9b2011-09-22 21:52:02 +0200153 .init_machine = omap3_init,
Benoit Cousson8d616492011-09-20 21:24:47 +0200154 .timer = &omap3_timer,
155 .dt_compat = omap3_boards_compat,
Russell Kingbaa95882011-11-05 17:06:28 +0000156 .restart = omap_prcm_restart,
Benoit Cousson8d616492011-09-20 21:24:47 +0200157MACHINE_END
158#endif
159
Benoit Cousson0e02a8c12011-12-01 11:05:17 +0100160#ifdef CONFIG_ARCH_OMAP4
Benoit Cousson8d616492011-09-20 21:24:47 +0200161static const char *omap4_boards_compat[] __initdata = {
162 "ti,omap4",
163 NULL,
164};
165
166DT_MACHINE_START(OMAP4_DT, "Generic OMAP4 (Flattened Device Tree)")
167 .reserve = omap_reserve,
168 .map_io = omap4_map_io,
169 .init_early = omap4430_init_early,
Benoit Coussonfbf75da2011-09-21 23:30:31 +0200170 .init_irq = omap_init_irq,
Benoit Coussonb7557062011-12-07 11:47:40 -0800171 .handle_irq = gic_handle_irq,
Benoit Coussona7cbb9b2011-09-22 21:52:02 +0200172 .init_machine = omap4_init,
Benoit Cousson8d616492011-09-20 21:24:47 +0200173 .timer = &omap4_timer,
174 .dt_compat = omap4_boards_compat,
Russell Kingbaa95882011-11-05 17:06:28 +0000175 .restart = omap_prcm_restart,
Benoit Cousson8d616492011-09-20 21:24:47 +0200176MACHINE_END
177#endif