2017-12-25 20:54:33 +01:00
|
|
|
// SPDX-License-Identifier: GPL-2.0
|
|
|
|
//
|
|
|
|
// Samsung's S3C64XX flattened device tree enabled machine
|
|
|
|
//
|
|
|
|
// Copyright (c) 2013 Tomasz Figa <tomasz.figa@gmail.com>
|
2013-08-26 02:37:51 +09:00
|
|
|
|
|
|
|
#include <asm/mach/arch.h>
|
|
|
|
#include <asm/mach/map.h>
|
|
|
|
#include <asm/system_misc.h>
|
|
|
|
|
2019-09-02 18:37:30 +02:00
|
|
|
#include "cpu.h"
|
|
|
|
#include "map.h"
|
2013-08-26 02:37:51 +09:00
|
|
|
|
2019-09-02 17:47:55 +02:00
|
|
|
#include "s3c64xx.h"
|
2013-08-26 02:37:51 +09:00
|
|
|
|
|
|
|
/*
|
|
|
|
* IO mapping for shared system controller IP.
|
|
|
|
*
|
|
|
|
* FIXME: Make remaining drivers use dynamic mapping.
|
|
|
|
*/
|
|
|
|
static struct map_desc s3c64xx_dt_iodesc[] __initdata = {
|
|
|
|
{
|
|
|
|
.virtual = (unsigned long)S3C_VA_SYS,
|
|
|
|
.pfn = __phys_to_pfn(S3C64XX_PA_SYSCON),
|
|
|
|
.length = SZ_4K,
|
|
|
|
.type = MT_DEVICE,
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
static void __init s3c64xx_dt_map_io(void)
|
|
|
|
{
|
|
|
|
debug_ll_io_init();
|
|
|
|
iotable_init(s3c64xx_dt_iodesc, ARRAY_SIZE(s3c64xx_dt_iodesc));
|
|
|
|
|
|
|
|
s3c64xx_init_cpu();
|
|
|
|
|
|
|
|
if (!soc_is_s3c64xx())
|
|
|
|
panic("SoC is not S3C64xx!");
|
|
|
|
}
|
|
|
|
|
2015-07-27 18:27:52 -04:00
|
|
|
static const char *const s3c64xx_dt_compat[] __initconst = {
|
2013-08-26 02:37:51 +09:00
|
|
|
"samsung,s3c6400",
|
|
|
|
"samsung,s3c6410",
|
|
|
|
NULL
|
|
|
|
};
|
|
|
|
|
|
|
|
DT_MACHINE_START(S3C6400_DT, "Samsung S3C64xx (Flattened Device Tree)")
|
|
|
|
/* Maintainer: Tomasz Figa <tomasz.figa@gmail.com> */
|
|
|
|
.dt_compat = s3c64xx_dt_compat,
|
|
|
|
.map_io = s3c64xx_dt_map_io,
|
|
|
|
MACHINE_END
|