[U-Boot-Users] [PATCH] lkc support for U-Boot

Holger Schurig h.schurig at mn-logistik.de
Thu Nov 7 10:11:59 CET 2002


> Why are all these things named ARCH_*?

They don't have to.

But in the Linux kernel they are all called CONFIG_ARCH_<boardname>. At least 
in the ARM tree, the one I'm familiar with:

#
# System Type
#
# CONFIG_ARCH_ANAKIN is not set
# CONFIG_ARCH_ARCA5K is not set
# CONFIG_ARCH_CLPS7500 is not set
# CONFIG_ARCH_CLPS711X is not set
# CONFIG_ARCH_CO285 is not set
CONFIG_ARCH_PXA=y
# CONFIG_ARCH_EBSA110 is not set
# CONFIG_ARCH_CAMELOT is not set
# CONFIG_ARCH_FOOTBRIDGE is not set
# CONFIG_ARCH_INTEGRATOR is not set
# CONFIG_ARCH_L7200 is not set
# CONFIG_ARCH_MX1ADS is not set
# CONFIG_ARCH_RPC is not set
# CONFIG_ARCH_RISCSTATION is not set
# CONFIG_ARCH_SA1100 is not set
# CONFIG_ARCH_SHARK is not set

> > So it is absolutely no problem to have in
> > u-boot/boards/<someboard>/config.in an entry like
>
> But that means that the configuration for one  board  is  distributed
> over  3 (or more?) config.in files. It has certain advantages to have
> it concentrated in one place...

The actual configuration is in the .config file --- and can be in the 
per-board directory as a def-config.

But what is configurable (the meta-configuration) info is distributed. 
Ideally, in each directory where some *.C or *.H files implement features the 
corresponding config.in file contains the meta-information of what the 
feature does, how it is named, how it relates to other config infos.


> I disagree. It is much more complicated to find  all  config  options
> relevant  to  once  specific  system,  and  requires  a  much  better
> understanding  of  the  config  mechanism  to   add   a   new   board
> configuration - correctly, that is.

Now. The one that is responsible for a board, e.g. the maintainer of the PP405 
board, once uses the menuconfig to set up all the options for this board. 
Then he does a simple "cp .config board/pp405/def-config" and ask you to 
check in this file.

If this board specifies a new command (e.g. CONFIG_PP405_TOGGLE_LED) then the 
code for this command is in boards/pp405/cmd_toggle.c. And the sheer 
existence of this new feature is also in boards/pp405/config.in. So the 
things are near to each other.

If you, on the other side, make a new general command that is not hardware 
related, then you add common/cmd_tetris.c, include/cmd_tetris.h, and in 
common/config.in you add the command definition:

define CMD_TETRIS
  bool "tetris: ever played tetris over a serial line?"
  default "n"

If now our PP405 guy dows a checkout and

  cp boards/pp405/def-config .config
  make oldconfig

then he still has not the new command selected. But it would appear on his 
make menuconfig/make xconfig screen to be selectable, clearly marked as 
"tetris: ever played tetris over a serial line? (NEW)". He can then create a 
new def-config if he wants to have this command on his platform. Or keep it 
as is.

If you now do this using the current approach, then a maintainer for a board 
would have to check from time to time the include/cmd_confdefs.h for new 
things on the radar and would 

In this case, the new command (cmd_tetris.c) and the definition of it's 
existence etc is in the same directory. For me this sounds easy to maintain.

Greetings, Holger

-- 
MN-Logistik GmbH         http://www.mn-logistik.de
Holger Schurig
Dieselstr. 18
61191 Rosbach v.d.Höhe
Tel: 06003/9141-0        Fax: 06003/9141-49





More information about the U-Boot mailing list