qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Qemu-devel] [PATCH v1] virtex_ml507: Add support for loading initrd


From: Andreas Färber
Subject: Re: [Qemu-devel] [PATCH v1] virtex_ml507: Add support for loading initrd images
Date: Mon, 03 Feb 2014 19:47:47 +0100
User-agent: Mozilla/5.0 (X11; Linux x86_64; rv:24.0) Gecko/20100101 Thunderbird/24.2.0

Am 03.02.2014 16:20, schrieb Edgar E. Iglesias:
> From: "Edgar E. Iglesias" <address@hidden>
> 
> Signed-off-by: Edgar E. Iglesias <address@hidden>
> ---
>  hw/ppc/virtex_ml507.c | 34 +++++++++++++++++++++++++++++++++-
>  1 file changed, 33 insertions(+), 1 deletion(-)
> 
> diff --git a/hw/ppc/virtex_ml507.c b/hw/ppc/virtex_ml507.c
> index bdb057e..19083d4 100644
> --- a/hw/ppc/virtex_ml507.c
> +++ b/hw/ppc/virtex_ml507.c
> @@ -166,6 +166,19 @@ static int xilinx_load_device_tree(hwaddr addr,
>      if (!fdt) {
>          return 0;
>      }
> +
> +    r = qemu_fdt_setprop_cell(fdt, "/chosen", "linux,initrd-start",
> +                              initrd_base);
> +    if (r < 0) {
> +        error_report("couldn't set /chosen/linux,initrd-start'");

Both this ...

> +    }
> +
> +    r = qemu_fdt_setprop_cell(fdt, "/chosen", "linux,initrd-end",
> +                              (initrd_base + initrd_size));
> +    if (r < 0) {
> +        error_report("couldn't set /chosen/linux,initrd-end'");

... and the other error_report() have either a stray trailing
single-quote or one missing before the path.

> +    }
> +
>      r = qemu_fdt_setprop_string(fdt, "/chosen", "bootargs", kernel_cmdline);
>      if (r < 0)
>          fprintf(stderr, "couldn't set /chosen/bootargs\n");
> @@ -179,6 +192,8 @@ static void virtex_init(QEMUMachineInitArgs *args)
>      const char *cpu_model = args->cpu_model;
>      const char *kernel_filename = args->kernel_filename;
>      const char *kernel_cmdline = args->kernel_cmdline;
> +    hwaddr initrd_base = 0;
> +    int initrd_size = 0;
>      MemoryRegion *address_space_mem = get_system_memory();
>      DeviceState *dev;
>      PowerPCCPU *cpu;
> @@ -242,10 +257,27 @@ static void virtex_init(QEMUMachineInitArgs *args)
>  
>          boot_info.ima_size = kernel_size;
>  
> +        /* Load initrd. */
> +        if (args->initrd_filename) {
> +            initrd_base = high = ROUND_UP(high, 4);
> +            initrd_size = load_image_targphys(args->initrd_filename,
> +                                              high, ram_size - high);
> +
> +            if (initrd_size < 0) {
> +                error_report("couldn't load ram disk '%s'\n",

And here's a stray \n.

Andreas

> +                             args->initrd_filename);
> +                exit(1);
> +            }
> +            high = ROUND_UP(high + initrd_size, 4);
> +        }
> +
>          /* Provide a device-tree.  */
>          boot_info.fdt = high + (8192 * 2);
>          boot_info.fdt &= ~8191;
> -        xilinx_load_device_tree(boot_info.fdt, ram_size, 0, 0, 
> kernel_cmdline);
> +
> +        xilinx_load_device_tree(boot_info.fdt, ram_size,
> +                                initrd_base, initrd_size,
> +                                kernel_cmdline);
>      }
>      env->load_info = &boot_info;
>  }

-- 
SUSE LINUX Products GmbH, Maxfeldstr. 5, 90409 Nürnberg, Germany
GF: Jeff Hawn, Jennifer Guild, Felix Imendörffer; HRB 16746 AG Nürnberg



reply via email to

[Prev in Thread] Current Thread [Next in Thread]