// SPDX-License-Identifier: GPL-2.0-or-later /* * init.c, Common initialization routines for NEC VR4100 series. * * Copyright (C) 2003-2009 Yoichi Yuasa <yuasa@linux-mips.org> */ #include <linux/init.h> #include <linux/ioport.h> #include <linux/irq.h> #include <linux/string.h> #include <asm/bootinfo.h> #include <asm/time.h> #include <asm/vr41xx/irq.h> #include <asm/vr41xx/vr41xx.h> #define IO_MEM_RESOURCE_START 0UL #define IO_MEM_RESOURCE_END 0x1fffffffUL static void __init iomem_resource_init(void) { iomem_resource.start = IO_MEM_RESOURCE_START; iomem_resource.end = IO_MEM_RESOURCE_END; } void __init plat_time_init(void) { unsigned long tclock; vr41xx_calculate_clock_frequency(); tclock = vr41xx_get_tclock_frequency(); if (current_cpu_data.processor_id == PRID_VR4131_REV2_0 || current_cpu_data.processor_id == PRID_VR4131_REV2_1) mips_hpt_frequency = tclock / 2; else mips_hpt_frequency = tclock / 4; } void __init plat_mem_setup(void) { iomem_resource_init(); vr41xx_siu_setup(); } void __init prom_init(void) { int argc, i; char **argv; argc = fw_arg0; argv = (char **)fw_arg1; for (i = 1; i < argc; i++) { strlcat(arcs_cmdline, argv[i], COMMAND_LINE_SIZE); if (i < (argc - 1)) strlcat(arcs_cmdline, " ", COMMAND_LINE_SIZE); } } void __init prom_free_prom_memory(void) { } |