17f627f03SMagnus Damm /*
27f627f03SMagnus Damm  * Emma Mobile EV2 processor support
37f627f03SMagnus Damm  *
47f627f03SMagnus Damm  * Copyright (C) 2012  Magnus Damm
57f627f03SMagnus Damm  *
67f627f03SMagnus Damm  * This program is free software; you can redistribute it and/or modify
77f627f03SMagnus Damm  * it under the terms of the GNU General Public License as published by
87f627f03SMagnus Damm  * the Free Software Foundation; version 2 of the License.
97f627f03SMagnus Damm  *
107f627f03SMagnus Damm  * This program is distributed in the hope that it will be useful,
117f627f03SMagnus Damm  * but WITHOUT ANY WARRANTY; without even the implied warranty of
127f627f03SMagnus Damm  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
137f627f03SMagnus Damm  * GNU General Public License for more details.
147f627f03SMagnus Damm  *
157f627f03SMagnus Damm  * You should have received a copy of the GNU General Public License
167f627f03SMagnus Damm  * along with this program; if not, write to the Free Software
177f627f03SMagnus Damm  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
187f627f03SMagnus Damm  */
197f627f03SMagnus Damm #include <linux/kernel.h>
207f627f03SMagnus Damm #include <linux/init.h>
21af164ca3SMagnus Damm #include <linux/mm.h>
227f627f03SMagnus Damm #include <asm/mach-types.h>
237f627f03SMagnus Damm #include <asm/mach/arch.h>
247f627f03SMagnus Damm #include <asm/mach/map.h>
25fd44aa5eSMagnus Damm #include "common.h"
267f627f03SMagnus Damm 
27bd5a875dSMagnus Damm static struct map_desc emev2_io_desc[] __initdata = {
28bd5a875dSMagnus Damm #ifdef CONFIG_SMP
29bd5a875dSMagnus Damm 	/* 2M mapping for SCU + L2 controller */
30bd5a875dSMagnus Damm 	{
31bd5a875dSMagnus Damm 		.virtual	= 0xf0000000,
32bd5a875dSMagnus Damm 		.pfn		= __phys_to_pfn(0x1e000000),
33bd5a875dSMagnus Damm 		.length		= SZ_2M,
34bd5a875dSMagnus Damm 		.type		= MT_DEVICE
35bd5a875dSMagnus Damm 	},
36bd5a875dSMagnus Damm #endif
37bd5a875dSMagnus Damm };
38bd5a875dSMagnus Damm 
39505891ecSMagnus Damm static void __init emev2_map_io(void)
40bd5a875dSMagnus Damm {
41bd5a875dSMagnus Damm 	iotable_init(emev2_io_desc, ARRAY_SIZE(emev2_io_desc));
42bd5a875dSMagnus Damm }
43bd5a875dSMagnus Damm 
44d24d1780SSimon Horman static const char *emev2_boards_compat_dt[] __initconst = {
453d5de271SMagnus Damm 	"renesas,emev2",
463d5de271SMagnus Damm 	NULL,
473d5de271SMagnus Damm };
483d5de271SMagnus Damm 
49505891ecSMagnus Damm extern struct smp_operations emev2_smp_ops;
50505891ecSMagnus Damm 
513d5de271SMagnus Damm DT_MACHINE_START(EMEV2_DT, "Generic Emma Mobile EV2 (Flattened Device Tree)")
52a62580e5SMarc Zyngier 	.smp		= smp_ops(emev2_smp_ops),
530ea2b538SMagnus Damm 	.map_io		= emev2_map_io,
54ef9026e6SMagnus Damm 	.init_early	= shmobile_init_delay,
553f348e1cSMagnus Damm 	.init_late	= shmobile_init_late,
563d5de271SMagnus Damm 	.dt_compat	= emev2_boards_compat_dt,
573d5de271SMagnus Damm MACHINE_END
58