1 // SPDX-License-Identifier: GPL-2.0
2 //
3 // Samsung's S3C64XX flattened device tree enabled machine
4 //
5 // Copyright (c) 2013 Tomasz Figa <tomasz.figa@gmail.com>
6 
7 #include <asm/mach/arch.h>
8 #include <asm/mach/map.h>
9 #include <asm/system_misc.h>
10 
11 #include <plat/cpu.h>
12 #include <mach/map.h>
13 
14 #include "common.h"
15 #include "watchdog-reset.h"
16 
17 /*
18  * IO mapping for shared system controller IP.
19  *
20  * FIXME: Make remaining drivers use dynamic mapping.
21  */
22 static struct map_desc s3c64xx_dt_iodesc[] __initdata = {
23 	{
24 		.virtual	= (unsigned long)S3C_VA_SYS,
25 		.pfn		= __phys_to_pfn(S3C64XX_PA_SYSCON),
26 		.length		= SZ_4K,
27 		.type		= MT_DEVICE,
28 	},
29 };
30 
s3c64xx_dt_map_io(void)31 static void __init s3c64xx_dt_map_io(void)
32 {
33 	debug_ll_io_init();
34 	iotable_init(s3c64xx_dt_iodesc, ARRAY_SIZE(s3c64xx_dt_iodesc));
35 
36 	s3c64xx_init_cpu();
37 
38 	if (!soc_is_s3c64xx())
39 		panic("SoC is not S3C64xx!");
40 }
41 
s3c64xx_dt_init_machine(void)42 static void __init s3c64xx_dt_init_machine(void)
43 {
44 	samsung_wdt_reset_of_init();
45 }
46 
s3c64xx_dt_restart(enum reboot_mode mode,const char * cmd)47 static void s3c64xx_dt_restart(enum reboot_mode mode, const char *cmd)
48 {
49 	if (mode != REBOOT_SOFT)
50 		samsung_wdt_reset();
51 
52 	/* if all else fails, or mode was for soft, jump to 0 */
53 	soft_restart(0);
54 }
55 
56 static const char *const s3c64xx_dt_compat[] __initconst = {
57 	"samsung,s3c6400",
58 	"samsung,s3c6410",
59 	NULL
60 };
61 
62 DT_MACHINE_START(S3C6400_DT, "Samsung S3C64xx (Flattened Device Tree)")
63 	/* Maintainer: Tomasz Figa <tomasz.figa@gmail.com> */
64 	.dt_compat	= s3c64xx_dt_compat,
65 	.map_io		= s3c64xx_dt_map_io,
66 	.init_machine	= s3c64xx_dt_init_machine,
67 	.restart        = s3c64xx_dt_restart,
68 MACHINE_END
69