18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * 48c2ecf20Sopenharmony_ci * Copyright (C) 2009 Gabor Juhos <juhosg@openwrt.org> 58c2ecf20Sopenharmony_ci * Copyright (C) 2010 Joonas Lahtinen <joonas.lahtinen@gmail.com> 68c2ecf20Sopenharmony_ci * Copyright (C) 2013 John Crispin <john@phrozen.org> 78c2ecf20Sopenharmony_ci */ 88c2ecf20Sopenharmony_ci 98c2ecf20Sopenharmony_ci#include <linux/string.h> 108c2ecf20Sopenharmony_ci#include <linux/of_fdt.h> 118c2ecf20Sopenharmony_ci#include <linux/of_platform.h> 128c2ecf20Sopenharmony_ci 138c2ecf20Sopenharmony_ci#include <asm/bootinfo.h> 148c2ecf20Sopenharmony_ci#include <asm/addrspace.h> 158c2ecf20Sopenharmony_ci 168c2ecf20Sopenharmony_ci#include <asm/mach-ralink/ralink_regs.h> 178c2ecf20Sopenharmony_ci 188c2ecf20Sopenharmony_ci#include "common.h" 198c2ecf20Sopenharmony_ci 208c2ecf20Sopenharmony_cistruct ralink_soc_info soc_info; 218c2ecf20Sopenharmony_cistruct rt2880_pmx_group *rt2880_pinmux_data = NULL; 228c2ecf20Sopenharmony_ci 238c2ecf20Sopenharmony_cienum ralink_soc_type ralink_soc; 248c2ecf20Sopenharmony_ciEXPORT_SYMBOL_GPL(ralink_soc); 258c2ecf20Sopenharmony_ci 268c2ecf20Sopenharmony_ciconst char *get_system_type(void) 278c2ecf20Sopenharmony_ci{ 288c2ecf20Sopenharmony_ci return soc_info.sys_type; 298c2ecf20Sopenharmony_ci} 308c2ecf20Sopenharmony_ci 318c2ecf20Sopenharmony_cistatic __init void prom_init_cmdline(void) 328c2ecf20Sopenharmony_ci{ 338c2ecf20Sopenharmony_ci int argc; 348c2ecf20Sopenharmony_ci char **argv; 358c2ecf20Sopenharmony_ci int i; 368c2ecf20Sopenharmony_ci 378c2ecf20Sopenharmony_ci pr_debug("prom: fw_arg0=%08x fw_arg1=%08x fw_arg2=%08x fw_arg3=%08x\n", 388c2ecf20Sopenharmony_ci (unsigned int)fw_arg0, (unsigned int)fw_arg1, 398c2ecf20Sopenharmony_ci (unsigned int)fw_arg2, (unsigned int)fw_arg3); 408c2ecf20Sopenharmony_ci 418c2ecf20Sopenharmony_ci argc = fw_arg0; 428c2ecf20Sopenharmony_ci argv = (char **) KSEG1ADDR(fw_arg1); 438c2ecf20Sopenharmony_ci 448c2ecf20Sopenharmony_ci if (!argv) { 458c2ecf20Sopenharmony_ci pr_debug("argv=%p is invalid, skipping\n", 468c2ecf20Sopenharmony_ci argv); 478c2ecf20Sopenharmony_ci return; 488c2ecf20Sopenharmony_ci } 498c2ecf20Sopenharmony_ci 508c2ecf20Sopenharmony_ci for (i = 0; i < argc; i++) { 518c2ecf20Sopenharmony_ci char *p = (char *) KSEG1ADDR(argv[i]); 528c2ecf20Sopenharmony_ci 538c2ecf20Sopenharmony_ci if (CPHYSADDR(p) && *p) { 548c2ecf20Sopenharmony_ci pr_debug("argv[%d]: %s\n", i, p); 558c2ecf20Sopenharmony_ci strlcat(arcs_cmdline, " ", sizeof(arcs_cmdline)); 568c2ecf20Sopenharmony_ci strlcat(arcs_cmdline, p, sizeof(arcs_cmdline)); 578c2ecf20Sopenharmony_ci } 588c2ecf20Sopenharmony_ci } 598c2ecf20Sopenharmony_ci} 608c2ecf20Sopenharmony_ci 618c2ecf20Sopenharmony_civoid __init prom_init(void) 628c2ecf20Sopenharmony_ci{ 638c2ecf20Sopenharmony_ci prom_soc_init(&soc_info); 648c2ecf20Sopenharmony_ci 658c2ecf20Sopenharmony_ci pr_info("SoC Type: %s\n", get_system_type()); 668c2ecf20Sopenharmony_ci 678c2ecf20Sopenharmony_ci prom_init_cmdline(); 688c2ecf20Sopenharmony_ci} 698c2ecf20Sopenharmony_ci 708c2ecf20Sopenharmony_civoid __init prom_free_prom_memory(void) 718c2ecf20Sopenharmony_ci{ 728c2ecf20Sopenharmony_ci} 73