ff2c8252bf
smp_ops providers do not modify their ops structures, so they should be made const for robustness. Since currently the MIPS kernel is not mapped with memory protection, this does not in itself provide any security benefit, but it still makes sense to make this change. There are also slight code size efficincies from the structure being made read-only, saving 128 bytes of kernel text on a pistachio_defconfig. Before: text data bss dec hex filename 7187239 1772752 470224 9430215 8fe4c7 vmlinux After: text data bss dec hex filename 7187111 1772752 470224 9430087 8fe447 vmlinux Signed-off-by: Matt Redfearn <matt.redfearn@imgtec.com> Cc: Sebastian Andrzej Siewior <bigeasy@linutronix.de> Cc: Arnd Bergmann <arnd@arndb.de> Cc: Marcin Nowakowski <marcin.nowakowski@imgtec.com> Cc: Bart Van Assche <bart.vanassche@sandisk.com> Cc: Masahiro Yamada <yamada.masahiro@socionext.com> Cc: Huacai Chen <chenhc@lemote.com> Cc: Paul Gortmaker <paul.gortmaker@windriver.com> Cc: Kevin Cernekee <cernekee@gmail.com> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Doug Ledford <dledford@redhat.com> Cc: James Hogan <james.hogan@imgtec.com> Cc: Joe Perches <joe@perches.com> Cc: Florian Fainelli <f.fainelli@gmail.com> Cc: Ingo Molnar <mingo@kernel.org> Cc: Paul Burton <paul.burton@imgtec.com> Cc: Andrew Morton <akpm@linux-foundation.org> Cc: Steven J. Hill <steven.hill@cavium.com> Cc: linux-mips@linux-mips.org Cc: linux-kernel@vger.kernel.org Patchwork: https://patchwork.linux-mips.org/patch/16784/ Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
68 lines
1.4 KiB
C
68 lines
1.4 KiB
C
/*
|
|
* This file is subject to the terms and conditions of the GNU General Public
|
|
* License. See the file "COPYING" in the main directory of this archive
|
|
* for more details.
|
|
*
|
|
* Copyright (C) 2013 Cavium, Inc.
|
|
*/
|
|
|
|
#include <linux/kernel.h>
|
|
#include <linux/kvm_para.h>
|
|
|
|
#include <asm/reboot.h>
|
|
#include <asm/bootinfo.h>
|
|
#include <asm/smp-ops.h>
|
|
#include <asm/time.h>
|
|
|
|
extern const struct plat_smp_ops paravirt_smp_ops;
|
|
|
|
const char *get_system_type(void)
|
|
{
|
|
return "MIPS Para-Virtualized Guest";
|
|
}
|
|
|
|
void __init plat_time_init(void)
|
|
{
|
|
mips_hpt_frequency = kvm_hypercall0(KVM_HC_MIPS_GET_CLOCK_FREQ);
|
|
|
|
preset_lpj = mips_hpt_frequency / (2 * HZ);
|
|
}
|
|
|
|
static void pv_machine_halt(void)
|
|
{
|
|
kvm_hypercall0(KVM_HC_MIPS_EXIT_VM);
|
|
}
|
|
|
|
/*
|
|
* Early entry point for arch setup
|
|
*/
|
|
void __init prom_init(void)
|
|
{
|
|
int i;
|
|
int argc = fw_arg0;
|
|
char **argv = (char **)fw_arg1;
|
|
|
|
#ifdef CONFIG_32BIT
|
|
set_io_port_base(KSEG1ADDR(0x1e000000));
|
|
#else /* CONFIG_64BIT */
|
|
set_io_port_base(PHYS_TO_XKSEG_UNCACHED(0x1e000000));
|
|
#endif
|
|
|
|
for (i = 0; i < argc; i++) {
|
|
strlcat(arcs_cmdline, argv[i], COMMAND_LINE_SIZE);
|
|
if (i < argc - 1)
|
|
strlcat(arcs_cmdline, " ", COMMAND_LINE_SIZE);
|
|
}
|
|
_machine_halt = pv_machine_halt;
|
|
register_smp_ops(¶virt_smp_ops);
|
|
}
|
|
|
|
void __init plat_mem_setup(void)
|
|
{
|
|
/* Do nothing, the "mem=???" parser handles our memory. */
|
|
}
|
|
|
|
void __init prom_free_prom_memory(void)
|
|
{
|
|
}
|