On 05/30/2012 06:00 AM, Alexander Graf wrote:
> We have a nice 64bit helper to ease the device tree generation and
> make the code more readable when creating 64bit 2-cell parameters.
> Use it when generating the device tree.
> 
> Signed-off-by: Alexander Graf <ag...@suse.de>
> ---
>  hw/ppce500_mpc8544ds.c |   10 ++++------
>  1 files changed, 4 insertions(+), 6 deletions(-)
> 
> diff --git a/hw/ppce500_mpc8544ds.c b/hw/ppce500_mpc8544ds.c
> index 2069891..32fbdd3 100644
> --- a/hw/ppce500_mpc8544ds.c
> +++ b/hw/ppce500_mpc8544ds.c
> @@ -91,7 +91,6 @@ static int mpc8544_load_device_tree(CPUPPCState *env,
>                                      const char *kernel_cmdline)
>  {
>      int ret = -1;
> -    uint32_t mem_reg_property[] = {0, cpu_to_be32(ramsize)};
>      int fdt_size;
>      void *fdt;
>      uint8_t hypercall[16];
> @@ -128,8 +127,7 @@ static int mpc8544_load_device_tree(CPUPPCState *env,
>  
>      qemu_devtree_add_subnode(fdt, "/memory");
>      qemu_devtree_setprop_string(fdt, "/memory", "device_type", "memory");
> -    qemu_devtree_setprop(fdt, "/memory", "reg", mem_reg_property,
> -                         sizeof(mem_reg_property));
> +    qemu_devtree_setprop_cell64(fdt, "/memory", "reg", ramsize);

The reg property is supposed to contain an address and a size, not just
size.  You're getting away with this because address happens to be zero
and you happen to be writing a 64-bit size into a device tree that
expects a 32-bit address followed by a 32-bit size (which should be
changed to expect 64-bit of both).

-Scott


Reply via email to