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) */ |
Vineet Gupta | 8d0d56b | 2015-02-02 19:23:21 +0530 | [diff] [blame] | 32 | else if (of_flat_dt_is_compatible(dt_root, "snps,arc-sdp")) |
Vineet Gupta | 5fa2daa | 2015-03-09 14:33:40 +0530 | [diff] [blame] | 33 | arc_base_baud = 33333333; /* Fixed 33MHz clk (AXS10x) */ |
Noam Camus | 19dbc76 | 2016-11-08 15:20:59 +0200 | [diff] [blame] | 34 | else if (of_flat_dt_is_compatible(dt_root, "ezchip,arc-nps")) |
| 35 | arc_base_baud = 800000000; /* Fixed 800MHz clk (NPS) */ |
Vineet Gupta | ffb7fcd | 2014-10-28 15:04:05 +0530 | [diff] [blame] | 36 | else |
Alexey Brodkin | 0e6e9b6 | 2016-02-01 16:31:14 +0300 | [diff] [blame] | 37 | arc_base_baud = 50000000; /* Fixed default 50MHz */ |
Vineet Gupta | ffb7fcd | 2014-10-28 15:04:05 +0530 | [diff] [blame] | 38 | } |
| 39 | #else |
| 40 | #define arc_set_early_base_baud(dt_root) |
| 41 | #endif |
| 42 | |
Rob Herring | 880beb8 | 2013-08-27 21:43:12 -0500 | [diff] [blame] | 43 | static const void * __init arch_get_next_mach(const char *const **match) |
| 44 | { |
| 45 | static const struct machine_desc *mdesc = __arch_info_begin; |
| 46 | const struct machine_desc *m = mdesc; |
| 47 | |
| 48 | if (m >= __arch_info_end) |
| 49 | return NULL; |
| 50 | |
| 51 | mdesc++; |
| 52 | *match = m->dt_compat; |
| 53 | return m; |
| 54 | } |
| 55 | |
Vineet Gupta | 999159a | 2013-01-22 17:00:52 +0530 | [diff] [blame] | 56 | /** |
| 57 | * setup_machine_fdt - Machine setup when an dtb was passed to the kernel |
| 58 | * @dt: virtual address pointer to dt blob |
| 59 | * |
| 60 | * If a dtb was passed to the kernel, then use it to choose the correct |
| 61 | * machine_desc and to setup the system. |
| 62 | */ |
Rob Herring | 880beb8 | 2013-08-27 21:43:12 -0500 | [diff] [blame] | 63 | const struct machine_desc * __init setup_machine_fdt(void *dt) |
Vineet Gupta | 999159a | 2013-01-22 17:00:52 +0530 | [diff] [blame] | 64 | { |
Rob Herring | 880beb8 | 2013-08-27 21:43:12 -0500 | [diff] [blame] | 65 | const struct machine_desc *mdesc; |
Vineet Gupta | 999159a | 2013-01-22 17:00:52 +0530 | [diff] [blame] | 66 | unsigned long dt_root; |
Vineet Gupta | 999159a | 2013-01-22 17:00:52 +0530 | [diff] [blame] | 67 | |
Rob Herring | ad81fcb | 2013-08-26 10:12:22 -0500 | [diff] [blame] | 68 | if (!early_init_dt_scan(dt)) |
Vineet Gupta | 03a6d28 | 2013-01-18 15:12:26 +0530 | [diff] [blame] | 69 | return NULL; |
Vineet Gupta | 999159a | 2013-01-22 17:00:52 +0530 | [diff] [blame] | 70 | |
Rob Herring | 880beb8 | 2013-08-27 21:43:12 -0500 | [diff] [blame] | 71 | mdesc = of_flat_dt_match_machine(NULL, arch_get_next_mach); |
| 72 | if (!mdesc) |
Vineet Gupta | 03a6d28 | 2013-01-18 15:12:26 +0530 | [diff] [blame] | 73 | machine_halt(); |
Vineet Gupta | 03a6d28 | 2013-01-18 15:12:26 +0530 | [diff] [blame] | 74 | |
Rob Herring | 880beb8 | 2013-08-27 21:43:12 -0500 | [diff] [blame] | 75 | dt_root = of_get_flat_dt_root(); |
Vineet Gupta | ffb7fcd | 2014-10-28 15:04:05 +0530 | [diff] [blame] | 76 | arc_set_early_base_baud(dt_root); |
| 77 | |
Rob Herring | 880beb8 | 2013-08-27 21:43:12 -0500 | [diff] [blame] | 78 | return mdesc; |
Vineet Gupta | 999159a | 2013-01-22 17:00:52 +0530 | [diff] [blame] | 79 | } |