board-generic.c 4.8 KB
Newer Older
1 2 3 4
/*
 * Copyright (C) 2005 Nokia Corporation
 * Author: Paul Mundt <paul.mundt@nokia.com>
 *
5
 * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/
6
 *
7 8
 * Modified from the original mach-omap/omap2/board-generic.c did by Paul
 * to support the OMAP2+ device tree boards with an unique board file.
9 10 11 12 13
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 */
14
#include <linux/io.h>
15
#include <linux/of_irq.h>
16 17
#include <linux/of_platform.h>
#include <linux/irqdomain.h>
18

19
#include <asm/hardware/gic.h>
20 21
#include <asm/mach/arch.h>

22
#include "common.h"
23
#include "common-board-devices.h"
24
#include "dss-common.h"
25

26
#if !(defined(CONFIG_ARCH_OMAP2) || defined(CONFIG_ARCH_OMAP3))
27
#define intc_of_init	NULL
28 29 30 31 32
#endif
#ifndef CONFIG_ARCH_OMAP4
#define gic_of_init		NULL
#endif

33 34 35 36
static struct of_device_id omap_dt_match_table[] __initdata = {
	{ .compatible = "simple-bus", },
	{ .compatible = "ti,omap-infra", },
	{ }
37 38
};

39 40
static void __init omap_generic_init(void)
{
41
	omap_sdrc_init(NULL, NULL);
42

43
	of_platform_populate(NULL, omap_dt_match_table, NULL, NULL);
44 45 46 47 48 49 50 51 52

	/*
	 * HACK: call display setup code for selected boards to enable omapdss.
	 * This will be removed when omapdss supports DT.
	 */
	if (of_machine_is_compatible("ti,omap4-panda"))
		omap4_panda_display_init_of();
	else if (of_machine_is_compatible("ti,omap4-sdp"))
		omap_4430sdp_display_init_of();
53 54
}

55
#ifdef CONFIG_SOC_OMAP2420
56 57 58 59 60 61 62 63 64
static const char *omap242x_boards_compat[] __initdata = {
	"ti,omap2420",
	NULL,
};

DT_MACHINE_START(OMAP242X_DT, "Generic OMAP2420 (Flattened Device Tree)")
	.reserve	= omap_reserve,
	.map_io		= omap242x_map_io,
	.init_early	= omap2420_init_early,
65
	.init_irq	= omap_intc_of_init,
66
	.handle_irq	= omap2_intc_handle_irq,
67 68 69
	.init_machine	= omap_generic_init,
	.timer		= &omap2_timer,
	.dt_compat	= omap242x_boards_compat,
70
	.restart	= omap2xxx_restart,
71 72 73
MACHINE_END
#endif

74
#ifdef CONFIG_SOC_OMAP2430
75 76 77 78 79 80
static const char *omap243x_boards_compat[] __initdata = {
	"ti,omap2430",
	NULL,
};

DT_MACHINE_START(OMAP243X_DT, "Generic OMAP2430 (Flattened Device Tree)")
81
	.reserve	= omap_reserve,
82 83
	.map_io		= omap243x_map_io,
	.init_early	= omap2430_init_early,
84
	.init_irq	= omap_intc_of_init,
85
	.handle_irq	= omap2_intc_handle_irq,
86
	.init_machine	= omap_generic_init,
A
Arnd Bergmann 已提交
87
	.timer		= &omap2_timer,
88
	.dt_compat	= omap243x_boards_compat,
89
	.restart	= omap2xxx_restart,
90 91 92
MACHINE_END
#endif

93
#ifdef CONFIG_ARCH_OMAP3
94 95 96 97 98 99 100 101 102
static const char *omap3_boards_compat[] __initdata = {
	"ti,omap3",
	NULL,
};

DT_MACHINE_START(OMAP3_DT, "Generic OMAP3 (Flattened Device Tree)")
	.reserve	= omap_reserve,
	.map_io		= omap3_map_io,
	.init_early	= omap3430_init_early,
103
	.init_irq	= omap_intc_of_init,
104
	.handle_irq	= omap3_intc_handle_irq,
105
	.init_machine	= omap_generic_init,
106 107
	.timer		= &omap3_timer,
	.dt_compat	= omap3_boards_compat,
108
	.restart	= omap3xxx_restart,
109
MACHINE_END
110 111 112 113 114 115 116 117 118 119 120 121 122 123 124

static const char *omap3_gp_boards_compat[] __initdata = {
	"ti,omap3-beagle",
	NULL,
};

DT_MACHINE_START(OMAP3_GP_DT, "Generic OMAP3-GP (Flattened Device Tree)")
	.reserve	= omap_reserve,
	.map_io		= omap3_map_io,
	.init_early	= omap3430_init_early,
	.init_irq	= omap_intc_of_init,
	.handle_irq	= omap3_intc_handle_irq,
	.init_machine	= omap_generic_init,
	.timer		= &omap3_secure_timer,
	.dt_compat	= omap3_gp_boards_compat,
125
	.restart	= omap3xxx_restart,
126 127 128
MACHINE_END
#endif

129 130 131 132 133 134 135 136 137 138
#ifdef CONFIG_SOC_AM33XX
static const char *am33xx_boards_compat[] __initdata = {
	"ti,am33xx",
	NULL,
};

DT_MACHINE_START(AM33XX_DT, "Generic AM33XX (Flattened Device Tree)")
	.reserve	= omap_reserve,
	.map_io		= am33xx_map_io,
	.init_early	= am33xx_init_early,
139
	.init_irq	= omap_intc_of_init,
140 141 142 143 144 145 146
	.handle_irq	= omap3_intc_handle_irq,
	.init_machine	= omap_generic_init,
	.timer		= &omap3_am33xx_timer,
	.dt_compat	= am33xx_boards_compat,
MACHINE_END
#endif

147
#ifdef CONFIG_ARCH_OMAP4
148 149 150 151 152 153 154
static const char *omap4_boards_compat[] __initdata = {
	"ti,omap4",
	NULL,
};

DT_MACHINE_START(OMAP4_DT, "Generic OMAP4 (Flattened Device Tree)")
	.reserve	= omap_reserve,
155
	.smp		= smp_ops(omap4_smp_ops),
156 157
	.map_io		= omap4_map_io,
	.init_early	= omap4430_init_early,
158
	.init_irq	= omap_gic_of_init,
159
	.handle_irq	= gic_handle_irq,
160
	.init_machine	= omap_generic_init,
161
	.init_late	= omap4430_init_late,
162 163
	.timer		= &omap4_timer,
	.dt_compat	= omap4_boards_compat,
164
	.restart	= omap44xx_restart,
165
MACHINE_END
166
#endif
167 168 169 170 171 172 173 174 175

#ifdef CONFIG_SOC_OMAP5
static const char *omap5_boards_compat[] __initdata = {
	"ti,omap5",
	NULL,
};

DT_MACHINE_START(OMAP5_DT, "Generic OMAP5 (Flattened Device Tree)")
	.reserve	= omap_reserve,
176
	.smp		= smp_ops(omap4_smp_ops),
177 178 179 180 181 182 183
	.map_io		= omap5_map_io,
	.init_early	= omap5_init_early,
	.init_irq	= omap_gic_of_init,
	.handle_irq	= gic_handle_irq,
	.init_machine	= omap_generic_init,
	.timer		= &omap5_timer,
	.dt_compat	= omap5_boards_compat,
184
	.restart	= omap44xx_restart,
185 186
MACHINE_END
#endif