|
|
|
#
|
|
|
|
# (C) Copyright 2004-2006
|
|
|
|
# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
|
|
|
|
#
|
|
|
|
# See file CREDITS for list of people who contributed to this
|
|
|
|
# project.
|
|
|
|
#
|
|
|
|
# This program is free software; you can redistribute it and/or
|
|
|
|
# modify it under the terms of the GNU General Public License as
|
|
|
|
# published by the Free Software Foundation; either version 2 of
|
|
|
|
# the License, or (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this program; if not, write to the Free Software
|
|
|
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston,
|
|
|
|
# MA 02111-1307 USA
|
|
|
|
#
|
|
|
|
|
|
|
|
include $(TOPDIR)/config.mk
|
|
|
|
|
|
|
|
LIB = $(obj)libcommon.o
|
|
|
|
|
|
|
|
# core
|
|
|
|
COBJS-y += main.o
|
|
|
|
COBJS-y += console.o
|
|
|
|
COBJS-y += command.o
|
|
|
|
COBJS-y += dlmalloc.o
|
|
|
|
COBJS-y += exports.o
|
|
|
|
COBJS-$(CONFIG_SYS_HUSH_PARSER) += hush.o
|
|
|
|
COBJS-y += image.o
|
|
|
|
COBJS-y += memsize.o
|
|
|
|
COBJS-y += s_record.o
|
|
|
|
COBJS-$(CONFIG_SERIAL_MULTI) += serial.o
|
|
|
|
COBJS-y += stdio.o
|
|
|
|
COBJS-y += xyzModem.o
|
|
|
|
|
|
|
|
# core command
|
|
|
|
COBJS-y += cmd_boot.o
|
|
|
|
COBJS-y += cmd_bootm.o
|
|
|
|
COBJS-y += cmd_help.o
|
|
|
|
COBJS-y += cmd_nvedit.o
|
|
|
|
COBJS-y += cmd_version.o
|
|
|
|
|
|
|
|
# environment
|
|
|
|
COBJS-y += env_common.o
|
|
|
|
COBJS-$(CONFIG_ENV_IS_IN_DATAFLASH) += env_dataflash.o
|
|
|
|
COBJS-$(CONFIG_ENV_IS_IN_EEPROM) += env_eeprom.o
|
|
|
|
XCOBJS-$(CONFIG_ENV_IS_EMBEDDED) += env_embedded.o
|
|
|
|
COBJS-$(CONFIG_ENV_IS_IN_EEPROM) += env_embedded.o
|
|
|
|
XCOBJS-$(CONFIG_ENV_IS_IN_FLASH) += env_embedded.o
|
|
|
|
COBJS-$(CONFIG_ENV_IS_IN_NVRAM) += env_embedded.o
|
|
|
|
COBJS-$(CONFIG_ENV_IS_IN_FLASH) += env_flash.o
|
|
|
|
COBJS-$(CONFIG_ENV_IS_IN_MG_DISK) += env_mgdisk.o
|
|
|
|
COBJS-$(CONFIG_ENV_IS_IN_MMC) += env_mmc.o
|
|
|
|
COBJS-$(CONFIG_ENV_IS_IN_NAND) += env_nand.o
|
|
|
|
COBJS-$(CONFIG_ENV_IS_IN_NVRAM) += env_nvram.o
|
|
|
|
COBJS-$(CONFIG_ENV_IS_IN_ONENAND) += env_onenand.o
|
|
|
|
COBJS-$(CONFIG_ENV_IS_IN_SPI_FLASH) += env_sf.o
|
|
|
|
COBJS-$(CONFIG_ENV_IS_NOWHERE) += env_nowhere.o
|
|
|
|
|
|
|
|
# command
|
|
|
|
COBJS-$(CONFIG_CMD_AMBAPP) += cmd_ambapp.o
|
|
|
|
COBJS-$(CONFIG_SOURCE) += cmd_source.o
|
|
|
|
COBJS-$(CONFIG_CMD_SOURCE) += cmd_source.o
|
|
|
|
COBJS-$(CONFIG_CMD_BDI) += cmd_bdinfo.o
|
|
|
|
COBJS-$(CONFIG_CMD_BEDBUG) += bedbug.o cmd_bedbug.o
|
|
|
|
COBJS-$(CONFIG_CMD_BMP) += cmd_bmp.o
|
|
|
|
COBJS-$(CONFIG_CMD_BOOTLDR) += cmd_bootldr.o
|
|
|
|
COBJS-$(CONFIG_CMD_CACHE) += cmd_cache.o
|
|
|
|
COBJS-$(CONFIG_CMD_CONSOLE) += cmd_console.o
|
|
|
|
COBJS-$(CONFIG_CMD_CPLBINFO) += cmd_cplbinfo.o
|
|
|
|
COBJS-$(CONFIG_DATAFLASH_MMC_SELECT) += cmd_dataflash_mmc_mux.o
|
|
|
|
COBJS-$(CONFIG_CMD_DATE) += cmd_date.o
|
|
|
|
ifdef CONFIG_4xx
|
|
|
|
COBJS-$(CONFIG_CMD_SETGETDCR) += cmd_dcr.o
|
|
|
|
endif
|
|
|
|
ifdef CONFIG_POST
|
|
|
|
COBJS-$(CONFIG_CMD_DIAG) += cmd_diag.o
|
|
|
|
endif
|
|
|
|
COBJS-$(CONFIG_CMD_DISPLAY) += cmd_display.o
|
|
|
|
COBJS-$(CONFIG_CMD_DTT) += cmd_dtt.o
|
|
|
|
COBJS-$(CONFIG_CMD_ECHO) += cmd_echo.o
|
|
|
|
COBJS-$(CONFIG_ENV_IS_IN_EEPROM) += cmd_eeprom.o
|
|
|
|
COBJS-$(CONFIG_CMD_EEPROM) += cmd_eeprom.o
|
|
|
|
COBJS-$(CONFIG_CMD_ELF) += cmd_elf.o
|
|
|
|
COBJS-$(CONFIG_SYS_HUSH_PARSER) += cmd_exit.o
|
|
|
|
COBJS-$(CONFIG_CMD_EXT2) += cmd_ext2.o
|
|
|
|
COBJS-$(CONFIG_CMD_FAT) += cmd_fat.o
|
|
|
|
COBJS-$(CONFIG_CMD_FDC)$(CONFIG_CMD_FDOS) += cmd_fdc.o
|
|
|
|
COBJS-$(CONFIG_OF_LIBFDT) += cmd_fdt.o fdt_support.o
|
|
|
|
COBJS-$(CONFIG_CMD_FDOS) += cmd_fdos.o
|
|
|
|
COBJS-$(CONFIG_CMD_FLASH) += cmd_flash.o
|
|
|
|
ifdef CONFIG_FPGA
|
|
|
|
COBJS-$(CONFIG_CMD_FPGA) += cmd_fpga.o
|
|
|
|
endif
|
|
|
|
COBJS-$(CONFIG_CMD_I2C) += cmd_i2c.o
|
|
|
|
COBJS-$(CONFIG_CMD_IDE) += cmd_ide.o
|
|
|
|
COBJS-$(CONFIG_CMD_IMMAP) += cmd_immap.o
|
|
|
|
COBJS-$(CONFIG_CMD_IRQ) += cmd_irq.o
|
|
|
|
COBJS-$(CONFIG_CMD_ITEST) += cmd_itest.o
|
|
|
|
COBJS-$(CONFIG_CMD_JFFS2) += cmd_jffs2.o
|
|
|
|
COBJS-$(CONFIG_CMD_CRAMFS) += cmd_cramfs.o
|
|
|
|
COBJS-$(CONFIG_CMD_LICENSE) += cmd_license.o
|
|
|
|
COBJS-y += cmd_load.o
|
|
|
|
COBJS-$(CONFIG_LOGBUFFER) += cmd_log.o
|
|
|
|
COBJS-$(CONFIG_ID_EEPROM) += cmd_mac.o
|
|
|
|
COBJS-$(CONFIG_CMD_MEMORY) += cmd_mem.o
|
|
|
|
COBJS-$(CONFIG_CMD_MFSL) += cmd_mfsl.o
|
|
|
|
COBJS-$(CONFIG_CMD_MG_DISK) += cmd_mgdisk.o
|
|
|
|
COBJS-$(CONFIG_MII) += miiphyutil.o
|
|
|
|
COBJS-$(CONFIG_CMD_MII) += miiphyutil.o
|
|
|
|
COBJS-$(CONFIG_CMD_MII) += cmd_mii.o
|
|
|
|
COBJS-$(CONFIG_CMD_MISC) += cmd_misc.o
|
|
|
|
COBJS-$(CONFIG_CMD_MMC) += cmd_mmc.o
|
|
|
|
COBJS-$(CONFIG_MP) += cmd_mp.o
|
|
|
|
COBJS-$(CONFIG_CMD_MTDPARTS) += cmd_mtdparts.o
|
|
|
|
COBJS-$(CONFIG_CMD_NAND) += cmd_nand.o
|
|
|
|
COBJS-$(CONFIG_CMD_NET) += cmd_net.o
|
|
|
|
COBJS-$(CONFIG_CMD_ONENAND) += cmd_onenand.o
|
|
|
|
COBJS-$(CONFIG_CMD_OTP) += cmd_otp.o
|
|
|
|
ifdef CONFIG_PCI
|
|
|
|
COBJS-$(CONFIG_CMD_PCI) += cmd_pci.o
|
|
|
|
endif
|
|
|
|
COBJS-y += cmd_pcmcia.o
|
|
|
|
COBJS-$(CONFIG_CMD_PORTIO) += cmd_portio.o
|
|
|
|
COBJS-$(CONFIG_CMD_REGINFO) += cmd_reginfo.o
|
|
|
|
COBJS-$(CONFIG_CMD_REISER) += cmd_reiser.o
|
|
|
|
COBJS-$(CONFIG_CMD_SATA) += cmd_sata.o
|
|
|
|
COBJS-$(CONFIG_CMD_SF) += cmd_sf.o
|
|
|
|
COBJS-$(CONFIG_CMD_SCSI) += cmd_scsi.o
|
|
|
|
COBJS-$(CONFIG_CMD_SETEXPR) += cmd_setexpr.o
|
|
|
|
COBJS-$(CONFIG_CMD_SPI) += cmd_spi.o
|
|
|
|
COBJS-$(CONFIG_CMD_SPIBOOTLDR) += cmd_spibootldr.o
|
|
|
|
COBJS-$(CONFIG_CMD_STRINGS) += cmd_strings.o
|
|
|
|
COBJS-$(CONFIG_CMD_TERMINAL) += cmd_terminal.o
|
|
|
|
COBJS-$(CONFIG_SYS_HUSH_PARSER) += cmd_test.o
|
|
|
|
COBJS-$(CONFIG_CMD_TSI148) += cmd_tsi148.o
|
|
|
|
COBJS-$(CONFIG_CMD_UBI) += cmd_ubi.o
|
|
|
|
COBJS-$(CONFIG_CMD_UBIFS) += cmd_ubifs.o
|
|
|
|
COBJS-$(CONFIG_CMD_UNIVERSE) += cmd_universe.o
|
|
|
|
ifdef CONFIG_CMD_USB
|
|
|
|
COBJS-y += cmd_usb.o
|
|
|
|
COBJS-y += usb.o
|
|
|
|
COBJS-$(CONFIG_USB_STORAGE) += usb_storage.o
|
|
|
|
endif
|
|
|
|
COBJS-$(CONFIG_CMD_XIMG) += cmd_ximg.o
|
|
|
|
COBJS-$(CONFIG_YAFFS2) += cmd_yaffs2.o
|
|
|
|
COBJS-$(CONFIG_VFD) += cmd_vfd.o
|
|
|
|
|
|
|
|
# others
|
|
|
|
COBJS-$(CONFIG_DDR_SPD) += ddr_spd.o
|
Add simple hwconfig infrastructure
This patch implements simple hwconfig infrastructure: an
interface for software knobs to control a hardware.
This is very simple implementation, i.e. it is implemented
via `hwconfig' environment variable. Later we could write
some "hwconfig <enable|disable|list>" commands, ncurses
interface for Award BIOS-like interface, and frame-buffer
interface for AMI GUI[1] BIOS-like interface with mouse
support[2].
Current implementation details/limitations:
1. Doesn't support options dependencies and mutual exclusion.
We can implement this by integrating apt-get[3] into the
u-boot. But I didn't bother yet.
2. Since we don't implement hwconfig command, i.e. we're working
with the environement directly, there is no way to tell that
toggling a particular option will need a reboot to take
an effect. So, for now it's advised to always reboot the
target after modifying hwconfig variable.
3. We support hwconfig options with arguments. For example,
set hwconfig dr_usb:mode=peripheral,phy_type=ulpi
That means:
- dr_usb - enable Dual-Role USB controller;
- dr_usb:mode=peripheral - USB in Function mode;
- dr_usb:phy_type=ulpi - USB should work with ULPI PHYs;
The purpose of this simple implementation is to define some
internal API and then we can continue improving user experience
by adding more mature interface, like hwconfig command with
bells and whistles. Or not adding, if we feel that current
interface fits its needs.
[1] http://en.wikipedia.org/wiki/American_Megatrends
[2] Regarding ncurses and GUI with mouse support -- I'm just
kidding.
[3] The comment regarding apt-get is also a joke, meaning that
dependency tracking could be non-trivial. For example, for
enabling HW feature X we may need to disable Y, and turn Z
into reduced mode (like RMII-only interface for ethernet,
no MII).
It's quite trivial to implement simple cases though.
Signed-off-by: Anton Vorontsov <avorontsov@ru.mvista.com>
Acked-by: Kim Phillips <kim.phillips@freescale.com>
16 years ago
|
|
|
COBJS-$(CONFIG_HWCONFIG) += hwconfig.o
|
|
|
|
COBJS-$(CONFIG_CONSOLE_MUX) += iomux.o
|
|
|
|
COBJS-y += flash.o
|
|
|
|
COBJS-$(CONFIG_CMD_KGDB) += kgdb.o kgdb_stubs.o
|
|
|
|
COBJS-$(CONFIG_KALLSYMS) += kallsyms.o
|
|
|
|
COBJS-$(CONFIG_LCD) += lcd.o
|
|
|
|
COBJS-$(CONFIG_LYNXKDI) += lynxkdi.o
|
|
|
|
COBJS-$(CONFIG_MODEM_SUPPORT) += modem.o
|
|
|
|
COBJS-$(CONFIG_UPDATE_TFTP) += update.o
|
|
|
|
COBJS-$(CONFIG_USB_KEYBOARD) += usb_kbd.o
|
|
|
|
|
|
|
|
|
|
|
|
COBJS := $(sort $(COBJS-y))
|
|
|
|
XCOBJS := $(sort $(XCOBJS-y))
|
|
|
|
SRCS := $(COBJS:.o=.c) $(XCOBJS:.o=.c)
|
|
|
|
OBJS := $(addprefix $(obj),$(COBJS))
|
|
|
|
XOBJS := $(addprefix $(obj),$(XCOBJS))
|
|
|
|
|
|
|
|
CPPFLAGS += -I..
|
|
|
|
|
|
|
|
all: $(LIB) $(XOBJS)
|
|
|
|
|
|
|
|
$(LIB): $(obj).depend $(OBJS)
|
|
|
|
$(call cmd_link_o_target, $(OBJS))
|
|
|
|
|
|
|
|
$(obj)env_embedded.o: $(src)env_embedded.c $(obj)../tools/envcrc
|
|
|
|
$(CC) $(AFLAGS) -Wa,--no-warn \
|
|
|
|
-DENV_CRC=$(shell $(obj)../tools/envcrc) \
|
|
|
|
-c -o $@ $(src)env_embedded.c
|
|
|
|
|
|
|
|
$(obj)../tools/envcrc:
|
|
|
|
$(MAKE) -C ../tools
|
|
|
|
|
|
|
|
#########################################################################
|
|
|
|
|
|
|
|
# defines $(obj).depend target
|
|
|
|
include $(SRCTREE)/rules.mk
|
|
|
|
|
|
|
|
sinclude $(obj).depend
|
|
|
|
|
|
|
|
#########################################################################
|