Vineet Gupta | 999159a | 2013-01-22 17:00:52 +0530 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2012 Synopsys, Inc. (www.synopsys.com) |
| 3 | * |
| 4 | * Based on reduced version of METAG |
| 5 | * |
| 6 | * This program is free software; you can redistribute it and/or modify |
| 7 | * it under the terms of the GNU General Public License version 2 as |
| 8 | * published by the Free Software Foundation. |
| 9 | */ |
| 10 | |
| 11 | |
| 12 | #include <linux/init.h> |
| 13 | #include <linux/reboot.h> |
| 14 | #include <linux/memblock.h> |
| 15 | #include <linux/of.h> |
| 16 | #include <linux/of_fdt.h> |
Vineet Gupta | 03a6d28 | 2013-01-18 15:12:26 +0530 | [diff] [blame] | 17 | #include <asm/mach_desc.h> |
Vineet Gupta | 999159a | 2013-01-22 17:00:52 +0530 | [diff] [blame] | 18 | |
Peter Hurley | 091f56b | 2015-02-03 20:08:52 -0500 | [diff] [blame] | 19 | #ifdef CONFIG_SERIAL_EARLYCON |
Vineet Gupta | ffb7fcd | 2014-10-28 15:04:05 +0530 | [diff] [blame] | 20 | |
| 21 | static unsigned int __initdata arc_base_baud; |
| 22 | |
| 23 | unsigned int __init arc_early_base_baud(void) |
| 24 | { |
| 25 | return arc_base_baud/16; |
| 26 | } |
| 27 | |
| 28 | static void __init arc_set_early_base_baud(unsigned long dt_root) |
| 29 | { |
Vineet Gupta | ffb7fcd | 2014-10-28 15:04:05 +0530 | [diff] [blame] | 30 | if (of_flat_dt_is_compatible(dt_root, "abilis,arc-tb10x")) |
Alexey Brodkin | 0e6e9b6 | 2016-02-01 16:31:14 +0300 | [diff] [blame] | 31 | arc_base_baud = 166666666; /* Fixed 166.6MHz clk (TB10x) */ |
Alexey Brodkin | a518d63 | 2017-08-15 21:13:55 +0300 | [diff] [blame] | 32 | else if (of_flat_dt_is_compatible(dt_root, "snps,arc-sdp") || |
| 33 | of_flat_dt_is_compatible(dt_root, "snps,hsdk")) |
| 34 | arc_base_baud = 33333333; /* Fixed 33MHz clk (AXS10x & HSDK) */ |
Noam Camus | 19dbc76 | 2016-11-08 15:20:59 +0200 | [diff] [blame] | 35 | else if (of_flat_dt_is_compatible(dt_root, "ezchip,arc-nps")) |
| 36 | arc_base_baud = 800000000; /* Fixed 800MHz clk (NPS) */ |
Vineet Gupta | ffb7fcd | 2014-10-28 15:04:05 +0530 | [diff] [blame] | 37 | else |
Alexey Brodkin | 0e6e9b6 | 2016-02-01 16:31:14 +0300 | [diff] [blame] | 38 | arc_base_baud = 50000000; /* Fixed default 50MHz */ |
Vineet Gupta | ffb7fcd | 2014-10-28 15:04:05 +0530 | [diff] [blame] | 39 | } |
| 40 | #else |
| 41 | #define arc_set_early_base_baud(dt_root) |
| 42 | #endif |
| 43 | |
Rob Herring | 880beb8 | 2013-08-27 21:43:12 -0500 | [diff] [blame] | 44 | static const void * __init arch_get_next_mach(const char *const **match) |
| 45 | { |
| 46 | static const struct machine_desc *mdesc = __arch_info_begin; |
| 47 | const struct machine_desc *m = mdesc; |
| 48 | |
| 49 | if (m >= __arch_info_end) |
| 50 | return NULL; |
| 51 | |
| 52 | mdesc++; |
| 53 | *match = m->dt_compat; |
| 54 | return m; |
| 55 | } |
| 56 | |
Vineet Gupta | 999159a | 2013-01-22 17:00:52 +0530 | [diff] [blame] | 57 | /** |
| 58 | * setup_machine_fdt - Machine setup when an dtb was passed to the kernel |
| 59 | * @dt: virtual address pointer to dt blob |
| 60 | * |
| 61 | * If a dtb was passed to the kernel, then use it to choose the correct |
| 62 | * machine_desc and to setup the system. |
| 63 | */ |
Rob Herring | 880beb8 | 2013-08-27 21:43:12 -0500 | [diff] [blame] | 64 | const struct machine_desc * __init setup_machine_fdt(void *dt) |
Vineet Gupta | 999159a | 2013-01-22 17:00:52 +0530 | [diff] [blame] | 65 | { |
Rob Herring | 880beb8 | 2013-08-27 21:43:12 -0500 | [diff] [blame] | 66 | const struct machine_desc *mdesc; |
Vineet Gupta | 999159a | 2013-01-22 17:00:52 +0530 | [diff] [blame] | 67 | unsigned long dt_root; |
Vineet Gupta | 999159a | 2013-01-22 17:00:52 +0530 | [diff] [blame] | 68 | |
Rob Herring | ad81fcb | 2013-08-26 10:12:22 -0500 | [diff] [blame] | 69 | if (!early_init_dt_scan(dt)) |
Vineet Gupta | 03a6d28 | 2013-01-18 15:12:26 +0530 | [diff] [blame] | 70 | return NULL; |
Vineet Gupta | 999159a | 2013-01-22 17:00:52 +0530 | [diff] [blame] | 71 | |
Rob Herring | 880beb8 | 2013-08-27 21:43:12 -0500 | [diff] [blame] | 72 | mdesc = of_flat_dt_match_machine(NULL, arch_get_next_mach); |
| 73 | if (!mdesc) |
Vineet Gupta | 03a6d28 | 2013-01-18 15:12:26 +0530 | [diff] [blame] | 74 | machine_halt(); |
Vineet Gupta | 03a6d28 | 2013-01-18 15:12:26 +0530 | [diff] [blame] | 75 | |
Rob Herring | 880beb8 | 2013-08-27 21:43:12 -0500 | [diff] [blame] | 76 | dt_root = of_get_flat_dt_root(); |
Vineet Gupta | ffb7fcd | 2014-10-28 15:04:05 +0530 | [diff] [blame] | 77 | arc_set_early_base_baud(dt_root); |
| 78 | |
Rob Herring | 880beb8 | 2013-08-27 21:43:12 -0500 | [diff] [blame] | 79 | return mdesc; |
Vineet Gupta | 999159a | 2013-01-22 17:00:52 +0530 | [diff] [blame] | 80 | } |