blob: ab3740e54ab930a6fcad4f41cb3e24479fd524e6 [file] [log] [blame]
wdenk7ebf7442002-11-02 23:17:16 +00001#
Detlev Zundelfd428c02010-03-12 10:01:12 +01002# (C) Copyright 2000-2010
wdenk7ebf7442002-11-02 23:17:16 +00003# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
4#
5# See file CREDITS for list of people who contributed to this
6# project.
7#
8# This program is free software; you can redistribute it and/or
9# modify it under the terms of the GNU General Public License as
Wolfgang Denk45a212c2006-07-19 17:52:30 +020010# published by the Free Software Foundatio; either version 2 of
wdenk7ebf7442002-11-02 23:17:16 +000011# the License, or (at your option) any later version.
12#
13# This program is distributed in the hope that it will be useful,
14# but WITHOUT ANY WARRANTY; without even the implied warranty of
Wolfgang Denkf9301e12008-03-04 14:58:31 +010015# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
wdenk7ebf7442002-11-02 23:17:16 +000016# GNU General Public License for more details.
17#
18# You should have received a copy of the GNU General Public License
19# along with this program; if not, write to the Free Software
20# Foundation, Inc., 59 Temple Place, Suite 330, Boston,
21# MA 02111-1307 USA
22#
23
Wolfgang Denk42d44f62011-02-02 22:37:32 +010024VERSION = 2011
Wolfgang Denk7a82c202011-05-19 22:23:50 +020025PATCHLEVEL = 06
Wolfgang Denk8b9e4782008-09-09 23:55:18 +020026SUBLEVEL =
Wolfgang Denk79cfe422011-06-22 11:39:24 +020027EXTRAVERSION = -rc3
Wolfgang Denk8b9e4782008-09-09 23:55:18 +020028ifneq "$(SUBLEVEL)" ""
Wolfgang Denk881a87e2006-02-21 17:33:04 +010029U_BOOT_VERSION = $(VERSION).$(PATCHLEVEL).$(SUBLEVEL)$(EXTRAVERSION)
Wolfgang Denk8b9e4782008-09-09 23:55:18 +020030else
31U_BOOT_VERSION = $(VERSION).$(PATCHLEVEL)$(EXTRAVERSION)
32endif
Peter Tyser561858e2008-11-03 09:30:59 -060033TIMESTAMP_FILE = $(obj)include/timestamp_autogenerated.h
Marian Balakowiczf9328632006-09-01 19:49:50 +020034VERSION_FILE = $(obj)include/version_autogenerated.h
Wolfgang Denk881a87e2006-02-21 17:33:04 +010035
wdenk7ebf7442002-11-02 23:17:16 +000036HOSTARCH := $(shell uname -m | \
Graeme Russfea25722011-04-13 19:43:28 +100037 sed -e s/i.86/x86/ \
wdenk7ebf7442002-11-02 23:17:16 +000038 -e s/sun4u/sparc64/ \
39 -e s/arm.*/arm/ \
40 -e s/sa110/arm/ \
Kumar Galad0179082010-04-28 02:52:02 -050041 -e s/ppc64/powerpc/ \
42 -e s/ppc/powerpc/ \
Nobuhiro Iwamatsu8d1f6352010-06-16 07:59:17 +090043 -e s/macppc/powerpc/\
44 -e s/sh.*/sh/)
wdenk7ebf7442002-11-02 23:17:16 +000045
Wolfgang Denkf9d77ed2005-08-12 23:23:46 +020046HOSTOS := $(shell uname -s | tr '[:upper:]' '[:lower:]' | \
wdenk7ebf7442002-11-02 23:17:16 +000047 sed -e 's/\(cygwin\).*/cygwin/')
48
Peter Tysercf7a7b92008-11-12 12:33:20 -060049# Set shell to bash if possible, otherwise fall back to sh
50SHELL := $(shell if [ -x "$$BASH" ]; then echo $$BASH; \
51 else if [ -x /bin/bash ]; then echo /bin/bash; \
52 else echo sh; fi; fi)
53
54export HOSTARCH HOSTOS SHELL
wdenk7ebf7442002-11-02 23:17:16 +000055
56# Deal with colliding definitions from tcsh etc.
57VENDOR=
58
59#########################################################################
Wolfgang Denkae6d1052008-01-13 00:59:21 +010060# Allow for silent builds
61ifeq (,$(findstring s,$(MAKEFLAGS)))
62XECHO = echo
63else
64XECHO = :
65endif
66
67#########################################################################
Marian Balakowiczf9328632006-09-01 19:49:50 +020068#
69# U-boot build supports producing a object files to the separate external
70# directory. Two use cases are supported:
Stefan Roese887e2ec2006-09-07 11:51:23 +020071#
Marian Balakowiczf9328632006-09-01 19:49:50 +020072# 1) Add O= to the make command line
73# 'make O=/tmp/build all'
74#
75# 2) Set environement variable BUILD_DIR to point to the desired location
76# 'export BUILD_DIR=/tmp/build'
77# 'make'
78#
79# The second approach can also be used with a MAKEALL script
80# 'export BUILD_DIR=/tmp/build'
81# './MAKEALL'
Stefan Roese887e2ec2006-09-07 11:51:23 +020082#
Marian Balakowiczf9328632006-09-01 19:49:50 +020083# Command line 'O=' setting overrides BUILD_DIR environent variable.
Stefan Roese887e2ec2006-09-07 11:51:23 +020084#
Marian Balakowiczf9328632006-09-01 19:49:50 +020085# When none of the above methods is used the local build is performed and
86# the object files are placed in the source directory.
Stefan Roese887e2ec2006-09-07 11:51:23 +020087#
wdenk7ebf7442002-11-02 23:17:16 +000088
Marian Balakowiczf9328632006-09-01 19:49:50 +020089ifdef O
90ifeq ("$(origin O)", "command line")
91BUILD_DIR := $(O)
92endif
93endif
wdenk7ebf7442002-11-02 23:17:16 +000094
Marian Balakowiczf9328632006-09-01 19:49:50 +020095ifneq ($(BUILD_DIR),)
96saved-output := $(BUILD_DIR)
Marian Balakowicz4f0645e2006-09-07 12:05:53 +020097
98# Attempt to create a output directory.
99$(shell [ -d ${BUILD_DIR} ] || mkdir -p ${BUILD_DIR})
100
Stefan Roesea73c8db2006-09-12 08:49:07 +0200101# Verify if it was successful.
Marian Balakowiczf9328632006-09-01 19:49:50 +0200102BUILD_DIR := $(shell cd $(BUILD_DIR) && /bin/pwd)
103$(if $(BUILD_DIR),,$(error output directory "$(saved-output)" does not exist))
104endif # ifneq ($(BUILD_DIR),)
105
106OBJTREE := $(if $(BUILD_DIR),$(BUILD_DIR),$(CURDIR))
107SRCTREE := $(CURDIR)
108TOPDIR := $(SRCTREE)
109LNDIR := $(OBJTREE)
110export TOPDIR SRCTREE OBJTREE
111
112MKCONFIG := $(SRCTREE)/mkconfig
113export MKCONFIG
114
115ifneq ($(OBJTREE),$(SRCTREE))
Wolfgang Denkdd520bf2006-11-30 18:02:20 +0100116REMOTE_BUILD := 1
Marian Balakowiczf9328632006-09-01 19:49:50 +0200117export REMOTE_BUILD
118endif
119
120# $(obj) and (src) are defined in config.mk but here in main Makefile
121# we also need them before config.mk is included which is the case for
122# some targets like unconfig, clean, clobber, distclean, etc.
123ifneq ($(OBJTREE),$(SRCTREE))
124obj := $(OBJTREE)/
125src := $(SRCTREE)/
126else
127obj :=
128src :=
Stefan Roese887e2ec2006-09-07 11:51:23 +0200129endif
Marian Balakowiczf9328632006-09-01 19:49:50 +0200130export obj src
131
Wolfgang Denk5013c092008-03-02 22:45:33 +0100132# Make sure CDPATH settings don't interfere
133unexport CDPATH
134
Marian Balakowiczf9328632006-09-01 19:49:50 +0200135#########################################################################
136
Mike Frysinger6d1ce382009-05-30 01:02:03 -0400137# The "tools" are needed early, so put this first
138# Don't include stuff already done in $(LIBS)
139SUBDIRS = tools \
Peter Tyser1bc15382009-07-10 11:03:19 -0500140 examples/standalone \
Peter Tyserd4abc752009-07-20 19:02:21 -0500141 examples/api
Mike Frysinger6d1ce382009-05-30 01:02:03 -0400142
143.PHONY : $(SUBDIRS)
144
Wolfgang Denkae6d1052008-01-13 00:59:21 +0100145ifeq ($(obj)include/config.mk,$(wildcard $(obj)include/config.mk))
Marian Balakowiczf9328632006-09-01 19:49:50 +0200146
Mike Frysinger2632c002009-07-21 22:59:36 -0400147# Include autoconf.mk before config.mk so that the config options are available
148# to all top level build files. We need the dummy all: target to prevent the
149# dependency target in autoconf.mk.dep from being the default.
150all:
151sinclude $(obj)include/autoconf.mk.dep
152sinclude $(obj)include/autoconf.mk
153
wdenk7ebf7442002-11-02 23:17:16 +0000154# load ARCH, BOARD, and CPU configuration
Wolfgang Denkae6d1052008-01-13 00:59:21 +0100155include $(obj)include/config.mk
wdenk1d9f4102004-10-09 22:21:29 +0000156export ARCH CPU BOARD VENDOR SOC
Marian Balakowiczf9328632006-09-01 19:49:50 +0200157
Mike Frysinger1ea6bcd2009-06-14 23:33:14 -0400158# set default to nothing for native builds
Wolfgang Denka5284ef2007-03-06 18:01:47 +0100159ifeq ($(HOSTARCH),$(ARCH))
Mike Frysinger1ea6bcd2009-06-14 23:33:14 -0400160CROSS_COMPILE ?=
wdenk7ebf7442002-11-02 23:17:16 +0000161endif
wdenk7ebf7442002-11-02 23:17:16 +0000162
Wolfgang Denk92b197f2006-03-12 01:37:50 +0100163# load other configuration
164include $(TOPDIR)/config.mk
165
Ilya Yanokd51dfff2011-06-20 12:45:37 +0000166# If board code explicitly specified LDSCRIPT or CONFIG_SYS_LDSCRIPT, use
167# that (or fail if absent). Otherwise, search for a linker script in a
168# standard location.
169
170ifndef LDSCRIPT
171 #LDSCRIPT := $(TOPDIR)/board/$(BOARDDIR)/u-boot.lds.debug
172 ifdef CONFIG_SYS_LDSCRIPT
173 # need to strip off double quotes
174 LDSCRIPT := $(subst ",,$(CONFIG_SYS_LDSCRIPT))
175 endif
176endif
177
178ifndef LDSCRIPT
179 ifeq ($(CONFIG_NAND_U_BOOT),y)
180 LDSCRIPT := $(TOPDIR)/board/$(BOARDDIR)/u-boot-nand.lds
181 ifeq ($(wildcard $(LDSCRIPT)),)
182 LDSCRIPT := $(TOPDIR)/$(CPUDIR)/u-boot-nand.lds
183 endif
184 endif
185 ifeq ($(wildcard $(LDSCRIPT)),)
186 LDSCRIPT := $(TOPDIR)/board/$(BOARDDIR)/u-boot.lds
187 endif
188 ifeq ($(wildcard $(LDSCRIPT)),)
189 LDSCRIPT := $(TOPDIR)/$(CPUDIR)/u-boot.lds
190 endif
191 ifeq ($(wildcard $(LDSCRIPT)),)
192$(error could not find linker script)
193 endif
194endif
195
wdenk7ebf7442002-11-02 23:17:16 +0000196#########################################################################
197# U-Boot objects....order is important (i.e. start must be first)
198
Peter Tyser03b70042010-04-12 22:28:02 -0500199OBJS = $(CPUDIR)/start.o
Graeme Russfea25722011-04-13 19:43:28 +1000200ifeq ($(CPU),x86)
Peter Tyser03b70042010-04-12 22:28:02 -0500201OBJS += $(CPUDIR)/start16.o
202OBJS += $(CPUDIR)/resetvec.o
wdenk2262cfe2002-11-18 00:14:45 +0000203endif
wdenk7ebf7442002-11-02 23:17:16 +0000204ifeq ($(CPU),ppc4xx)
Peter Tyser03b70042010-04-12 22:28:02 -0500205OBJS += $(CPUDIR)/resetvec.o
wdenk7ebf7442002-11-02 23:17:16 +0000206endif
wdenk42d1f032003-10-15 23:53:47 +0000207ifeq ($(CPU),mpc85xx)
Peter Tyser03b70042010-04-12 22:28:02 -0500208OBJS += $(CPUDIR)/resetvec.o
wdenk42d1f032003-10-15 23:53:47 +0000209endif
wdenk7ebf7442002-11-02 23:17:16 +0000210
Marian Balakowiczf9328632006-09-01 19:49:50 +0200211OBJS := $(addprefix $(obj),$(OBJS))
212
Sebastien Carlier6d8962e2010-11-05 15:48:07 +0100213LIBS = lib/libgeneric.o
214LIBS += lib/lzma/liblzma.o
215LIBS += lib/lzo/liblzo.o
Mike Frysingere89516f2011-04-08 12:23:30 +0000216LIBS += lib/zlib/libz.o
Kim Phillips7608d752007-08-21 17:00:17 -0500217LIBS += $(shell if [ -f board/$(VENDOR)/common/Makefile ]; then echo \
Sebastien Carlier6d8962e2010-11-05 15:48:07 +0100218 "board/$(VENDOR)/common/lib$(VENDOR).o"; fi)
219LIBS += $(CPUDIR)/lib$(CPU).o
wdenk1d9f4102004-10-09 22:21:29 +0000220ifdef SOC
Sebastien Carlier6d8962e2010-11-05 15:48:07 +0100221LIBS += $(CPUDIR)/$(SOC)/lib$(SOC).o
wdenk1d9f4102004-10-09 22:21:29 +0000222endif
Stefan Roese323bfa82007-04-23 12:00:22 +0200223ifeq ($(CPU),ixp)
Sebastien Carlier6d8962e2010-11-05 15:48:07 +0100224LIBS += arch/arm/cpu/ixp/npe/libnpe.o
Stefan Roese323bfa82007-04-23 12:00:22 +0200225endif
Sebastien Carlier6d8962e2010-11-05 15:48:07 +0100226LIBS += arch/$(ARCH)/lib/lib$(ARCH).o
227LIBS += fs/cramfs/libcramfs.o fs/fat/libfat.o fs/fdos/libfdos.o fs/jffs2/libjffs2.o \
228 fs/reiserfs/libreiserfs.o fs/ext2/libext2fs.o fs/yaffs2/libyaffs2.o \
229 fs/ubifs/libubifs.o
230LIBS += net/libnet.o
231LIBS += disk/libdisk.o
232LIBS += drivers/bios_emulator/libatibiosemu.o
233LIBS += drivers/block/libblock.o
234LIBS += drivers/dma/libdma.o
235LIBS += drivers/fpga/libfpga.o
236LIBS += drivers/gpio/libgpio.o
237LIBS += drivers/hwmon/libhwmon.o
238LIBS += drivers/i2c/libi2c.o
239LIBS += drivers/input/libinput.o
240LIBS += drivers/misc/libmisc.o
241LIBS += drivers/mmc/libmmc.o
242LIBS += drivers/mtd/libmtd.o
243LIBS += drivers/mtd/nand/libnand.o
244LIBS += drivers/mtd/onenand/libonenand.o
245LIBS += drivers/mtd/ubi/libubi.o
246LIBS += drivers/mtd/spi/libspi_flash.o
247LIBS += drivers/net/libnet.o
248LIBS += drivers/net/phy/libphy.o
249LIBS += drivers/pci/libpci.o
250LIBS += drivers/pcmcia/libpcmcia.o
251LIBS += drivers/power/libpower.o
252LIBS += drivers/spi/libspi.o
Dave Liu7737d5c2006-11-03 12:11:15 -0600253ifeq ($(CPU),mpc83xx)
Sebastien Carlier6d8962e2010-11-05 15:48:07 +0100254LIBS += drivers/qe/libqe.o
255LIBS += arch/powerpc/cpu/mpc8xxx/lib8xxx.o
Dave Liu7737d5c2006-11-03 12:11:15 -0600256endif
Andy Flemingda9d4612007-08-14 00:14:25 -0500257ifeq ($(CPU),mpc85xx)
Sebastien Carlier6d8962e2010-11-05 15:48:07 +0100258LIBS += drivers/qe/libqe.o
259LIBS += arch/powerpc/cpu/mpc8xxx/ddr/libddr.o
260LIBS += arch/powerpc/cpu/mpc8xxx/lib8xxx.o
Kumar Gala58e5e9a2008-08-26 15:01:29 -0500261endif
262ifeq ($(CPU),mpc86xx)
Sebastien Carlier6d8962e2010-11-05 15:48:07 +0100263LIBS += arch/powerpc/cpu/mpc8xxx/ddr/libddr.o
264LIBS += arch/powerpc/cpu/mpc8xxx/lib8xxx.o
Andy Flemingda9d4612007-08-14 00:14:25 -0500265endif
Sebastien Carlier6d8962e2010-11-05 15:48:07 +0100266LIBS += drivers/rtc/librtc.o
267LIBS += drivers/serial/libserial.o
268LIBS += drivers/twserial/libtws.o
Simon Glass89d48362011-02-16 11:14:33 -0800269LIBS += drivers/usb/eth/libusb_eth.a
Sebastien Carlier6d8962e2010-11-05 15:48:07 +0100270LIBS += drivers/usb/gadget/libusb_gadget.o
271LIBS += drivers/usb/host/libusb_host.o
272LIBS += drivers/usb/musb/libusb_musb.o
273LIBS += drivers/usb/phy/libusb_phy.o
274LIBS += drivers/video/libvideo.o
275LIBS += drivers/watchdog/libwatchdog.o
276LIBS += common/libcommon.o
277LIBS += lib/libfdt/libfdt.o
278LIBS += api/libapi.o
279LIBS += post/libpost.o
Marian Balakowiczf9328632006-09-01 19:49:50 +0200280
Steve Sakomand34efc72010-06-08 13:07:46 -0700281ifeq ($(SOC),omap3)
Sebastien Carlier6d8962e2010-11-05 15:48:07 +0100282LIBS += $(CPUDIR)/omap-common/libomap-common.o
Steve Sakomand34efc72010-06-08 13:07:46 -0700283endif
284ifeq ($(SOC),omap4)
Sebastien Carlier6d8962e2010-11-05 15:48:07 +0100285LIBS += $(CPUDIR)/omap-common/libomap-common.o
Steve Sakomand34efc72010-06-08 13:07:46 -0700286endif
287
Minkyu Kang852bd072010-08-19 13:48:11 +0900288ifeq ($(SOC),s5pc1xx)
Sebastien Carlier6d8962e2010-11-05 15:48:07 +0100289LIBS += $(CPUDIR)/s5p-common/libs5p-common.o
Minkyu Kang852bd072010-08-19 13:48:11 +0900290endif
291ifeq ($(SOC),s5pc2xx)
Sebastien Carlier6d8962e2010-11-05 15:48:07 +0100292LIBS += $(CPUDIR)/s5p-common/libs5p-common.o
Minkyu Kang852bd072010-08-19 13:48:11 +0900293endif
294
Wolfgang Denk566d49a2010-11-22 23:36:42 +0100295LIBS := $(addprefix $(obj),$(sort $(LIBS)))
Peter Tyser561858e2008-11-03 09:30:59 -0600296.PHONY : $(LIBS) $(TIMESTAMP_FILE) $(VERSION_FILE)
wdenka8c7c702003-12-06 19:49:23 +0000297
Sebastien Carlier6d8962e2010-11-05 15:48:07 +0100298LIBBOARD = board/$(BOARDDIR)/lib$(BOARD).o
Wolfgang Denkde109d92008-04-30 17:25:07 +0200299LIBBOARD := $(addprefix $(obj),$(LIBBOARD))
300
wdenk4f7cb082003-09-11 23:06:34 +0000301# Add GCC lib
Wolfgang Denk52b1bf22009-07-23 13:15:59 +0200302ifdef USE_PRIVATE_LIBGCC
303ifeq ("$(USE_PRIVATE_LIBGCC)", "yes")
Matthias Weisser635d1b32010-11-18 09:35:09 +0100304PLATFORM_LIBGCC = $(OBJTREE)/arch/$(ARCH)/lib/libgcc.o
Wolfgang Denk52b1bf22009-07-23 13:15:59 +0200305else
306PLATFORM_LIBGCC = -L $(USE_PRIVATE_LIBGCC) -lgcc
307endif
308else
309PLATFORM_LIBGCC = -L $(shell dirname `$(CC) $(CFLAGS) -print-libgcc-file-name`) -lgcc
310endif
311PLATFORM_LIBS += $(PLATFORM_LIBGCC)
312export PLATFORM_LIBS
wdenk3d3befa2004-03-14 15:06:13 +0000313
Mike Frysinger6ac9f472009-08-23 02:47:59 -0400314# Special flags for CPP when processing the linker script.
315# Pass the version down so we can handle backwards compatibility
316# on the fly.
317LDPPFLAGS += \
318 -include $(TOPDIR)/include/u-boot/u-boot.lds.h \
319 $(shell $(LD) --version | \
320 sed -ne 's/GNU ld version \([0-9][0-9]*\)\.\([0-9][0-9]*\).*/-DLD_MAJOR=\1 -DLD_MINOR=\2/p')
321
Marian Balakowiczf9328632006-09-01 19:49:50 +0200322__OBJS := $(subst $(obj),,$(OBJS))
Wolfgang Denkde109d92008-04-30 17:25:07 +0200323__LIBS := $(subst $(obj),,$(LIBS)) $(subst $(obj),,$(LIBBOARD))
Marian Balakowiczf9328632006-09-01 19:49:50 +0200324
wdenk7ebf7442002-11-02 23:17:16 +0000325#########################################################################
wdenkbdccc4f2003-08-05 17:43:17 +0000326#########################################################################
wdenk7ebf7442002-11-02 23:17:16 +0000327
Mike Frysingerf3a14d32010-10-13 22:58:23 -0400328ifneq ($(CONFIG_BOARD_SIZE_LIMIT),)
329BOARD_SIZE_CHECK = \
330 @actual=`wc -c $@ | awk '{print $$1}'`; \
331 limit=$(CONFIG_BOARD_SIZE_LIMIT); \
332 if test $$actual -gt $$limit; then \
333 echo "$@ exceeds file size limit:"; \
334 echo " limit: $$limit bytes"; \
335 echo " actual: $$actual bytes"; \
336 echo " excess: $$((actual - limit)) bytes"; \
337 exit 1; \
338 fi
339else
340BOARD_SIZE_CHECK =
341endif
342
Mike Frysinger3e883372009-06-15 00:25:19 -0400343# Always append ALL so that arch config.mk's can add custom ones
Haiying Wange935a372011-01-27 09:44:59 -0500344ALL += $(obj)u-boot.srec $(obj)u-boot.bin $(obj)System.map
345
346ifeq ($(CONFIG_NAND_U_BOOT),y)
347ALL += $(obj)u-boot-nand.bin
348endif
349
350ifeq ($(CONFIG_ONENAND_U_BOOT),y)
351ALL += $(obj)u-boot-onenand.bin
352ONENAND_BIN ?= $(obj)onenand_ipl/onenand-ipl-2k.bin
353endif
wdenk7ebf7442002-11-02 23:17:16 +0000354
Chander Kashyap0d3c62e2011-05-24 20:02:57 +0000355ifeq ($(CONFIG_MMC_U_BOOT),y)
356ALL += $(obj)mmc_spl/u-boot-mmc-spl.bin
357endif
358
wdenkbdccc4f2003-08-05 17:43:17 +0000359all: $(ALL)
wdenk7ebf7442002-11-02 23:17:16 +0000360
Marian Balakowiczf9328632006-09-01 19:49:50 +0200361$(obj)u-boot.hex: $(obj)u-boot
wdenk6310eb92005-01-09 21:28:15 +0000362 $(OBJCOPY) ${OBJCFLAGS} -O ihex $< $@
363
Marian Balakowiczf9328632006-09-01 19:49:50 +0200364$(obj)u-boot.srec: $(obj)u-boot
Ricardo Ribalda Delgado0817d682008-09-07 17:10:27 -0400365 $(OBJCOPY) -O srec $< $@
wdenk7ebf7442002-11-02 23:17:16 +0000366
Marian Balakowiczf9328632006-09-01 19:49:50 +0200367$(obj)u-boot.bin: $(obj)u-boot
wdenk7ebf7442002-11-02 23:17:16 +0000368 $(OBJCOPY) ${OBJCFLAGS} -O binary $< $@
Mike Frysingerf3a14d32010-10-13 22:58:23 -0400369 $(BOARD_SIZE_CHECK)
wdenk7ebf7442002-11-02 23:17:16 +0000370
Mike Frysinger94a91e22008-02-04 19:26:57 -0500371$(obj)u-boot.ldr: $(obj)u-boot
Mike Frysinger76d82182009-07-21 22:17:36 -0400372 $(CREATE_LDR_ENV)
Mike Frysinger68e56322008-08-07 18:56:56 -0400373 $(LDR) -T $(CONFIG_BFIN_CPU) -c $@ $< $(LDR_FLAGS)
Mike Frysingerf3a14d32010-10-13 22:58:23 -0400374 $(BOARD_SIZE_CHECK)
Mike Frysinger94a91e22008-02-04 19:26:57 -0500375
376$(obj)u-boot.ldr.hex: $(obj)u-boot.ldr
377 $(OBJCOPY) ${OBJCFLAGS} -O ihex $< $@ -I binary
378
379$(obj)u-boot.ldr.srec: $(obj)u-boot.ldr
380 $(OBJCOPY) ${OBJCFLAGS} -O srec $< $@ -I binary
381
Marian Balakowiczf9328632006-09-01 19:49:50 +0200382$(obj)u-boot.img: $(obj)u-boot.bin
Wolfgang Denka2a0a712010-05-15 21:23:51 +0200383 $(obj)tools/mkimage -A $(ARCH) -T firmware -C none \
Wolfgang Denk14d0a022010-10-07 21:51:12 +0200384 -a $(CONFIG_SYS_TEXT_BASE) -e 0 \
Wolfgang Denk881a87e2006-02-21 17:33:04 +0100385 -n $(shell sed -n -e 's/.*U_BOOT_VERSION//p' $(VERSION_FILE) | \
wdenkbdccc4f2003-08-05 17:43:17 +0000386 sed -e 's/"[ ]*$$/ for $(BOARD) board"/') \
387 -d $< $@
388
Stefano Babic8edcde52010-01-20 18:19:10 +0100389$(obj)u-boot.imx: $(obj)u-boot.bin
Stefano Babic45d7d722011-01-24 00:14:26 +0000390 $(obj)tools/mkimage -n $(CONFIG_IMX_CONFIG) -T imximage \
Wolfgang Denk14d0a022010-10-07 21:51:12 +0200391 -e $(CONFIG_SYS_TEXT_BASE) -d $< $@
Stefano Babic8edcde52010-01-20 18:19:10 +0100392
Prafulla Wadaskaraa0c7a82009-09-07 15:05:02 +0530393$(obj)u-boot.kwb: $(obj)u-boot.bin
Prafulla Wadaskar31d80c72010-10-27 17:46:06 +0530394 $(obj)tools/mkimage -n $(CONFIG_SYS_KWD_CONFIG) -T kwbimage \
Eric Cooper2ea88b02010-10-19 13:31:11 -0400395 -a $(CONFIG_SYS_TEXT_BASE) -e $(CONFIG_SYS_TEXT_BASE) -d $< $@
Prafulla Wadaskaraa0c7a82009-09-07 15:05:02 +0530396
Heiko Schocher566a4942007-06-22 19:11:54 +0200397$(obj)u-boot.sha1: $(obj)u-boot.bin
Heiko Schocher01159532007-07-14 01:06:58 +0200398 $(obj)tools/ubsha1 $(obj)u-boot.bin
Heiko Schocher566a4942007-06-22 19:11:54 +0200399
Marian Balakowiczf9328632006-09-01 19:49:50 +0200400$(obj)u-boot.dis: $(obj)u-boot
wdenk7ebf7442002-11-02 23:17:16 +0000401 $(OBJDUMP) -d $< > $@
402
Mike Frysingerecb1dc82009-05-20 04:35:14 -0400403GEN_UBOOT = \
Wolfgang Denkde109d92008-04-30 17:25:07 +0200404 UNDEF_SYM=`$(OBJDUMP) -x $(LIBBOARD) $(LIBS) | \
405 sed -n -e 's/.*\($(SYM_PREFIX)__u_boot_cmd_.*\)/-u\1/p'|sort|uniq`;\
Nobuhiro Iwamatsu8aba9dc2011-01-06 10:23:54 +0900406 cd $(LNDIR) && $(LD) $(LDFLAGS) $(LDFLAGS_$(@F)) $$UNDEF_SYM $(__OBJS) \
Marian Balakowiczf9328632006-09-01 19:49:50 +0200407 --start-group $(__LIBS) --end-group $(PLATFORM_LIBS) \
wdenkb2184c32002-11-19 23:01:07 +0000408 -Map u-boot.map -o u-boot
Wolfgang Denk16a354f2010-10-26 00:08:35 +0200409$(obj)u-boot: depend \
410 $(SUBDIRS) $(OBJS) $(LIBBOARD) $(LIBS) $(LDSCRIPT) $(obj)u-boot.lds
Mike Frysingerecb1dc82009-05-20 04:35:14 -0400411 $(GEN_UBOOT)
412ifeq ($(CONFIG_KALLSYMS),y)
Wolfgang Denk1aada9c2009-08-17 14:00:53 +0200413 smap=`$(call SYSTEM_MAP,u-boot) | \
414 awk '$$2 ~ /[tTwW]/ {printf $$1 $$3 "\\\\000"}'` ; \
415 $(CC) $(CFLAGS) -DSYSTEM_MAP="\"$${smap}\"" \
416 -c common/system_map.c -o $(obj)common/system_map.o
Mike Frysingerecb1dc82009-05-20 04:35:14 -0400417 $(GEN_UBOOT) $(obj)common/system_map.o
418endif
wdenk7ebf7442002-11-02 23:17:16 +0000419
Peter Tyserd0d61442009-03-13 18:54:25 -0500420$(OBJS): depend
Peter Tyser03b70042010-04-12 22:28:02 -0500421 $(MAKE) -C $(CPUDIR) $(if $(REMOTE_BUILD),$@,$(notdir $@))
Marian Balakowiczf9328632006-09-01 19:49:50 +0200422
Peter Tyserd0d61442009-03-13 18:54:25 -0500423$(LIBS): depend $(SUBDIRS)
Marian Balakowiczf9328632006-09-01 19:49:50 +0200424 $(MAKE) -C $(dir $(subst $(obj),,$@))
wdenka8c7c702003-12-06 19:49:23 +0000425
Peter Tyserd0d61442009-03-13 18:54:25 -0500426$(LIBBOARD): depend $(LIBS)
Wolfgang Denkde109d92008-04-30 17:25:07 +0200427 $(MAKE) -C $(dir $(subst $(obj),,$@))
428
Peter Tyserd0d61442009-03-13 18:54:25 -0500429$(SUBDIRS): depend
wdenkb028f712003-12-07 21:39:28 +0000430 $(MAKE) -C $@ all
wdenk7ebf7442002-11-02 23:17:16 +0000431
Peter Tyserd0d61442009-03-13 18:54:25 -0500432$(LDSCRIPT): depend
Mike Frysingerf65c9812008-02-16 02:12:37 -0500433 $(MAKE) -C $(dir $@) $(notdir $@)
434
Wolfgang Denk1aada9c2009-08-17 14:00:53 +0200435$(obj)u-boot.lds: $(LDSCRIPT)
436 $(CPP) $(CPPFLAGS) $(LDPPFLAGS) -ansi -D__ASSEMBLY__ -P - <$^ >$@
437
Haiying Wange935a372011-01-27 09:44:59 -0500438nand_spl: $(TIMESTAMP_FILE) $(VERSION_FILE) depend
Marian Balakowicz8318fbf2006-10-23 22:17:05 +0200439 $(MAKE) -C nand_spl/board/$(BOARDDIR) all
Stefan Roese887e2ec2006-09-07 11:51:23 +0200440
Haiying Wange935a372011-01-27 09:44:59 -0500441$(obj)u-boot-nand.bin: nand_spl $(obj)u-boot.bin
Marian Balakowicz8318fbf2006-10-23 22:17:05 +0200442 cat $(obj)nand_spl/u-boot-spl-16k.bin $(obj)u-boot.bin > $(obj)u-boot-nand.bin
Stefan Roese887e2ec2006-09-07 11:51:23 +0200443
Haiying Wange935a372011-01-27 09:44:59 -0500444onenand_ipl: $(TIMESTAMP_FILE) $(VERSION_FILE) $(obj)include/autoconf.mk
Stefan Roesef2302d42008-08-06 14:05:38 +0200445 $(MAKE) -C onenand_ipl/board/$(BOARDDIR) all
Kyungmin Park751b9b52008-01-17 16:43:25 +0900446
Haiying Wange935a372011-01-27 09:44:59 -0500447$(obj)u-boot-onenand.bin: onenand_ipl $(obj)u-boot.bin
Kyungmin Parkca6189d2009-09-22 09:05:00 +0900448 cat $(ONENAND_BIN) $(obj)u-boot.bin > $(obj)u-boot-onenand.bin
Kyungmin Park751b9b52008-01-17 16:43:25 +0900449
Chander Kashyap0d3c62e2011-05-24 20:02:57 +0000450mmc_spl: $(TIMESTAMP_FILE) $(VERSION_FILE) depend
451 $(MAKE) -C mmc_spl/board/$(BOARDDIR) all
452
453$(obj)mmc_spl/u-boot-mmc-spl.bin: mmc_spl
454
Wolfgang Denkae6d1052008-01-13 00:59:21 +0100455$(VERSION_FILE):
Wolfgang Denk976b38c2011-02-12 10:37:11 +0100456 @( localvers='$(shell $(TOPDIR)/tools/setlocalversion $(TOPDIR))' ; \
457 printf '#define PLAIN_VERSION "%s%s"\n' \
458 "$(U_BOOT_VERSION)" "$${localvers}" ; \
459 printf '#define U_BOOT_VERSION "U-Boot %s%s"\n' \
460 "$(U_BOOT_VERSION)" "$${localvers}" ; \
461 ) > $@.tmp
Alexander Holler89ffa8d2011-01-19 00:24:40 +0100462 @( printf '#define CC_VERSION_STRING "%s"\n' \
463 '$(shell $(CC) --version | head -n 1)' )>> $@.tmp
464 @( printf '#define LD_VERSION_STRING "%s"\n' \
465 '$(shell $(LD) -v | head -n 1)' )>> $@.tmp
Mike Frysinger0ec7a062008-02-04 17:44:23 -0500466 @cmp -s $@ $@.tmp && rm -f $@.tmp || mv -f $@.tmp $@
Wolfgang Denk881a87e2006-02-21 17:33:04 +0100467
Peter Tyser561858e2008-11-03 09:30:59 -0600468$(TIMESTAMP_FILE):
Ilya Yanokd6b93712010-06-21 18:13:21 +0400469 @LC_ALL=C date +'#define U_BOOT_DATE "%b %d %C%y"' > $@
470 @LC_ALL=C date +'#define U_BOOT_TIME "%T"' >> $@
Peter Tyser561858e2008-11-03 09:30:59 -0600471
Marian Balakowiczf9328632006-09-01 19:49:50 +0200472updater:
Mike Frysinger0358df42010-08-15 00:03:21 -0400473 $(MAKE) -C tools/updater all
dzu8f713fd2003-08-07 14:20:31 +0000474
Daniel Hobi2a998792010-01-18 18:13:39 +0100475# Explicitly make _depend in subdirs containing multiple targets to prevent
476# parallel sub-makes creating .depend files simultaneously.
Wolfgang Denk16a354f2010-10-26 00:08:35 +0200477depend dep: $(TIMESTAMP_FILE) $(VERSION_FILE) \
478 $(obj)include/autoconf.mk \
479 $(obj)include/generated/generic-asm-offsets.h
Peter Tyser03b70042010-04-12 22:28:02 -0500480 for dir in $(SUBDIRS) $(CPUDIR) $(dir $(LDSCRIPT)) ; do \
Daniel Hobi2a998792010-01-18 18:13:39 +0100481 $(MAKE) -C $$dir _depend ; done
wdenk7ebf7442002-11-02 23:17:16 +0000482
Li Yange5e4e702009-12-09 18:13:26 +0800483TAG_SUBDIRS = $(SUBDIRS)
484TAG_SUBDIRS += $(dir $(__LIBS))
Jean-Christophe PLAGNIOL-VILLARDa340c322007-11-25 18:45:47 +0100485TAG_SUBDIRS += include
Jean-Christophe PLAGNIOL-VILLARDa340c322007-11-25 18:45:47 +0100486
Marian Balakowiczf9328632006-09-01 19:49:50 +0200487tags ctags:
Li Yange5e4e702009-12-09 18:13:26 +0800488 ctags -w -o $(obj)ctags `find $(TAG_SUBDIRS) \
489 -name '*.[chS]' -print`
wdenk7ebf7442002-11-02 23:17:16 +0000490
491etags:
Li Yange5e4e702009-12-09 18:13:26 +0800492 etags -a -o $(obj)etags `find $(TAG_SUBDIRS) \
493 -name '*.[chS]' -print`
Li Yangffda5862008-02-29 11:46:05 +0800494cscope:
Li Yange5e4e702009-12-09 18:13:26 +0800495 find $(TAG_SUBDIRS) -name '*.[chS]' -print > cscope.files
Li Yangffda5862008-02-29 11:46:05 +0800496 cscope -b -q -k
wdenk7ebf7442002-11-02 23:17:16 +0000497
Mike Frysingerecb1dc82009-05-20 04:35:14 -0400498SYSTEM_MAP = \
499 $(NM) $1 | \
wdenk7ebf7442002-11-02 23:17:16 +0000500 grep -v '\(compiled\)\|\(\.o$$\)\|\( [aUw] \)\|\(\.\.ng$$\)\|\(LASH[RL]DI\)' | \
Mike Frysingerecb1dc82009-05-20 04:35:14 -0400501 LC_ALL=C sort
502$(obj)System.map: $(obj)u-boot
503 @$(call SYSTEM_MAP,$<) > $(obj)System.map
wdenk7ebf7442002-11-02 23:17:16 +0000504
Grant Likely2f155f62007-09-24 09:05:31 -0600505#
506# Auto-generate the autoconf.mk file (which is included by all makefiles)
507#
508# This target actually generates 2 files; autoconf.mk and autoconf.mk.dep.
509# the dep file is only include in this top level makefile to determine when
510# to regenerate the autoconf.mk file.
Wolfgang Denk1510b822008-05-13 23:15:52 +0200511$(obj)include/autoconf.mk.dep: $(obj)include/config.h include/common.h
512 @$(XECHO) Generating $@ ; \
Mike Frysinger16fe7772008-02-18 05:10:07 -0500513 set -e ; \
Wolfgang Denkae6d1052008-01-13 00:59:21 +0100514 : Generate the dependancies ; \
Mike Frysinger9aef7382009-07-19 15:17:03 -0400515 $(CC) -x c -DDO_DEPS_ONLY -M $(HOSTCFLAGS) $(CPPFLAGS) \
Wolfgang Denk1510b822008-05-13 23:15:52 +0200516 -MQ $(obj)include/autoconf.mk include/common.h > $@
517
518$(obj)include/autoconf.mk: $(obj)include/config.h
519 @$(XECHO) Generating $@ ; \
520 set -e ; \
Wolfgang Denkae6d1052008-01-13 00:59:21 +0100521 : Extract the config macros ; \
Wolfgang Denk1510b822008-05-13 23:15:52 +0200522 $(CPP) $(CFLAGS) -DDO_DEPS_ONLY -dM include/common.h | \
Wolfgang Denk4a0f7532008-12-16 14:41:02 +0100523 sed -n -f tools/scripts/define2mk.sed > $@.tmp && \
524 mv $@.tmp $@
Grant Likely2f155f62007-09-24 09:05:31 -0600525
Wolfgang Denk16a354f2010-10-26 00:08:35 +0200526$(obj)include/generated/generic-asm-offsets.h: $(obj)include/autoconf.mk.dep \
527 $(obj)lib/asm-offsets.s
528 @$(XECHO) Generating $@
529 tools/scripts/make-asm-offsets $(obj)lib/asm-offsets.s $@
530
531$(obj)lib/asm-offsets.s: $(obj)include/autoconf.mk.dep \
532 $(src)lib/asm-offsets.c
533 @mkdir -p $(obj)lib
534 $(CC) -DDO_DEPS_ONLY \
535 $(CFLAGS) $(CFLAGS_$(BCURDIR)/$(@F)) $(CFLAGS_$(BCURDIR)) \
536 -o $@ $(src)lib/asm-offsets.c -c -S
537
wdenk7ebf7442002-11-02 23:17:16 +0000538#########################################################################
Wolfgang Denkae6d1052008-01-13 00:59:21 +0100539else # !config.mk
Marian Balakowiczf9328632006-09-01 19:49:50 +0200540all $(obj)u-boot.hex $(obj)u-boot.srec $(obj)u-boot.bin \
541$(obj)u-boot.img $(obj)u-boot.dis $(obj)u-boot \
Mike Frysinger0358df42010-08-15 00:03:21 -0400542$(filter-out tools,$(SUBDIRS)) $(TIMESTAMP_FILE) $(VERSION_FILE) \
543updater depend dep tags ctags etags cscope $(obj)System.map:
wdenk7ebf7442002-11-02 23:17:16 +0000544 @echo "System not configured - see README" >&2
545 @ exit 1
Mike Frysingerc7c0d542010-01-21 04:03:22 -0500546
547tools:
Mike Frysinger0358df42010-08-15 00:03:21 -0400548 $(MAKE) -C $@ all
Wolfgang Denkae6d1052008-01-13 00:59:21 +0100549endif # config.mk
wdenk7ebf7442002-11-02 23:17:16 +0000550
Mike Frysinger0358df42010-08-15 00:03:21 -0400551easylogo env gdb:
552 $(MAKE) -C tools/$@ all MTD_VERSION=${MTD_VERSION}
553gdbtools: gdb
554
555tools-all: easylogo env gdb
556 $(MAKE) -C tools HOST_TOOLS_ALL=y
557
Wolfgang Denk4e53a252006-10-25 00:43:17 +0200558.PHONY : CHANGELOG
559CHANGELOG:
Ben Warrenb985b5d2006-10-26 14:38:25 -0400560 git log --no-merges U-Boot-1_1_5.. | \
561 unexpand -a | sed -e 's/\s\s*$$//' > $@
Wolfgang Denk4e53a252006-10-25 00:43:17 +0200562
Harald Welte0a823aa2008-07-09 22:30:30 +0800563include/license.h: tools/bin2header COPYING
Wolfgang Denk0e42ada2010-05-27 23:18:33 +0200564 cat COPYING | gzip -9 -c | ./tools/bin2header license_gzip > include/license.h
wdenk7ebf7442002-11-02 23:17:16 +0000565#########################################################################
566
567unconfig:
Stefan Roese887e2ec2006-09-07 11:51:23 +0200568 @rm -f $(obj)include/config.h $(obj)include/config.mk \
Grant Likely2f155f62007-09-24 09:05:31 -0600569 $(obj)board/*/config.tmp $(obj)board/*/*/config.tmp \
570 $(obj)include/autoconf.mk $(obj)include/autoconf.mk.dep
wdenk7ebf7442002-11-02 23:17:16 +0000571
Wolfgang Denka6862bc2010-05-27 23:18:36 +0200572%_config:: unconfig
573 @$(MKCONFIG) -A $(@:_config=)
574
Loïc Minierd6a5e6d2011-01-19 13:16:30 +0100575sinclude $(obj).boards.depend
576$(obj).boards.depend: boards.cfg
Mike Frysinger727ebd92010-08-11 18:52:36 -0400577 awk '(NF && $$1 !~ /^#/) { print $$1 ": " $$1 "_config; $$(MAKE)" }' $< > $@
Mike Frysinger9f4a4202009-10-01 12:11:54 -0400578
Wolfgang Denk8c994632010-05-27 23:18:35 +0200579#
580# Functions to generate common board directory names
581#
582lcname = $(shell echo $(1) | sed -e 's/\(.*\)_config/\L\1/')
583ucname = $(shell echo $(1) | sed -e 's/\(.*\)_config/\U\1/')
584
wdenk4e5ca3e2003-12-08 01:34:36 +0000585#########################################################################
586## Coldfire
587#########################################################################
588
Wolfgang Wegner9d79e572010-01-25 11:27:44 +0100589astro_mcf5373l_config \
590astro_mcf5373l_RAM_config : unconfig
Wolfgang Denked7a1962010-05-27 23:18:34 +0200591 @$(MKCONFIG) -n $@ -t $@ astro_mcf5373l m68k mcf532x mcf5373l astro
Wolfgang Wegner9d79e572010-01-25 11:27:44 +0100592
TsiChung Liewa21d0c22008-10-21 15:37:02 +0000593M52277EVB_config \
594M52277EVB_spansion_config \
595M52277EVB_stmicro_config : unconfig
596 @case "$@" in \
597 M52277EVB_config) FLASH=SPANSION;; \
598 M52277EVB_spansion_config) FLASH=SPANSION;; \
599 M52277EVB_stmicro_config) FLASH=STMICRO;; \
600 esac; \
601 if [ "$${FLASH}" = "SPANSION" ] ; then \
602 echo "#define CONFIG_SYS_SPANSION_BOOT" >> $(obj)include/config.h ; \
Wolfgang Denk14d0a022010-10-07 21:51:12 +0200603 echo "CONFIG_SYS_TEXT_BASE = 0x00000000" > $(obj)board/freescale/m52277evb/config.tmp ; \
TsiChung Liewa21d0c22008-10-21 15:37:02 +0000604 cp $(obj)board/freescale/m52277evb/u-boot.spa $(obj)board/freescale/m52277evb/u-boot.lds ; \
TsiChung Liewa21d0c22008-10-21 15:37:02 +0000605 fi; \
606 if [ "$${FLASH}" = "STMICRO" ] ; then \
607 echo "#define CONFIG_CF_SBF" >> $(obj)include/config.h ; \
608 echo "#define CONFIG_SYS_STMICRO_BOOT" >> $(obj)include/config.h ; \
Wolfgang Denk14d0a022010-10-07 21:51:12 +0200609 echo "CONFIG_SYS_TEXT_BASE = 0x43E00000" > $(obj)board/freescale/m52277evb/config.tmp ; \
TsiChung Liewa21d0c22008-10-21 15:37:02 +0000610 cp $(obj)board/freescale/m52277evb/u-boot.stm $(obj)board/freescale/m52277evb/u-boot.lds ; \
TsiChung Liewa21d0c22008-10-21 15:37:02 +0000611 fi
Wolfgang Denk0e42ada2010-05-27 23:18:33 +0200612 @$(MKCONFIG) -n $@ -a M52277EVB m68k mcf5227x m52277evb freescale
TsiChungLiew1552af72008-01-14 17:43:33 -0600613
TsiChungLiew4a442d32007-08-16 19:23:50 -0500614M5235EVB_config \
615M5235EVB_Flash16_config \
616M5235EVB_Flash32_config: unconfig
617 @case "$@" in \
618 M5235EVB_config) FLASH=16;; \
619 M5235EVB_Flash16_config) FLASH=16;; \
620 M5235EVB_Flash32_config) FLASH=32;; \
621 esac; \
TsiChungLiew4a442d32007-08-16 19:23:50 -0500622 if [ "$${FLASH}" != "16" ] ; then \
Wolfgang Denkae6d1052008-01-13 00:59:21 +0100623 echo "#define NORFLASH_PS32BIT 1" >> $(obj)include/config.h ; \
Wolfgang Denk14d0a022010-10-07 21:51:12 +0200624 echo "CONFIG_SYS_TEXT_BASE = 0xFFC00000" > $(obj)board/freescale/m5235evb/config.tmp ; \
TsiChungLiew4a442d32007-08-16 19:23:50 -0500625 cp $(obj)board/freescale/m5235evb/u-boot.32 $(obj)board/freescale/m5235evb/u-boot.lds ; \
626 else \
Wolfgang Denk14d0a022010-10-07 21:51:12 +0200627 echo "CONFIG_SYS_TEXT_BASE = 0xFFE00000" > $(obj)board/freescale/m5235evb/config.tmp ; \
TsiChungLiew4a442d32007-08-16 19:23:50 -0500628 cp $(obj)board/freescale/m5235evb/u-boot.16 $(obj)board/freescale/m5235evb/u-boot.lds ; \
629 fi
Wolfgang Denk0e42ada2010-05-27 23:18:33 +0200630 @$(MKCONFIG) -n $@ -a M5235EVB m68k mcf523x m5235evb freescale
TsiChungLiew4a442d32007-08-16 19:23:50 -0500631
Wolfgang Denk74812662005-12-12 16:06:05 +0100632cobra5272_config : unconfig
Wolfgang Denked7a1962010-05-27 23:18:34 +0200633 @$(MKCONFIG) $@ m68k mcf52x2 cobra5272
Wolfgang Denk74812662005-12-12 16:06:05 +0100634
Wolfgang Denk4176c792006-06-10 19:27:47 +0200635EB+MCF-EV123_config : unconfig
Marian Balakowiczf9328632006-09-01 19:49:50 +0200636 @mkdir -p $(obj)include
637 @mkdir -p $(obj)board/BuS/EB+MCF-EV123
Wolfgang Denk14d0a022010-10-07 21:51:12 +0200638 @echo "CONFIG_SYS_TEXT_BASE = 0xFFE00000"|tee $(obj)board/BuS/EB+MCF-EV123/textbase.mk
Wolfgang Denk0e42ada2010-05-27 23:18:33 +0200639 @$(MKCONFIG) -n $@ EB+MCF-EV123 m68k mcf52x2 EB+MCF-EV123 BuS
Wolfgang Denk4176c792006-06-10 19:27:47 +0200640
641EB+MCF-EV123_internal_config : unconfig
Marian Balakowiczf9328632006-09-01 19:49:50 +0200642 @mkdir -p $(obj)include
643 @mkdir -p $(obj)board/BuS/EB+MCF-EV123
Wolfgang Denk14d0a022010-10-07 21:51:12 +0200644 @echo "CONFIG_SYS_TEXT_BASE = 0xF0000000"|tee $(obj)board/BuS/EB+MCF-EV123/textbase.mk
Wolfgang Denk0e42ada2010-05-27 23:18:33 +0200645 @$(MKCONFIG) -n $@ EB+MCF-EV123 m68k mcf52x2 EB+MCF-EV123 BuS
Wolfgang Denk4176c792006-06-10 19:27:47 +0200646
TsiChung Liew8e585f02007-06-18 13:50:13 -0500647M5329AFEE_config \
648M5329BFEE_config : unconfig
649 @case "$@" in \
650 M5329AFEE_config) NAND=0;; \
651 M5329BFEE_config) NAND=16;; \
652 esac; \
TsiChung Liew8e585f02007-06-18 13:50:13 -0500653 if [ "$${NAND}" != "0" ] ; then \
TsiChungLiewab77bc52007-08-15 15:39:17 -0500654 echo "#define NANDFLASH_SIZE $${NAND}" > $(obj)include/config.h ; \
TsiChung Liew8e585f02007-06-18 13:50:13 -0500655 fi
Wolfgang Denk0e42ada2010-05-27 23:18:33 +0200656 @$(MKCONFIG) -n $@ -a M5329EVB m68k mcf532x m5329evb freescale
TsiChung Liew8e585f02007-06-18 13:50:13 -0500657
TsiChungLiewaa5f1f92008-01-14 17:23:08 -0600658M5373EVB_config : unconfig
659 @case "$@" in \
660 M5373EVB_config) NAND=16;; \
661 esac; \
TsiChungLiewaa5f1f92008-01-14 17:23:08 -0600662 if [ "$${NAND}" != "0" ] ; then \
663 echo "#define NANDFLASH_SIZE $${NAND}" > $(obj)include/config.h ; \
664 fi
665 @$(MKCONFIG) -a M5373EVB m68k mcf532x m5373evb freescale
666
TsiChung Liew05316f82008-08-11 13:41:49 +0000667M54451EVB_config \
TsiChung Liew05316f82008-08-11 13:41:49 +0000668M54451EVB_stmicro_config : unconfig
669 @case "$@" in \
TsiChung Liew709b3842009-06-11 15:39:57 +0000670 M54451EVB_config) FLASH=NOR;; \
TsiChung Liew05316f82008-08-11 13:41:49 +0000671 M54451EVB_stmicro_config) FLASH=STMICRO;; \
672 esac; \
TsiChung Liew709b3842009-06-11 15:39:57 +0000673 if [ "$${FLASH}" = "NOR" ] ; then \
Wolfgang Denk14d0a022010-10-07 21:51:12 +0200674 echo "CONFIG_SYS_TEXT_BASE = 0x00000000" > $(obj)board/freescale/m54451evb/config.tmp ; \
TsiChung Liew05316f82008-08-11 13:41:49 +0000675 cp $(obj)board/freescale/m54451evb/u-boot.spa $(obj)board/freescale/m54451evb/u-boot.lds ; \
TsiChung Liew05316f82008-08-11 13:41:49 +0000676 fi; \
677 if [ "$${FLASH}" = "STMICRO" ] ; then \
678 echo "#define CONFIG_CF_SBF" >> $(obj)include/config.h ; \
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200679 echo "#define CONFIG_SYS_STMICRO_BOOT" >> $(obj)include/config.h ; \
Wolfgang Denk14d0a022010-10-07 21:51:12 +0200680 echo "CONFIG_SYS_TEXT_BASE = 0x47E00000" > $(obj)board/freescale/m54451evb/config.tmp ; \
TsiChung Liew05316f82008-08-11 13:41:49 +0000681 cp $(obj)board/freescale/m54451evb/u-boot.stm $(obj)board/freescale/m54451evb/u-boot.lds ; \
TsiChung Liew05316f82008-08-11 13:41:49 +0000682 fi; \
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200683 echo "#define CONFIG_SYS_INPUT_CLKSRC 24000000" >> $(obj)include/config.h ;
Wolfgang Denk0e42ada2010-05-27 23:18:33 +0200684 @$(MKCONFIG) -n $@ -a M54451EVB m68k mcf5445x m54451evb freescale
TsiChung Liew05316f82008-08-11 13:41:49 +0000685
TsiChungLiew8ae158c2007-08-16 15:05:11 -0500686M54455EVB_config \
687M54455EVB_atmel_config \
688M54455EVB_intel_config \
689M54455EVB_a33_config \
690M54455EVB_a66_config \
691M54455EVB_i33_config \
TsiChung Liew9f751552008-07-23 20:38:53 -0500692M54455EVB_i66_config \
693M54455EVB_stm33_config : unconfig
TsiChungLiew8ae158c2007-08-16 15:05:11 -0500694 @case "$@" in \
695 M54455EVB_config) FLASH=ATMEL; FREQ=33333333;; \
696 M54455EVB_atmel_config) FLASH=ATMEL; FREQ=33333333;; \
697 M54455EVB_intel_config) FLASH=INTEL; FREQ=33333333;; \
698 M54455EVB_a33_config) FLASH=ATMEL; FREQ=33333333;; \
699 M54455EVB_a66_config) FLASH=ATMEL; FREQ=66666666;; \
700 M54455EVB_i33_config) FLASH=INTEL; FREQ=33333333;; \
701 M54455EVB_i66_config) FLASH=INTEL; FREQ=66666666;; \
TsiChung Liew9f751552008-07-23 20:38:53 -0500702 M54455EVB_stm33_config) FLASH=STMICRO; FREQ=33333333;; \
TsiChungLiew8ae158c2007-08-16 15:05:11 -0500703 esac; \
Wolfgang Denk1aaab9b2008-01-02 15:54:45 +0100704 if [ "$${FLASH}" = "INTEL" ] ; then \
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200705 echo "#define CONFIG_SYS_INTEL_BOOT" >> $(obj)include/config.h ; \
Wolfgang Denk14d0a022010-10-07 21:51:12 +0200706 echo "CONFIG_SYS_TEXT_BASE = 0x00000000" > $(obj)board/freescale/m54455evb/config.tmp ; \
TsiChungLiewe8ee8f32007-10-25 17:16:22 -0500707 cp $(obj)board/freescale/m54455evb/u-boot.int $(obj)board/freescale/m54455evb/u-boot.lds ; \
TsiChung Liew9f751552008-07-23 20:38:53 -0500708 fi; \
709 if [ "$${FLASH}" = "ATMEL" ] ; then \
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200710 echo "#define CONFIG_SYS_ATMEL_BOOT" >> $(obj)include/config.h ; \
Wolfgang Denk14d0a022010-10-07 21:51:12 +0200711 echo "CONFIG_SYS_TEXT_BASE = 0x04000000" > $(obj)board/freescale/m54455evb/config.tmp ; \
TsiChungLiewe8ee8f32007-10-25 17:16:22 -0500712 cp $(obj)board/freescale/m54455evb/u-boot.atm $(obj)board/freescale/m54455evb/u-boot.lds ; \
TsiChungLiew8ae158c2007-08-16 15:05:11 -0500713 fi; \
TsiChung Liew9f751552008-07-23 20:38:53 -0500714 if [ "$${FLASH}" = "STMICRO" ] ; then \
715 echo "#define CONFIG_CF_SBF" >> $(obj)include/config.h ; \
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200716 echo "#define CONFIG_SYS_STMICRO_BOOT" >> $(obj)include/config.h ; \
Wolfgang Denk14d0a022010-10-07 21:51:12 +0200717 echo "CONFIG_SYS_TEXT_BASE = 0x4FE00000" > $(obj)board/freescale/m54455evb/config.tmp ; \
TsiChung Liew9f751552008-07-23 20:38:53 -0500718 cp $(obj)board/freescale/m54455evb/u-boot.stm $(obj)board/freescale/m54455evb/u-boot.lds ; \
TsiChung Liew9f751552008-07-23 20:38:53 -0500719 fi; \
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200720 echo "#define CONFIG_SYS_INPUT_CLKSRC $${FREQ}" >> $(obj)include/config.h ; \
Wolfgang Denk0e42ada2010-05-27 23:18:33 +0200721 @$(MKCONFIG) -n $@ -a M54455EVB m68k mcf5445x m54455evb freescale
TsiChungLiew8ae158c2007-08-16 15:05:11 -0500722
TsiChungLiew57a12722008-01-15 14:15:46 -0600723M5475AFE_config \
724M5475BFE_config \
725M5475CFE_config \
726M5475DFE_config \
727M5475EFE_config \
728M5475FFE_config \
729M5475GFE_config : unconfig
730 @case "$@" in \
731 M5475AFE_config) BOOT=2;CODE=0;VID=0;USB=0;RAM=64;RAM1=0;; \
732 M5475BFE_config) BOOT=2;CODE=16;VID=0;USB=0;RAM=64;RAM1=0;; \
733 M5475CFE_config) BOOT=2;CODE=16;VID=1;USB=1;RAM=64;RAM1=0;; \
734 M5475DFE_config) BOOT=2;CODE=0;VID=0;USB=1;RAM=64;RAM1=0;; \
735 M5475EFE_config) BOOT=2;CODE=0;VID=1;USB=1;RAM=64;RAM1=0;; \
736 M5475FFE_config) BOOT=2;CODE=32;VID=1;USB=1;RAM=64;RAM1=64;; \
737 M5475GFE_config) BOOT=4;CODE=0;VID=0;USB=0;RAM=64;RAM1=0;; \
738 esac; \
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200739 echo "#define CONFIG_SYS_BUSCLK 133333333" > $(obj)include/config.h ; \
740 echo "#define CONFIG_SYS_BOOTSZ $${BOOT}" >> $(obj)include/config.h ; \
741 echo "#define CONFIG_SYS_DRAMSZ $${RAM}" >> $(obj)include/config.h ; \
TsiChungLiew57a12722008-01-15 14:15:46 -0600742 if [ "$${RAM1}" != "0" ] ; then \
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200743 echo "#define CONFIG_SYS_DRAMSZ1 $${RAM1}" >> $(obj)include/config.h ; \
TsiChungLiew57a12722008-01-15 14:15:46 -0600744 fi; \
745 if [ "$${CODE}" != "0" ] ; then \
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200746 echo "#define CONFIG_SYS_NOR1SZ $${CODE}" >> $(obj)include/config.h ; \
TsiChungLiew57a12722008-01-15 14:15:46 -0600747 fi; \
748 if [ "$${VID}" == "1" ] ; then \
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200749 echo "#define CONFIG_SYS_VIDEO" >> $(obj)include/config.h ; \
TsiChungLiew57a12722008-01-15 14:15:46 -0600750 fi; \
751 if [ "$${USB}" == "1" ] ; then \
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200752 echo "#define CONFIG_SYS_USBCTRL" >> $(obj)include/config.h ; \
TsiChungLiew57a12722008-01-15 14:15:46 -0600753 fi
Wolfgang Denk0e42ada2010-05-27 23:18:33 +0200754 @$(MKCONFIG) -n $@ -a M5475EVB m68k mcf547x_8x m547xevb freescale
TsiChungLiew57a12722008-01-15 14:15:46 -0600755
756M5485AFE_config \
757M5485BFE_config \
758M5485CFE_config \
759M5485DFE_config \
760M5485EFE_config \
761M5485FFE_config \
762M5485GFE_config \
763M5485HFE_config : unconfig
764 @case "$@" in \
765 M5485AFE_config) BOOT=2;CODE=0;VID=0;USB=0;RAM=64;RAM1=0;; \
766 M5485BFE_config) BOOT=2;CODE=16;VID=0;USB=0;RAM=64;RAM1=0;; \
767 M5485CFE_config) BOOT=2;CODE=16;VID=1;USB=1;RAM=64;RAM1=0;; \
768 M5485DFE_config) BOOT=2;CODE=0;VID=0;USB=1;RAM=64;RAM1=0;; \
769 M5485EFE_config) BOOT=2;CODE=0;VID=1;USB=1;RAM=64;RAM1=0;; \
770 M5485FFE_config) BOOT=2;CODE=32;VID=1;USB=1;RAM=64;RAM1=64;; \
771 M5485GFE_config) BOOT=4;CODE=0;VID=0;USB=0;RAM=64;RAM1=0;; \
TsiChungLiew4d264ef2008-01-30 15:08:15 -0600772 M5485HFE_config) BOOT=2;CODE=16;VID=1;USB=0;RAM=64;RAM1=0;; \
TsiChungLiew57a12722008-01-15 14:15:46 -0600773 esac; \
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200774 echo "#define CONFIG_SYS_BUSCLK 100000000" > $(obj)include/config.h ; \
775 echo "#define CONFIG_SYS_BOOTSZ $${BOOT}" >> $(obj)include/config.h ; \
776 echo "#define CONFIG_SYS_DRAMSZ $${RAM}" >> $(obj)include/config.h ; \
TsiChungLiew57a12722008-01-15 14:15:46 -0600777 if [ "$${RAM1}" != "0" ] ; then \
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200778 echo "#define CONFIG_SYS_DRAMSZ1 $${RAM1}" >> $(obj)include/config.h ; \
TsiChungLiew57a12722008-01-15 14:15:46 -0600779 fi; \
780 if [ "$${CODE}" != "0" ] ; then \
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200781 echo "#define CONFIG_SYS_NOR1SZ $${CODE}" >> $(obj)include/config.h ; \
TsiChungLiew57a12722008-01-15 14:15:46 -0600782 fi; \
783 if [ "$${VID}" == "1" ] ; then \
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200784 echo "#define CONFIG_SYS_VIDEO" >> $(obj)include/config.h ; \
TsiChungLiew57a12722008-01-15 14:15:46 -0600785 fi; \
786 if [ "$${USB}" == "1" ] ; then \
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200787 echo "#define CONFIG_SYS_USBCTRL" >> $(obj)include/config.h ; \
TsiChungLiew57a12722008-01-15 14:15:46 -0600788 fi
Wolfgang Denk0e42ada2010-05-27 23:18:33 +0200789 @$(MKCONFIG) -n $@ -a M5485EVB m68k mcf547x_8x m548xevb freescale
TsiChungLiew57a12722008-01-15 14:15:46 -0600790
wdenk7ebf7442002-11-02 23:17:16 +0000791#========================================================================
792# ARM
793#========================================================================
Po-Yu Chuang43a5f0d2009-11-11 17:27:30 +0800794
Ulf Samuelssona4b46ed2008-04-12 20:56:03 +0200795#########################################################################
Matthias Weisser34be1062010-01-18 10:58:13 +0100796## ARM926EJ-S Systems
Ulf Samuelssona4b46ed2008-04-12 20:56:03 +0200797#########################################################################
798
Nicolas Ferre89a7a872008-12-06 13:11:14 +0100799at91sam9261ek_nandflash_config \
800at91sam9261ek_dataflash_cs0_config \
801at91sam9261ek_dataflash_cs3_config \
Sedji Gaouaou5ccc2d92009-06-25 17:04:15 +0200802at91sam9261ek_config \
803at91sam9g10ek_nandflash_config \
804at91sam9g10ek_dataflash_cs0_config \
805at91sam9g10ek_dataflash_cs3_config \
806at91sam9g10ek_config : unconfig
Jean-Christophe PLAGNIOL-VILLARDe12d9a82009-01-03 17:22:24 +0100807 @mkdir -p $(obj)include
Sedji Gaouaou5ccc2d92009-06-25 17:04:15 +0200808 @if [ "$(findstring 9g10,$@)" ] ; then \
809 echo "#define CONFIG_AT91SAM9G10EK 1" >>$(obj)include/config.h ; \
Sedji Gaouaou5ccc2d92009-06-25 17:04:15 +0200810 else \
811 echo "#define CONFIG_AT91SAM9261EK 1" >>$(obj)include/config.h ; \
812 fi;
Nicolas Ferre89a7a872008-12-06 13:11:14 +0100813 @if [ "$(findstring _nandflash,$@)" ] ; then \
814 echo "#define CONFIG_SYS_USE_NANDFLASH 1" >>$(obj)include/config.h ; \
Sedji Gaouaou5ccc2d92009-06-25 17:04:15 +0200815 elif [ "$(findstring dataflash_cs0,$@)" ] ; then \
Nicolas Ferre89a7a872008-12-06 13:11:14 +0100816 echo "#define CONFIG_SYS_USE_DATAFLASH_CS3 1" >>$(obj)include/config.h ; \
Nicolas Ferre89a7a872008-12-06 13:11:14 +0100817 else \
818 echo "#define CONFIG_SYS_USE_DATAFLASH_CS0 1" >>$(obj)include/config.h ; \
Nicolas Ferre89a7a872008-12-06 13:11:14 +0100819 fi;
Wolfgang Denk0e42ada2010-05-27 23:18:33 +0200820 @$(MKCONFIG) -n $@ -a at91sam9261ek arm arm926ejs at91sam9261ek atmel at91
Jean-Christophe PLAGNIOL-VILLARD28962f52008-11-01 10:47:59 +0100821
Jean-Christophe PLAGNIOL-VILLARD1b3b7c62009-06-13 12:48:36 +0200822at91sam9263ek_norflash_config \
823at91sam9263ek_norflash_boot_config \
Nicolas Ferre89a7a872008-12-06 13:11:14 +0100824at91sam9263ek_nandflash_config \
825at91sam9263ek_dataflash_config \
826at91sam9263ek_dataflash_cs0_config \
Jean-Christophe PLAGNIOL-VILLARD28962f52008-11-01 10:47:59 +0100827at91sam9263ek_config : unconfig
Jean-Christophe PLAGNIOL-VILLARDe12d9a82009-01-03 17:22:24 +0100828 @mkdir -p $(obj)include
Nicolas Ferre89a7a872008-12-06 13:11:14 +0100829 @if [ "$(findstring _nandflash,$@)" ] ; then \
830 echo "#define CONFIG_SYS_USE_NANDFLASH 1" >>$(obj)include/config.h ; \
Jean-Christophe PLAGNIOL-VILLARD1b3b7c62009-06-13 12:48:36 +0200831 elif [ "$(findstring norflash,$@)" ] ; then \
832 echo "#define CONFIG_SYS_USE_NORFLASH 1" >>$(obj)include/config.h ; \
Nicolas Ferre89a7a872008-12-06 13:11:14 +0100833 else \
834 echo "#define CONFIG_SYS_USE_DATAFLASH 1" >>$(obj)include/config.h ; \
Nicolas Ferre89a7a872008-12-06 13:11:14 +0100835 fi;
Jean-Christophe PLAGNIOL-VILLARD1b3b7c62009-06-13 12:48:36 +0200836 @if [ "$(findstring norflash_boot,$@)" ] ; then \
837 echo "#define CONFIG_SYS_USE_BOOT_NORFLASH 1" >>$(obj)include/config.h ; \
Jean-Christophe PLAGNIOL-VILLARD1b3b7c62009-06-13 12:48:36 +0200838 fi;
Wolfgang Denk0e42ada2010-05-27 23:18:33 +0200839 @$(MKCONFIG) -n $@ -a at91sam9263ek arm arm926ejs at91sam9263ek atmel at91
Jean-Christophe PLAGNIOL-VILLARD28962f52008-11-01 10:47:59 +0100840
Nicolas Ferre89a7a872008-12-06 13:11:14 +0100841at91sam9rlek_nandflash_config \
842at91sam9rlek_dataflash_config \
843at91sam9rlek_dataflash_cs0_config \
Jean-Christophe PLAGNIOL-VILLARD28962f52008-11-01 10:47:59 +0100844at91sam9rlek_config : unconfig
Jean-Christophe PLAGNIOL-VILLARDe12d9a82009-01-03 17:22:24 +0100845 @mkdir -p $(obj)include
Nicolas Ferre89a7a872008-12-06 13:11:14 +0100846 @if [ "$(findstring _nandflash,$@)" ] ; then \
847 echo "#define CONFIG_SYS_USE_NANDFLASH 1" >>$(obj)include/config.h ; \
Nicolas Ferre89a7a872008-12-06 13:11:14 +0100848 else \
849 echo "#define CONFIG_SYS_USE_DATAFLASH 1" >>$(obj)include/config.h ; \
Nicolas Ferre89a7a872008-12-06 13:11:14 +0100850 fi;
Wolfgang Denk0e42ada2010-05-27 23:18:33 +0200851 @$(MKCONFIG) -n $@ -a at91sam9rlek arm arm926ejs at91sam9rlek atmel at91
Jean-Christophe PLAGNIOL-VILLARD28962f52008-11-01 10:47:59 +0100852
Sedji Gaouaou22ee6472009-07-09 10:16:29 +0200853at91sam9m10g45ek_nandflash_config \
854at91sam9m10g45ek_dataflash_config \
855at91sam9m10g45ek_dataflash_cs0_config \
856at91sam9m10g45ek_config \
857at91sam9g45ekes_nandflash_config \
858at91sam9g45ekes_dataflash_config \
859at91sam9g45ekes_dataflash_cs0_config \
860at91sam9g45ekes_config : unconfig
861 @mkdir -p $(obj)include
862 @if [ "$(findstring 9m10,$@)" ] ; then \
863 echo "#define CONFIG_AT91SAM9M10G45EK 1" >>$(obj)include/config.h ; \
Sedji Gaouaou22ee6472009-07-09 10:16:29 +0200864 else \
865 echo "#define CONFIG_AT91SAM9G45EKES 1" >>$(obj)include/config.h ; \
866 fi;
Sedji Gaouaou22ee6472009-07-09 10:16:29 +0200867 @if [ "$(findstring _nandflash,$@)" ] ; then \
868 echo "#define CONFIG_SYS_USE_NANDFLASH 1" >>$(obj)include/config.h ; \
Sedji Gaouaou22ee6472009-07-09 10:16:29 +0200869 else \
870 echo "#define CONFIG_ATMEL_SPI 1" >>$(obj)include/config.h ; \
Sedji Gaouaou22ee6472009-07-09 10:16:29 +0200871 fi;
Wolfgang Denk0e42ada2010-05-27 23:18:33 +0200872 @$(MKCONFIG) -n $@ -a at91sam9m10g45ek arm arm926ejs at91sam9m10g45ek atmel at91
Sedji Gaouaou22ee6472009-07-09 10:16:29 +0200873
Asen Dimovb5d289f2010-04-20 22:49:04 +0300874pm9g45_config : unconfig
875 @mkdir -p $(obj)include
876 @$(MKCONFIG) -a pm9g45 arm arm926ejs pm9g45 ronetix at91
877
Albin Tonnerre94539672009-08-24 18:03:26 +0200878SBC35_A9G20_NANDFLASH_config \
879SBC35_A9G20_EEPROM_config \
880SBC35_A9G20_config : unconfig
881 @mkdir -p $(obj)include
882 @echo "#define CONFIG_$(@:_config=) 1" >$(obj)include/config.h
Wolfgang Denk0e42ada2010-05-27 23:18:33 +0200883 @$(MKCONFIG) -n $@ -a sbc35_a9g20 arm arm926ejs sbc35_a9g20 calao at91
Albin Tonnerre94539672009-08-24 18:03:26 +0200884
Albin Tonnerre2dc851e2009-08-20 16:04:49 +0200885TNY_A9G20_NANDFLASH_config \
886TNY_A9G20_EEPROM_config \
887TNY_A9G20_config \
888TNY_A9260_NANDFLASH_config \
889TNY_A9260_EEPROM_config \
890TNY_A9260_config : unconfig
891 @mkdir -p $(obj)include
892 @echo "#define CONFIG_$(@:_config=) 1" >$(obj)include/config.h
Wolfgang Denk0e42ada2010-05-27 23:18:33 +0200893 @$(MKCONFIG) -n $@ -a tny_a9260 arm arm926ejs tny_a9260 calao at91
Albin Tonnerre2dc851e2009-08-20 16:04:49 +0200894
Wolfgang Denk74f43042005-09-25 01:48:28 +0200895########################################################################
Wolfgang Denk87cb6862005-10-06 17:08:18 +0200896## ARM Integrator boards - see doc/README-integrator for more info.
897integratorap_config \
898ap_config \
899ap966_config \
900ap922_config \
901ap922_XA10_config \
902ap7_config \
Wolfgang Denkdd520bf2006-11-30 18:02:20 +0100903ap720t_config \
Wolfgang Denk87cb6862005-10-06 17:08:18 +0200904ap920t_config \
905ap926ejs_config \
906ap946es_config: unconfig
Jean-Christophe PLAGNIOL-VILLARD576afd42009-05-17 00:58:37 +0200907 @board/armltd/integrator/split_by_variant.sh ap $@
wdenk3d3befa2004-03-14 15:06:13 +0000908
Wolfgang Denk87cb6862005-10-06 17:08:18 +0200909integratorcp_config \
910cp_config \
911cp920t_config \
912cp926ejs_config \
913cp946es_config \
914cp1136_config \
915cp966_config \
916cp922_config \
917cp922_XA10_config \
918cp1026_config: unconfig
Jean-Christophe PLAGNIOL-VILLARD576afd42009-05-17 00:58:37 +0200919 @board/armltd/integrator/split_by_variant.sh cp $@
wdenk25d67122004-12-10 11:40:40 +0000920
Ulf Samuelssona4b46ed2008-04-12 20:56:03 +0200921xtract_omap1610xxx = $(subst _cs0boot,,$(subst _cs3boot,,$(subst _cs_autoboot,,$(subst _config,,$1))))
922
wdenk63e73c92004-02-23 22:22:28 +0000923omap1610inn_config \
924omap1610inn_cs0boot_config \
925omap1610inn_cs3boot_config \
wdenk3ff02c22004-06-09 15:25:53 +0000926omap1610inn_cs_autoboot_config \
wdenk63e73c92004-02-23 22:22:28 +0000927omap1610h2_config \
928omap1610h2_cs0boot_config \
wdenk3ff02c22004-06-09 15:25:53 +0000929omap1610h2_cs3boot_config \
930omap1610h2_cs_autoboot_config: unconfig
Marian Balakowiczf9328632006-09-01 19:49:50 +0200931 @mkdir -p $(obj)include
wdenk63e73c92004-02-23 22:22:28 +0000932 @if [ "$(findstring _cs0boot_, $@)" ] ; then \
Wolfgang Denkcdd917a2007-08-02 00:48:45 +0200933 echo "#define CONFIG_CS0_BOOT" >> .$(obj)include/config.h ; \
wdenk3ff02c22004-06-09 15:25:53 +0000934 elif [ "$(findstring _cs_autoboot_, $@)" ] ; then \
Wolfgang Denkcdd917a2007-08-02 00:48:45 +0200935 echo "#define CONFIG_CS_AUTOBOOT" >> $(obj)include/config.h ; \
wdenk63e73c92004-02-23 22:22:28 +0000936 else \
Wolfgang Denkcdd917a2007-08-02 00:48:45 +0200937 echo "#define CONFIG_CS3_BOOT" >> $(obj)include/config.h ; \
wdenk63e73c92004-02-23 22:22:28 +0000938 fi;
Wolfgang Denk0e42ada2010-05-27 23:18:33 +0200939 @$(MKCONFIG) -n $@ -a $(call xtract_omap1610xxx,$@) arm arm926ejs omap1610inn ti omap
wdenk6f213472003-08-29 22:00:43 +0000940
wdenka56bd922004-06-06 23:13:55 +0000941omap730p2_config \
942omap730p2_cs0boot_config \
943omap730p2_cs3boot_config : unconfig
Marian Balakowiczf9328632006-09-01 19:49:50 +0200944 @mkdir -p $(obj)include
wdenka56bd922004-06-06 23:13:55 +0000945 @if [ "$(findstring _cs0boot_, $@)" ] ; then \
Marian Balakowiczf9328632006-09-01 19:49:50 +0200946 echo "#define CONFIG_CS0_BOOT" >> $(obj)include/config.h ; \
wdenka56bd922004-06-06 23:13:55 +0000947 else \
Marian Balakowiczf9328632006-09-01 19:49:50 +0200948 echo "#define CONFIG_CS3_BOOT" >> $(obj)include/config.h ; \
wdenka56bd922004-06-06 23:13:55 +0000949 fi;
Wolfgang Denked7a1962010-05-27 23:18:34 +0200950 @$(MKCONFIG) -n $@ -a omap730p2 arm arm926ejs omap730p2 ti omap
wdenka56bd922004-06-06 23:13:55 +0000951
Vipin KUMAR080cfee2010-01-15 19:15:52 +0530952spear300_config \
Vipin KUMAR7da69232010-01-15 19:15:53 +0530953spear310_config \
954spear320_config : unconfig
Wolfgang Denked7a1962010-05-27 23:18:34 +0200955 @$(MKCONFIG) -n $@ -t $@ spear3xx arm arm926ejs $(@:_config=) spear spear
Vipin KUMAR7e074152010-01-15 19:15:50 +0530956
Vipin KUMAR566c9c12010-01-15 19:15:48 +0530957spear600_config : unconfig
Wolfgang Denked7a1962010-05-27 23:18:34 +0200958 @$(MKCONFIG) -n $@ -t $@ spear6xx arm arm926ejs $(@:_config=) spear spear
Vipin KUMAR566c9c12010-01-15 19:15:48 +0530959
Jean-Christophe PLAGNIOL-VILLARD47fd3bf2009-01-28 21:58:03 +0100960SX1_stdout_serial_config \
961SX1_config: unconfig
962 @mkdir -p $(obj)include
963 @if [ "$(findstring _stdout_serial_, $@)" ] ; then \
964 echo "#undef CONFIG_STDOUT_USBTTY" >> $(obj)include/config.h ; \
Jean-Christophe PLAGNIOL-VILLARD47fd3bf2009-01-28 21:58:03 +0100965 else \
966 echo "#define CONFIG_STDOUT_USBTTY" >> $(obj)include/config.h ; \
Jean-Christophe PLAGNIOL-VILLARD47fd3bf2009-01-28 21:58:03 +0100967 fi;
Wolfgang Denk0e42ada2010-05-27 23:18:33 +0200968 @$(MKCONFIG) -n $@ SX1 arm arm925t sx1
wdenk2d24a3a2004-06-09 21:50:45 +0000969
John Rigby6895d452010-01-25 23:12:58 -0700970tx25_config : unconfig
John Rigby6895d452010-01-25 23:12:58 -0700971 @echo "CONFIG_NAND_U_BOOT = y" >> $(obj)include/config.mk
Wolfgang Denked7a1962010-05-27 23:18:34 +0200972 @$(MKCONFIG) $@ arm arm926ejs tx25 karo mx25
John Rigby6895d452010-01-25 23:12:58 -0700973
Wolfgang Denka6862bc2010-05-27 23:18:36 +0200974edb9301_config \
975edb9302_config \
976edb9302a_config \
977edb9307_config \
978edb9307a_config \
979edb9312_config \
980edb9315_config \
981edb9315a_config: unconfig
982 @$(MKCONFIG) -n $@ -t $(@:_config=) edb93xx arm arm920t edb93xx - ep93xx
983
Wolfgang Denk699f0512008-07-15 22:22:44 +0200984#########################################################################
Wolfgang Denk87cb6862005-10-06 17:08:18 +0200985# ARM supplied Versatile development boards
Wolfgang Denk699f0512008-07-15 22:22:44 +0200986#########################################################################
987
Wolfgang Denk87cb6862005-10-06 17:08:18 +0200988versatile_config \
989versatileab_config \
990versatilepb_config : unconfig
Jean-Christophe PLAGNIOL-VILLARDe4943ec2009-01-29 12:07:21 +0100991 @board/armltd/versatile/split_by_variant.sh $@
wdenk074cff02004-02-24 00:16:43 +0000992
993#########################################################################
wdenk43d96162003-03-06 00:02:04 +0000994## XScale Systems
wdenk7ebf7442002-11-02 23:17:16 +0000995#########################################################################
996
Stefan Roese9d8d5a52007-01-18 16:05:47 +0100997pdnb3_config \
Wolfgang Denkf9301e12008-03-04 14:58:31 +0100998scpu_config: unconfig
Wolfgang Denkcdd917a2007-08-02 00:48:45 +0200999 @mkdir -p $(obj)include
Stefan Roese9d8d5a52007-01-18 16:05:47 +01001000 @if [ "$(findstring scpu_,$@)" ] ; then \
Wolfgang Denkf9301e12008-03-04 14:58:31 +01001001 echo "#define CONFIG_SCPU" >>$(obj)include/config.h ; \
Stefan Roese9d8d5a52007-01-18 16:05:47 +01001002 fi
Wolfgang Denk0e42ada2010-05-27 23:18:33 +02001003 @$(MKCONFIG) -n $@ -a pdnb3 arm ixp pdnb3 prodrive
Wolfgang Denkba94a1b2006-05-30 15:56:48 +02001004
wdenk8ed96042005-01-09 23:16:25 +00001005#########################################################################
1006## ARM1136 Systems
1007#########################################################################
wdenk8ed96042005-01-09 23:16:25 +00001008
Peter Pearse5ca98812007-11-09 15:24:26 +00001009apollon_config : unconfig
Wolfgang Denk8cbf4e42009-12-06 00:26:19 +01001010 @mkdir -p $(obj)include
Kyungmin Park751b9b52008-01-17 16:43:25 +09001011 @echo "#define CONFIG_ONENAND_U_BOOT" > $(obj)include/config.h
Kyungmin Park751b9b52008-01-17 16:43:25 +09001012 @echo "CONFIG_ONENAND_U_BOOT = y" >> $(obj)include/config.mk
Wolfgang Denka6862bc2010-05-27 23:18:36 +02001013 @$(MKCONFIG) $@ arm arm1136 apollon - omap24xx
Peter Pearse5ca98812007-11-09 15:24:26 +00001014
Guennadi Liakhovetskia2bb7102009-02-24 10:44:02 +01001015imx31_phycore_eet_config \
Sascha Hauer5ad86212008-03-26 20:41:17 +01001016imx31_phycore_config : unconfig
Guennadi Liakhovetski69c5bf22009-04-05 00:37:07 +02001017 @mkdir -p $(obj)include
Guennadi Liakhovetskia2bb7102009-02-24 10:44:02 +01001018 @if [ -n "$(findstring _eet_,$@)" ]; then \
1019 echo "#define CONFIG_IMX31_PHYCORE_EET" >> $(obj)include/config.h; \
1020 fi
Wolfgang Denka6862bc2010-05-27 23:18:36 +02001021 @$(MKCONFIG) -n $@ -a imx31_phycore arm arm1136 imx31_phycore - mx31
Sascha Hauer5ad86212008-03-26 20:41:17 +01001022
Magnus Liljad08e5ca2009-07-04 10:31:24 +02001023mx31pdk_config \
1024mx31pdk_nand_config : unconfig
1025 @mkdir -p $(obj)include
1026 @if [ -n "$(findstring _nand_,$@)" ]; then \
1027 echo "#define CONFIG_NAND_U_BOOT" >> $(obj)include/config.h; \
1028 else \
1029 echo "#define CONFIG_SKIP_LOWLEVEL_INIT" >> $(obj)include/config.h; \
Magnus Liljad08e5ca2009-07-04 10:31:24 +02001030 fi
Wolfgang Denk0e42ada2010-05-27 23:18:33 +02001031 @$(MKCONFIG) -n $@ -a mx31pdk arm arm1136 mx31pdk freescale mx31
Magnus Lilja8449f282009-07-01 01:07:55 +02001032
Guennadi Liakhovetski11edcfe2008-08-31 00:39:47 +02001033#########################################################################
1034## ARM1176 Systems
1035#########################################################################
1036smdk6400_noUSB_config \
1037smdk6400_config : unconfig
1038 @mkdir -p $(obj)include $(obj)board/samsung/smdk6400
1039 @mkdir -p $(obj)nand_spl/board/samsung/smdk6400
1040 @echo "#define CONFIG_NAND_U_BOOT" > $(obj)include/config.h
Wolfgang Denk0e42ada2010-05-27 23:18:33 +02001041 @echo "CONFIG_NAND_U_BOOT = y" >> $(obj)include/config.mk
Guennadi Liakhovetski11edcfe2008-08-31 00:39:47 +02001042 @if [ -z "$(findstring smdk6400_noUSB_config,$@)" ]; then \
1043 echo "RAM_TEXT = 0x57e00000" >> $(obj)board/samsung/smdk6400/config.tmp;\
Guennadi Liakhovetski11edcfe2008-08-31 00:39:47 +02001044 else \
1045 echo "RAM_TEXT = 0xc7e00000" >> $(obj)board/samsung/smdk6400/config.tmp;\
Guennadi Liakhovetski11edcfe2008-08-31 00:39:47 +02001046 fi
Wolfgang Denk54e19a72010-06-18 01:20:49 +02001047 @$(MKCONFIG) smdk6400 arm arm1176 smdk6400 samsung s3c64xx
Guennadi Liakhovetski11edcfe2008-08-31 00:39:47 +02001048 @echo "CONFIG_NAND_U_BOOT = y" >> $(obj)include/config.mk
1049
wdenk2262cfe2002-11-18 00:14:45 +00001050#========================================================================
wdenk4a551702003-10-08 23:26:14 +00001051# Nios
1052#========================================================================
wdenk4a551702003-10-08 23:26:14 +00001053
wdenk5c952cf2004-10-10 21:27:30 +00001054#########################################################################
1055## Nios-II
1056#########################################################################
1057
Thomas Chou8cbb0dd2010-04-21 08:40:59 +08001058# nios2 generic boards
1059NIOS2_GENERIC = nios2-generic
1060
1061$(NIOS2_GENERIC:%=%_config) : unconfig
Wolfgang Denked7a1962010-05-27 23:18:34 +02001062 @$(MKCONFIG) $@ nios2 nios2 nios2-generic altera
Thomas Chou8cbb0dd2010-04-21 08:40:59 +08001063
Wolfgang Denk0afe5192006-03-12 02:10:00 +01001064#########################################################################
wdenk3e386912003-04-05 00:53:31 +00001065#########################################################################
wdenk7ebf7442002-11-02 23:17:16 +00001066
1067clean:
Peter Tyser1bc15382009-07-10 11:03:19 -05001068 @rm -f $(obj)examples/standalone/82559_eeprom \
Wolfgang Denkd640ac52009-09-07 23:52:31 +02001069 $(obj)examples/standalone/atmel_df_pow2 \
Peter Tyser1bc15382009-07-10 11:03:19 -05001070 $(obj)examples/standalone/eepro100_eeprom \
1071 $(obj)examples/standalone/hello_world \
1072 $(obj)examples/standalone/interrupt \
1073 $(obj)examples/standalone/mem_to_mem_idma2intr \
1074 $(obj)examples/standalone/sched \
Mike Frysinger201a0172011-05-07 12:05:30 +00001075 $(obj)examples/standalone/smc911{11,x}_eeprom \
Peter Tyser1bc15382009-07-10 11:03:19 -05001076 $(obj)examples/standalone/test_burst \
1077 $(obj)examples/standalone/timer
Peter Tyserd4abc752009-07-20 19:02:21 -05001078 @rm -f $(obj)examples/api/demo{,.bin}
Wolfgang Denkf9301e12008-03-04 14:58:31 +01001079 @rm -f $(obj)tools/bmp_logo $(obj)tools/easylogo/easylogo \
1080 $(obj)tools/env/{fw_printenv,fw_setenv} \
1081 $(obj)tools/envcrc \
1082 $(obj)tools/gdb/{astest,gdbcont,gdbsend} \
1083 $(obj)tools/gen_eth_addr $(obj)tools/img2srec \
1084 $(obj)tools/mkimage $(obj)tools/mpc86x_clk \
1085 $(obj)tools/ncb $(obj)tools/ubsha1
1086 @rm -f $(obj)board/cray/L1/{bootscript.c,bootscript.image} \
Wolfgang Denk74c7a952010-10-16 18:24:16 +02001087 $(obj)board/matrix_vision/*/bootscript.img \
Wolfgang Denkf9301e12008-03-04 14:58:31 +01001088 $(obj)board/netstar/{eeprom,crcek,crcit,*.srec,*.bin} \
Wolfgang Denk566e5cf2011-05-01 20:44:23 +02001089 $(obj)board/voiceblue/eeprom \
Wolfgang Denk1dcb50a2009-02-22 01:17:47 +01001090 $(obj)board/armltd/{integratorap,integratorcp}/u-boot.lds \
Wolfgang Denk1aada9c2009-08-17 14:00:53 +02001091 $(obj)u-boot.lds \
Peter Tyserc6fb83d2010-04-12 22:28:13 -05001092 $(obj)arch/blackfin/cpu/bootrom-asm-offsets.[chs]
Wolfgang Denkdc7746d2008-04-20 15:39:38 -07001093 @rm -f $(obj)include/bmp_logo.h
Wolfgang Denk16a354f2010-10-26 00:08:35 +02001094 @rm -f $(obj)lib/asm-offsets.s
Wolfgang Denk1aada9c2009-08-17 14:00:53 +02001095 @rm -f $(obj)nand_spl/{u-boot.lds,u-boot-spl,u-boot-spl.map,System.map}
Kyungmin Parkca6189d2009-09-22 09:05:00 +09001096 @rm -f $(obj)onenand_ipl/onenand-{ipl,ipl.bin,ipl.map}
Chander Kashyap0d3c62e2011-05-24 20:02:57 +00001097 @rm -f $(obj)mmc_spl/{u-boot.lds,u-boot-spl,u-boot-spl.map,u-boot-spl.bin,u-boot-mmc-spl.bin}
Kyungmin Parkca6189d2009-09-22 09:05:00 +09001098 @rm -f $(ONENAND_BIN)
Wolfgang Denk1aada9c2009-08-17 14:00:53 +02001099 @rm -f $(obj)onenand_ipl/u-boot.lds
Peter Tyserd4abc752009-07-20 19:02:21 -05001100 @rm -f $(TIMESTAMP_FILE) $(VERSION_FILE)
Wolfgang Denkae6d1052008-01-13 00:59:21 +01001101 @find $(OBJTREE) -type f \
wdenk7ebf7442002-11-02 23:17:16 +00001102 \( -name 'core' -o -name '*.bak' -o -name '*~' \
Peter Tyser2b48f7d2009-03-13 18:54:26 -05001103 -o -name '*.o' -o -name '*.a' -o -name '*.exe' \) -print \
wdenk7ebf7442002-11-02 23:17:16 +00001104 | xargs rm -f
wdenk7ebf7442002-11-02 23:17:16 +00001105
1106clobber: clean
Mike Frysinger727ebd92010-08-11 18:52:36 -04001107 @find $(OBJTREE) -type f \( -name '*.depend' \
wdenk4c0d4c32004-06-09 17:34:58 +00001108 -o -name '*.srec' -o -name '*.bin' -o -name u-boot.img \) \
1109 -print0 \
1110 | xargs -0 rm -f
Li Yangffda5862008-02-29 11:46:05 +08001111 @rm -f $(OBJS) $(obj)*.bak $(obj)ctags $(obj)etags $(obj)TAGS \
Wolfgang Denk5013c092008-03-02 22:45:33 +01001112 $(obj)cscope.* $(obj)*.*~
Wolfgang Denkae6d1052008-01-13 00:59:21 +01001113 @rm -f $(obj)u-boot $(obj)u-boot.map $(obj)u-boot.hex $(ALL)
Prafulla Wadaskaraa0c7a82009-09-07 15:05:02 +05301114 @rm -f $(obj)u-boot.kwb
Stefano Babicc5fb70c2010-02-05 15:13:58 +01001115 @rm -f $(obj)u-boot.imx
Peter Tyserfb8b33c2009-03-13 18:54:47 -05001116 @rm -f $(obj)tools/{env/crc32.c,inca-swap-bytes}
Stefan Roesea47a12b2010-04-15 16:07:28 +02001117 @rm -f $(obj)arch/powerpc/cpu/mpc824x/bedbug_603e.c
Loïc Miniera9d8bc92011-01-19 13:16:29 +01001118 @rm -fr $(obj)include/asm/proc $(obj)include/asm/arch $(obj)include/asm
Wolfgang Denk16a354f2010-10-26 00:08:35 +02001119 @rm -fr $(obj)include/generated
Jean-Christophe PLAGNIOL-VILLARDa958b662008-08-16 18:54:27 +02001120 @[ ! -d $(obj)nand_spl ] || find $(obj)nand_spl -name "*" -type l -print | xargs rm -f
1121 @[ ! -d $(obj)onenand_ipl ] || find $(obj)onenand_ipl -name "*" -type l -print | xargs rm -f
Chander Kashyap0d3c62e2011-05-24 20:02:57 +00001122 @[ ! -d $(obj)mmc_spl ] || find $(obj)mmc_spl -name "*" -type l -print | xargs rm -f
wdenk7ebf7442002-11-02 23:17:16 +00001123
Marian Balakowiczf9328632006-09-01 19:49:50 +02001124ifeq ($(OBJTREE),$(SRCTREE))
wdenk7ebf7442002-11-02 23:17:16 +00001125mrproper \
1126distclean: clobber unconfig
Marian Balakowiczf9328632006-09-01 19:49:50 +02001127else
1128mrproper \
1129distclean: clobber unconfig
Wolfgang Denkae6d1052008-01-13 00:59:21 +01001130 rm -rf $(obj)*
Marian Balakowiczf9328632006-09-01 19:49:50 +02001131endif
wdenk7ebf7442002-11-02 23:17:16 +00001132
1133backup:
1134 F=`basename $(TOPDIR)` ; cd .. ; \
Ilya Yanokd6b93712010-06-21 18:13:21 +04001135 gtar --force-local -zcvf `LC_ALL=C date "+$$F-%Y-%m-%d-%T.tar.gz"` $$F
wdenk7ebf7442002-11-02 23:17:16 +00001136
1137#########################################################################