Re: [Qemu-devel] [PATCH v9 02/11] device_tree.c: Terminate the empty reservemap in create_device_tree()

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

 



On Sat, Nov 23, 2013 at 3:17 AM, Peter Maydell <peter.maydell@xxxxxxxxxx> wrote:
> Device trees created with create_device_tree() may not have any
> entries in their reservemap, because the FDT API requires that the
> reservemap is completed before any FDT nodes are added, and
> create_device_tree() itself creates a node.  However we were not
> calling fdt_finish_reservemap(), which meant that there was no
> terminator in the reservemap list and whatever happened to be at the
> start of the FDT data section would end up being interpreted as
> reservemap entries.  Avoid this by calling fdt_finish_reservemap()
> to add the terminator.
>
> Signed-off-by: Peter Maydell <peter.maydell@xxxxxxxxxx>
> Acked-by: Alexander Graf <agraf@xxxxxxx>

Reviewed-by: Peter Crosthwaite <peter.crosthwaite@xxxxxxxxxx>

> ---
>  device_tree.c |    4 ++++
>  1 file changed, 4 insertions(+)
>
> diff --git a/device_tree.c b/device_tree.c
> index ffec99a..391da8c 100644
> --- a/device_tree.c
> +++ b/device_tree.c
> @@ -41,6 +41,10 @@ void *create_device_tree(int *sizep)
>      if (ret < 0) {
>          goto fail;
>      }
> +    ret = fdt_finish_reservemap(fdt);
> +    if (ret < 0) {
> +        goto fail;
> +    }
>      ret = fdt_begin_node(fdt, "");
>      if (ret < 0) {
>          goto fail;
> --
> 1.7.9.5
>
>
_______________________________________________
kvmarm mailing list
kvmarm@xxxxxxxxxxxxxxxxxxxxx
https://lists.cs.columbia.edu/cucslists/listinfo/kvmarm




[Index of Archives]     [Linux KVM]     [Spice Development]     [Libvirt]     [Libvirt Users]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux