Board level compatibility matching

Benjamin Herrenschmidt benh at kernel.crashing.org
Sat Aug 2 08:48:23 EST 2008


> This is sort of the part that sucks.  Look at 44x.  There are 10
> board.c files there.  There really only needs to be 3 or 4 (sam440ep,
> warp, virtex, and "generic") because the board files are identical in
> everything except name. By doing the library code approach, one still
> has to create a board.c file for a new board and plug in the library
> functions to ppc_md.

And ? How is that a big deal ? Real products (ie not eval boards, and
even those ...) will probably end up needing that due to subtle
differences anyway.

> Alternatively, you could do the:
> 
> compatible = "specific-board", "similar-board"
> 
> approach that has been done for e.g. Bamboo and Yosemite.  Again, the
> issue is that is that OK?  Is it OK for a board to claim compatibility
> with another board when it might not have all the devices of that
> board, or might have additional devices, etc.  I was of the opinion
> it is, and the device tree handles this just fine, as does the platform
> code. But it can be confusing, hence the discussion here.

Well, as I said. If it stops being ok, just create your own board
and it will take over provided you put it before the other one in
the link order.

If we generalize that approach, we might want to change the board
probing code a bit to first do a full pass based on the first
entry in compatible, then another full pass based on the second, etc...

Ben.





More information about the devicetree-discuss mailing list