Boot interface for device trees on ARM

Grant Likely grant.likely at secretlab.ca
Wed May 19 21:45:50 EST 2010


On Mon, May 17, 2010 at 8:54 PM, Jeremy Kerr <jeremy.kerr at canonical.com> wrote:
> Hi all,
>
> As we're getting closer to device tree support on ARM, I'd like to get some
> input on our proposed boot interface.
>
> Basically, I'd like to define how we pass the device tree from the bootloader
> to the kernel.
>
> My current method of doing this is through a new atag. It looks like this:
>
>        /* flattened device tree blob pointer */
>        #define ATAG_DEVTREE    0x5441000a
>
>        struct tag_devtree {
>                __u32 start;    /* physical start address */
>                __u32 size;     /* size of dtb image in bytes */
>        };
>
> With ATAG_DEVTREE, we keep the existing boot interface the same (ie, machine
> number in r1, atags pointer r2).

For the reference of those new to this discussion, here is a link to
the previous thread and the link to the draft boot interface document.

http://www.mail-archive.com/devicetree-discuss@lists.ozlabs.org/msg00884.html
http://devicetree.org/Boot_Environment

[...]

>  - We are now potentially carrying data in two different places - atags and
> the device tree. For example, the physical memory layout and kernel command
> line may be present in both.

I've tried to explicitly addresses this in the draft document.  the DT
blob always supersedes ATAG information.

Cheers,
g.

-- 
Grant Likely, B.Sc., P.Eng.
Secret Lab Technologies Ltd.


More information about the devicetree-discuss mailing list