mirror of https://github.com/xemu-project/xemu.git
hw/loongarch: remove global loaderparams variable
Passing the struct around explicitly makes the control-flow more obvious. Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org> Reviewed-by: Song Gao <gaosong@loongson.cn> Signed-off-by: Thomas Weißschuh <thomas@t-8ch.de> Message-Id: <20231010-loongarch-loader-params-v2-1-512cc7959683@t-8ch.de> Signed-off-by: Song Gao <gaosong@loongson.cn>
This commit is contained in:
parent
5f1a3132c6
commit
2cfdab739a
|
@ -47,6 +47,13 @@
|
|||
#include "qemu/error-report.h"
|
||||
|
||||
|
||||
struct loaderparams {
|
||||
uint64_t ram_size;
|
||||
const char *kernel_filename;
|
||||
const char *kernel_cmdline;
|
||||
const char *initrd_filename;
|
||||
};
|
||||
|
||||
static void virt_flash_create(LoongArchMachineState *lams)
|
||||
{
|
||||
DeviceState *dev = qdev_new(TYPE_PFLASH_CFI01);
|
||||
|
@ -411,24 +418,17 @@ static const MemoryRegionOps loongarch_virt_pm_ops = {
|
|||
}
|
||||
};
|
||||
|
||||
static struct _loaderparams {
|
||||
uint64_t ram_size;
|
||||
const char *kernel_filename;
|
||||
const char *kernel_cmdline;
|
||||
const char *initrd_filename;
|
||||
} loaderparams;
|
||||
|
||||
static uint64_t cpu_loongarch_virt_to_phys(void *opaque, uint64_t addr)
|
||||
{
|
||||
return addr & MAKE_64BIT_MASK(0, TARGET_PHYS_ADDR_SPACE_BITS);
|
||||
}
|
||||
|
||||
static int64_t load_kernel_info(void)
|
||||
static int64_t load_kernel_info(const struct loaderparams *loaderparams)
|
||||
{
|
||||
uint64_t kernel_entry, kernel_low, kernel_high;
|
||||
ssize_t kernel_size;
|
||||
|
||||
kernel_size = load_elf(loaderparams.kernel_filename, NULL,
|
||||
kernel_size = load_elf(loaderparams->kernel_filename, NULL,
|
||||
cpu_loongarch_virt_to_phys, NULL,
|
||||
&kernel_entry, &kernel_low,
|
||||
&kernel_high, NULL, 0,
|
||||
|
@ -436,7 +436,7 @@ static int64_t load_kernel_info(void)
|
|||
|
||||
if (kernel_size < 0) {
|
||||
error_report("could not load kernel '%s': %s",
|
||||
loaderparams.kernel_filename,
|
||||
loaderparams->kernel_filename,
|
||||
load_elf_strerror(kernel_size));
|
||||
exit(1);
|
||||
}
|
||||
|
@ -728,7 +728,8 @@ static void reset_load_elf(void *opaque)
|
|||
}
|
||||
}
|
||||
|
||||
static void fw_cfg_add_kernel_info(FWCfgState *fw_cfg)
|
||||
static void fw_cfg_add_kernel_info(const struct loaderparams *loaderparams,
|
||||
FWCfgState *fw_cfg)
|
||||
{
|
||||
/*
|
||||
* Expose the kernel, the command line, and the initrd in fw_cfg.
|
||||
|
@ -737,36 +738,38 @@ static void fw_cfg_add_kernel_info(FWCfgState *fw_cfg)
|
|||
*/
|
||||
load_image_to_fw_cfg(fw_cfg,
|
||||
FW_CFG_KERNEL_SIZE, FW_CFG_KERNEL_DATA,
|
||||
loaderparams.kernel_filename,
|
||||
loaderparams->kernel_filename,
|
||||
false);
|
||||
|
||||
if (loaderparams.initrd_filename) {
|
||||
if (loaderparams->initrd_filename) {
|
||||
load_image_to_fw_cfg(fw_cfg,
|
||||
FW_CFG_INITRD_SIZE, FW_CFG_INITRD_DATA,
|
||||
loaderparams.initrd_filename, false);
|
||||
loaderparams->initrd_filename, false);
|
||||
}
|
||||
|
||||
if (loaderparams.kernel_cmdline) {
|
||||
if (loaderparams->kernel_cmdline) {
|
||||
fw_cfg_add_i32(fw_cfg, FW_CFG_CMDLINE_SIZE,
|
||||
strlen(loaderparams.kernel_cmdline) + 1);
|
||||
strlen(loaderparams->kernel_cmdline) + 1);
|
||||
fw_cfg_add_string(fw_cfg, FW_CFG_CMDLINE_DATA,
|
||||
loaderparams.kernel_cmdline);
|
||||
loaderparams->kernel_cmdline);
|
||||
}
|
||||
}
|
||||
|
||||
static void loongarch_firmware_boot(LoongArchMachineState *lams)
|
||||
static void loongarch_firmware_boot(LoongArchMachineState *lams,
|
||||
const struct loaderparams *loaderparams)
|
||||
{
|
||||
fw_cfg_add_kernel_info(lams->fw_cfg);
|
||||
fw_cfg_add_kernel_info(loaderparams, lams->fw_cfg);
|
||||
}
|
||||
|
||||
static void loongarch_direct_kernel_boot(LoongArchMachineState *lams)
|
||||
static void loongarch_direct_kernel_boot(LoongArchMachineState *lams,
|
||||
const struct loaderparams *loaderparams)
|
||||
{
|
||||
MachineState *machine = MACHINE(lams);
|
||||
int64_t kernel_addr = 0;
|
||||
LoongArchCPU *lacpu;
|
||||
int i;
|
||||
|
||||
kernel_addr = load_kernel_info();
|
||||
kernel_addr = load_kernel_info(loaderparams);
|
||||
if (!machine->firmware) {
|
||||
for (i = 0; i < machine->smp.cpus; i++) {
|
||||
lacpu = LOONGARCH_CPU(qemu_get_cpu(i));
|
||||
|
@ -793,6 +796,7 @@ static void loongarch_init(MachineState *machine)
|
|||
MachineClass *mc = MACHINE_GET_CLASS(machine);
|
||||
CPUState *cpu;
|
||||
char *ramName = NULL;
|
||||
struct loaderparams loaderparams = { };
|
||||
|
||||
if (!cpu_model) {
|
||||
cpu_model = LOONGARCH_CPU_TYPE_NAME("la464");
|
||||
|
@ -898,9 +902,9 @@ static void loongarch_init(MachineState *machine)
|
|||
/* load the kernel. */
|
||||
if (loaderparams.kernel_filename) {
|
||||
if (lams->bios_loaded) {
|
||||
loongarch_firmware_boot(lams);
|
||||
loongarch_firmware_boot(lams, &loaderparams);
|
||||
} else {
|
||||
loongarch_direct_kernel_boot(lams);
|
||||
loongarch_direct_kernel_boot(lams, &loaderparams);
|
||||
}
|
||||
}
|
||||
fdt_add_flash_node(lams);
|
||||
|
|
Loading…
Reference in New Issue