|
|
|
#
|
|
|
|
# (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
|
|
|
|
ifndef CONFIG_SPL_BUILD
|
|
|
|
COBJS-y += main.o
|
|
|
|
COBJS-y += command.o
|
|
|
|
COBJS-y += exports.o
|
|
|
|
COBJS-$(CONFIG_SYS_HUSH_PARSER) += hush.o
|
|
|
|
COBJS-y += image.o
|
|
|
|
COBJS-y += s_record.o
|
|
|
|
COBJS-$(CONFIG_SERIAL_MULTI) += serial.o
|
|
|
|
COBJS-y += xyzModem.o
|
|
|
|
|
|
|
|
# core command
|
|
|
|
COBJS-y += cmd_boot.o
|
|
|
|
COBJS-$(CONFIG_CMD_BOOTM) += 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_MMC) += env_mmc.o
|
|
|
|
COBJS-$(CONFIG_ENV_IS_IN_FAT) += env_fat.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_IN_REMOTE) += env_remote.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_FITUPD) += cmd_fitupd.o
|
|
|
|
COBJS-$(CONFIG_CMD_FLASH) += cmd_flash.o
|
|
|
|
ifdef CONFIG_FPGA
|
|
|
|
COBJS-$(CONFIG_CMD_FPGA) += cmd_fpga.o
|
|
|
|
endif
|
|
|
|
COBJS-$(CONFIG_CMD_GPIO) += cmd_gpio.o
|
|
|
|
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_LDRINFO) += cmd_ldrinfo.o
|
|
|
|
COBJS-$(CONFIG_CMD_LED) += cmd_led.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_MD5SUM) += cmd_md5sum.o
|
|
|
|
COBJS-$(CONFIG_CMD_MEMORY) += cmd_mem.o
|
|
|
|
COBJS-$(CONFIG_CMD_MFSL) += cmd_mfsl.o
|
|
|
|
COBJS-$(CONFIG_MII) += miiphyutil.o
|
|
|
|
COBJS-$(CONFIG_CMD_MII) += miiphyutil.o
|
Create PHY Lib for U-Boot
Extends the mii_dev structure to participate in a full-blown MDIO and
PHY driver scheme. The mii_dev structure and miiphy calls are modified
in such a way to allow the original mii command and miiphy
infrastructure to work as before, but also to support a new set of APIs
which allow (among other things) sharing of PHY driver code and 10G support
The mii command will continue to support normal PHY management functions
(Clause 22 of 802.3), but will not be changed to support 10G
(Clause 45).
The basic design is similar to PHY Lib from Linux, but simplified for
U-Boot's network and driver infrastructure.
We now have MDIO drivers and PHY drivers
An MDIO driver provides:
read
write
reset
A PHY driver provides:
(optionally): probe
config - initial setup, starting of auto-negotiation
startup - waiting for AN, and reading link state
shutdown - any cleanup needed
The ethernet drivers interact with the PHY Lib using these functions:
phy_connect()
phy_config()
phy_startup()
phy_shutdown()
Each PHY driver can be configured separately, or all at once using
config_phylib_all_drivers.h (added in the patch which adds the drivers)
We also provide generic drivers for Clause 22 (10/100/1000), and
Clause 45 (10G) PHYs.
We also implement phy_reset(), and call it in phy_connect(). Because
phy_reset() is essentially the same as miiphy_reset, but:
a) must support 10G PHYs, and
b) should use the phylib primitives,
we implement miiphy_reset, using phy_reset(), but only when
CONFIG_PHYLIB is set. Otherwise, we just use the old version. In this
way, we save on compile size, even if we don't manage to save code size.
Pulled ethtool.h and mdio.h from:
git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-next-2.6
782d640afd15af7a1faf01cfe566ca4ac511319d
With many, many deletions so as to enable compilation under u-boot
Signed-off-by: Andy Fleming <afleming@freescale.com>
Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
Acked-by: Detlev Zundel <dzu@denx.de>
14 years ago
|
|
|
COBJS-$(CONFIG_PHYLIB) += miiphyutil.o
|
|
|
|
COBJS-$(CONFIG_CMD_MII) += cmd_mii.o
|
|
|
|
ifdef CONFIG_PHYLIB
|
|
|
|
COBJS-$(CONFIG_CMD_MII) += cmd_mdio.o
|
|
|
|
endif
|
|
|
|
COBJS-$(CONFIG_CMD_MISC) += cmd_misc.o
|
|
|
|
COBJS-$(CONFIG_CMD_MMC) += cmd_mmc.o
|
|
|
|
COBJS-$(CONFIG_CMD_MMC_SPI) += cmd_mmc_spi.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_PXE) += cmd_pxe.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_SHA1SUM) += cmd_sha1sum.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_CMD_TIME) += cmd_time.o
|
|
|
|
COBJS-$(CONFIG_SYS_HUSH_PARSER) += cmd_test.o
|
|
|
|
COBJS-$(CONFIG_CMD_TPM) += cmd_tpm.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
|
|
|
|
COBJS-$(CONFIG_CMD_UNZIP) += cmd_unzip.o
|
|
|
|
ifdef CONFIG_CMD_USB
|
|
|
|
COBJS-y += cmd_usb.o
|
|
|
|
COBJS-y += usb.o usb_hub.o
|
|
|
|
COBJS-$(CONFIG_USB_STORAGE) += usb_storage.o
|
|
|
|
endif
|
|
|
|
COBJS-$(CONFIG_CMD_XIMG) += cmd_ximg.o
|
|
|
|
COBJS-$(CONFIG_YAFFS2) += cmd_yaffs2.o
|
|
|
|
COBJS-$(CONFIG_CMD_SPL) += cmd_spl.o
|
|
|
|
|
|
|
|
# others
|
|
|
|
ifdef CONFIG_DDR_SPD
|
|
|
|
SPD := y
|
|
|
|
endif
|
|
|
|
ifdef CONFIG_SPD_EEPROM
|
|
|
|
SPD := y
|
|
|
|
endif
|
|
|
|
COBJS-$(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
|
bootstage: Implement core microsecond boot time measurement
This defines the basics of a new boot time measurement feature. This allows
logging of very accurate time measurements as the boot proceeds, by using
an available microsecond counter.
To enable the feature, define CONFIG_BOOTSTAGE in your board config file.
Also available is CONFIG_BOOTSTAGE_REPORT which will cause a report to be
printed just before handing off to the OS.
Most IDs are not named at this stage. For that I would first like to
renumber them all.
Timer summary in microseconds:
Mark Elapsed Stage
0 0 reset
205,000 205,000 board_init_f
6,053,000 5,848,000 bootm_start
6,053,000 0 id=1
6,058,000 5,000 id=101
6,058,000 0 id=100
6,061,000 3,000 id=103
6,064,000 3,000 id=104
6,093,000 29,000 id=107
6,093,000 0 id=106
6,093,000 0 id=105
6,093,000 0 id=108
7,089,000 996,000 id=7
7,089,000 0 id=15
7,089,000 0 id=8
7,097,000 8,000 start_kernel
Signed-off-by: Simon Glass <sjg@chromium.org>
13 years ago
|
|
|
COBJS-$(CONFIG_BOOTSTAGE) += bootstage.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_MENU) += menu.o
|
|
|
|
COBJS-$(CONFIG_MODEM_SUPPORT) += modem.o
|
|
|
|
COBJS-$(CONFIG_UPDATE_TFTP) += update.o
|
|
|
|
COBJS-$(CONFIG_USB_KEYBOARD) += usb_kbd.o
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifdef CONFIG_SPL_BUILD
|
|
|
|
COBJS-$(CONFIG_SPL_YMODEM_SUPPORT) += xyzModem.o
|
|
|
|
endif
|
|
|
|
COBJS-y += console.o
|
|
|
|
COBJS-y += dlmalloc.o
|
|
|
|
COBJS-y += memsize.o
|
|
|
|
COBJS-y += stdio.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
|
|
|
|
|
|
|
|
#########################################################################
|