blob: fa86d13df5edb57925120be470ed97a19662d1fb [file] [log] [blame]
Thomas Gleixnerd2912cb2019-06-04 10:11:33 +02001// SPDX-License-Identifier: GPL-2.0-only
Vineet Gupta999159a2013-01-22 17:00:52 +05302/*
3 * Copyright (C) 2012 Synopsys, Inc. (www.synopsys.com)
4 *
5 * Based on reduced version of METAG
Vineet Gupta999159a2013-01-22 17:00:52 +05306 */
7
8
9#include <linux/init.h>
10#include <linux/reboot.h>
11#include <linux/memblock.h>
12#include <linux/of.h>
13#include <linux/of_fdt.h>
Vineet Gupta03a6d282013-01-18 15:12:26 +053014#include <asm/mach_desc.h>
Vineet Gupta999159a2013-01-22 17:00:52 +053015
Peter Hurley091f56b2015-02-03 20:08:52 -050016#ifdef CONFIG_SERIAL_EARLYCON
Vineet Guptaffb7fcd2014-10-28 15:04:05 +053017
18static unsigned int __initdata arc_base_baud;
19
20unsigned int __init arc_early_base_baud(void)
21{
22 return arc_base_baud/16;
23}
24
25static void __init arc_set_early_base_baud(unsigned long dt_root)
26{
Vineet Guptaffb7fcd2014-10-28 15:04:05 +053027 if (of_flat_dt_is_compatible(dt_root, "abilis,arc-tb10x"))
Alexey Brodkin0e6e9b62016-02-01 16:31:14 +030028 arc_base_baud = 166666666; /* Fixed 166.6MHz clk (TB10x) */
Alexey Brodkina518d632017-08-15 21:13:55 +030029 else if (of_flat_dt_is_compatible(dt_root, "snps,arc-sdp") ||
30 of_flat_dt_is_compatible(dt_root, "snps,hsdk"))
31 arc_base_baud = 33333333; /* Fixed 33MHz clk (AXS10x & HSDK) */
Noam Camus19dbc762016-11-08 15:20:59 +020032 else if (of_flat_dt_is_compatible(dt_root, "ezchip,arc-nps"))
33 arc_base_baud = 800000000; /* Fixed 800MHz clk (NPS) */
Vineet Guptaffb7fcd2014-10-28 15:04:05 +053034 else
Alexey Brodkin0e6e9b62016-02-01 16:31:14 +030035 arc_base_baud = 50000000; /* Fixed default 50MHz */
Vineet Guptaffb7fcd2014-10-28 15:04:05 +053036}
37#else
38#define arc_set_early_base_baud(dt_root)
39#endif
40
Rob Herring880beb82013-08-27 21:43:12 -050041static const void * __init arch_get_next_mach(const char *const **match)
42{
43 static const struct machine_desc *mdesc = __arch_info_begin;
44 const struct machine_desc *m = mdesc;
45
46 if (m >= __arch_info_end)
47 return NULL;
48
49 mdesc++;
50 *match = m->dt_compat;
51 return m;
52}
53
Vineet Gupta999159a2013-01-22 17:00:52 +053054/**
55 * setup_machine_fdt - Machine setup when an dtb was passed to the kernel
56 * @dt: virtual address pointer to dt blob
57 *
58 * If a dtb was passed to the kernel, then use it to choose the correct
59 * machine_desc and to setup the system.
60 */
Rob Herring880beb82013-08-27 21:43:12 -050061const struct machine_desc * __init setup_machine_fdt(void *dt)
Vineet Gupta999159a2013-01-22 17:00:52 +053062{
Rob Herring880beb82013-08-27 21:43:12 -050063 const struct machine_desc *mdesc;
Vineet Gupta999159a2013-01-22 17:00:52 +053064 unsigned long dt_root;
Vineet Gupta999159a2013-01-22 17:00:52 +053065
Rob Herringad81fcb2013-08-26 10:12:22 -050066 if (!early_init_dt_scan(dt))
Vineet Gupta03a6d282013-01-18 15:12:26 +053067 return NULL;
Vineet Gupta999159a2013-01-22 17:00:52 +053068
Rob Herring880beb82013-08-27 21:43:12 -050069 mdesc = of_flat_dt_match_machine(NULL, arch_get_next_mach);
70 if (!mdesc)
Vineet Gupta03a6d282013-01-18 15:12:26 +053071 machine_halt();
Vineet Gupta03a6d282013-01-18 15:12:26 +053072
Rob Herring880beb82013-08-27 21:43:12 -050073 dt_root = of_get_flat_dt_root();
Vineet Guptaffb7fcd2014-10-28 15:04:05 +053074 arc_set_early_base_baud(dt_root);
75
Rob Herring880beb82013-08-27 21:43:12 -050076 return mdesc;
Vineet Gupta999159a2013-01-22 17:00:52 +053077}