common flatdevtree code

Mark A. Greer mgreer at mvista.com
Fri Sep 29 05:34:43 EST 2006


On Wed, Sep 27, 2006 at 06:52:19PM -0500, Hollis Blanchard wrote:
> On Thu, 2006-09-28 at 01:41 +0200, Segher Boessenkool wrote:
> > > I talked to David Gibson about this and he pointed out that there is a
> > > problem with using a void * to identify nodes (i.e. returned from
> > > ft_find_device and passed to ft_set_prop etc.).  The problem is that
> > > if we reallocate the space for the tree, then any void * handles that
> > > the user of the library has are then invalid.  Perhaps we have to use
> > > offsets from the beginning of the struct region instead - the offset
> > > for a node will be stable across changes of the node or any of its
> > > descendents, at least.
> > 
> > Or unpack the tree before you operate on it.  You can pack it
> > again later if you need to pass it as a flat tree again (or the
> > bootwrapper could implement a real OF client interface, which
> > is useful for many more things!)
> > 
> > A flat contiguous blob of bytes is convenient to pass around,
> > but not such a great data structure for basically anything else ;-)
> 
> I agree; I think this data structure's design is explicitly static, and
> now we're trying to dynamically edit it.
> 
> We essentially need to do unpack/pack now whenever the size of the
> structure changes (e.g. changing a property size, adding or removing
> anything). Making that explicit (and one-time) might be a good idea:
>         tree = ft_unpack(blob);
>         n = ft_find_node(tree, "/node");
>         ft_set_prop(n, "property", value, len);
>         ...
>         blob = ft_pack(tree);

FWIW, this makes a lot of sense to me.

Mark



More information about the Linuxppc-dev mailing list