• Huacai Chen's avatar
    MIPS: Loongson64: Add kexec/kdump support · 6ce48897
    Huacai Chen authored
    Add kexec/kdump support for Loongson64 by:
    1, Provide Loongson-specific kexec functions: loongson_kexec_prepare(),
       loongson_kexec_shutdown() and loongson_crash_shutdown();
    2, Provide Loongson-specific assembly code in kexec_smp_wait();
    
    To start Loongson64, The boot CPU needs 3 parameters:
    fw_arg0: the number of arguments in cmdline (i.e., argc).
    fw_arg1: structure holds cmdline such as "root=/dev/sda1 console=tty"
             (i.e., argv).
    fw_arg2: environment (i.e., envp, additional boot parameters from LEFI).
    
    Non-boot CPUs do not need one parameter as the IPI mailbox base address.
    They query their own IPI mailbox to get PC, SP and GP in a loopi, until
    the boot CPU brings them up.
    
    loongson_kexec_prepare(): Setup cmdline for kexec/kdump. The kexec/kdump
    cmdline comes from kexec's "append" option string. This structure will
    be parsed in fw_init_cmdline() of arch/mips/fw/lib/cmdline.c. Both image
    ->control_code_page and the cmdline need to be in a safe memory region
    (memory allocated by the old kernel may be corrupted by the new kernel).
    In order to maintain compatibility for the old firmware, the low 2MB is
    reserverd and safe for Loongson. So let KEXEC_CTRL_CODE and KEXEC_ARGV_
    ADDR be here. LEFI parameters may be corrupted at runtime, so backup it
    at mips_reboot_setup(), and then restore it at loongson_kexec_shutdown()
    /loongson_crash_shutdown().
    
    loongson_kexec_shutdown(): Wake up all present CPUs and let them go to
    reboot_code_buffer. Pass the kexec parameters to kexec_args.
    
    loongson_crash_shutdown(): Pass the kdump parameters to kexec_args.
    
    The assembly part in kexec_smp_wait provide a routine as BIOS does, in
    order to keep secondary CPUs in a querying loop.
    
    The layout of low 2MB memory in our design:
    0x80000000, the first MB, the first 64K, Exception vectors
    0x80010000, the first MB, the second 64K, STR (suspend) data
    0x80020000, the first MB, the third and fourth 64K, UEFI HOB
    0x80040000, the first MB, the fifth 64K, RT-Thread for SMC
    0x80100000, the second MB, the first 64K, KEXEC code
    0x80108000, the second MB, the second 64K, KEXEC data
    
    Cc: Eric Biederman <ebiederm@xmission.com>
    Tested-by: default avatarJinyang He <hejinyang@loongson.cn>
    Signed-off-by: default avatarHuacai Chen <chenhuacai@kernel.org>
    Signed-off-by: default avatarJinyang He <hejinyang@loongson.cn>
    Signed-off-by: default avatarYouling Tang <tangyouling@loongson.cn>
    Signed-off-by: default avatarThomas Bogendoerfer <tsbogend@alpha.franken.de>
    6ce48897
kernel-entry-init.h 2.74 KB