blob: ef51abcc265924d9fa83e7735aa274928309952e [file] [log] [blame]
wdenkefee1702002-07-20 20:14:13 +00001#
Marian Balakowiczd62379d2006-09-01 19:49:50 +02002# (C) Copyright 2000-2006
wdenkefee1702002-07-20 20:14:13 +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
10# published by the Free Software Foundation; either version 2 of
11# 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
15# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16# 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
wdenkefee1702002-07-20 20:14:13 +000024TOOLSUBDIRS =
Peter Tyserd0c23bf2009-03-13 18:54:45 -050025LIBFDT_DIR = $(SRCTREE)/libfdt/
wdenkefee1702002-07-20 20:14:13 +000026
27#
28# Mac OS X / Darwin's C preprocessor is Apple specific. It
29# generates numerous errors and warnings. We want to bypass it
30# and use GNU C's cpp. To do this we pass the -traditional-cpp
31# option to the compiler. Note that the -traditional-cpp flag
32# DOES NOT have the same semantics as GNU C's flag, all it does
33# is invoke the GNU preprocessor in stock ANSI/ISO C fashion.
34#
35# Apple's linker is similar, thanks to the new 2 stage linking
36# multiple symbol definitions are treated as errors, hence the
37# -multiply_defined suppress option to turn off this error.
38#
39ifeq ($(HOSTOS)-$(HOSTARCH),darwin-ppc)
wdenkefee1702002-07-20 20:14:13 +000040HOST_CFLAGS = -traditional-cpp -Wall
41HOST_LDFLAGS =-multiply_defined suppress
Aubrey.Lifecb2a02007-05-14 11:47:35 +080042HOST_ENVIRO_CFLAGS =
wdenkefee1702002-07-20 20:14:13 +000043
44else
wdenkefee1702002-07-20 20:14:13 +000045ifeq ($(HOSTOS)-$(HOSTARCH),netbsd-ppc)
46HOST_CFLAGS = -Wall -pedantic
47HOST_LDFLAGS =
48HOST_ENVIRO_CFLAGS =
49
50#
51# Everyone else
52#
53else
wdenkefee1702002-07-20 20:14:13 +000054HOST_CFLAGS = -Wall -pedantic
55HOST_LDFLAGS =
56HOST_ENVIRO_CFLAGS =
57endif
58endif
59
60#
61# Cygwin needs .exe files :-(
62#
63ifeq ($(HOSTOS),cygwin)
64SFX = .exe
raptorbrino@aim.com59f12752007-12-13 21:23:28 -050065HOST_CFLAGS += -ansi
wdenkefee1702002-07-20 20:14:13 +000066else
67SFX =
68endif
69
wdenkefee1702002-07-20 20:14:13 +000070#
71# Include this after HOSTOS HOSTARCH check
72# so that we can act intelligently.
73#
74include $(TOPDIR)/config.mk
75
Peter Tyser5b3c54d2009-03-13 18:54:34 -050076# Generated executable files
Peter Tyserf3494492009-03-13 18:54:36 -050077BIN_FILES-$(CONFIG_CMD_LOADS) += img2srec$(SFX)
Peter Tyser5b3c54d2009-03-13 18:54:34 -050078BIN_FILES-y += mkimage$(SFX)
Peter Tyser82b88f82009-03-13 18:54:39 -050079BIN_FILES-$(CONFIG_ENV_IS_EMBEDDED) += envcrc$(SFX)
Peter Tyser77b45b82009-03-13 18:54:37 -050080BIN_FILES-$(CONFIG_SHA1_CHECK_UB_IMG) += ubsha1$(SFX)
Peter Tyser39168772009-03-13 18:54:40 -050081BIN_FILES-$(CONFIG_CMD_NET) += gen_eth_addr$(SFX)
Peter Tyserce7626d2009-03-13 18:54:35 -050082BIN_FILES-$(CONFIG_LCD_LOGO) += bmp_logo$(SFX)
83BIN_FILES-$(CONFIG_VIDEO_LOGO) += bmp_logo$(SFX)
Peter Tyser7e897672009-03-13 18:54:38 -050084BIN_FILES-$(CONFIG_INCA_IP) += inca-swap-bytes$(SFX)
Peter Tyser0fa9ce32009-03-13 18:54:41 -050085BIN_FILES-$(CONFIG_NETCONSOLE) += ncb$(SFX)
Peter Tyser5b3c54d2009-03-13 18:54:34 -050086
87# Source files which are symlinked from elsewhere in U-Boot
88OBJ_LINKS-y += env_embedded.o
89OBJ_LINKS-y += crc32.o md5.o
90OBJ_LINKS-y += sha1.o
91OBJ_LINKS-y += image.o
92
93# Source files located in the tools directory
Peter Tyserf3494492009-03-13 18:54:36 -050094OBJ_FILES-$(CONFIG_CMD_LOADS) += img2srec.o
Peter Tyser5b3c54d2009-03-13 18:54:34 -050095OBJ_FILES-y += mkimage.o
Peter Tyser82b88f82009-03-13 18:54:39 -050096OBJ_FILES-$(CONFIG_ENV_IS_EMBEDDED) += envcrc.o
Peter Tyser77b45b82009-03-13 18:54:37 -050097OBJ_FILES-$(CONFIG_SHA1_CHECK_UB_IMG) += ubsha1.o
Peter Tyser39168772009-03-13 18:54:40 -050098OBJ_FILES-$(CONFIG_CMD_NET) += gen_eth_addr.o
Peter Tyserce7626d2009-03-13 18:54:35 -050099OBJ_FILES-$(CONFIG_LCD_LOGO) += bmp_logo.o
100OBJ_FILES-$(CONFIG_VIDEO_LOGO) += bmp_logo.o
Peter Tyser7e897672009-03-13 18:54:38 -0500101OBJ_FILES-$(CONFIG_INCA_IP) += inca-swap-bytes.o
Peter Tyser0fa9ce32009-03-13 18:54:41 -0500102OBJ_FILES-$(CONFIG_NETCONSOLE) += ncb.o
Peter Tyser5b3c54d2009-03-13 18:54:34 -0500103
104# Don't build by default
105#ifeq ($(ARCH),ppc)
106#BIN_FILES-y += mpc86x_clk$(SFX)
107#OBJ_FILES-y += mpc86x_clk.o
108#endif
109
110# Flattened device tree objects
111LIBFDT_OBJ_FILES-y += fdt.o
112LIBFDT_OBJ_FILES-y += fdt_ro.o
113LIBFDT_OBJ_FILES-y += fdt_rw.o
114LIBFDT_OBJ_FILES-y += fdt_strerror.o
115LIBFDT_OBJ_FILES-y += fdt_wip.o
116
Peter Tyserce7626d2009-03-13 18:54:35 -0500117# Generated LCD/video logo
Peter Tyser5b3c54d2009-03-13 18:54:34 -0500118LOGO_H = $(OBJTREE)/include/bmp_logo.h
Peter Tyserce7626d2009-03-13 18:54:35 -0500119LOGO-$(CONFIG_LCD_LOGO) += $(LOGO_H)
120LOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_H)
Peter Tyser5b3c54d2009-03-13 18:54:34 -0500121
122ifeq ($(LOGO_BMP),)
123LOGO_BMP= logos/denx.bmp
124endif
125ifeq ($(VENDOR),atmel)
126LOGO_BMP= logos/atmel.bmp
127endif
128
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200129# now $(obj) is defined
Peter Tyser5b3c54d2009-03-13 18:54:34 -0500130SRCS := $(addprefix $(obj),$(OBJ_LINKS-y:.o=.c)) $(OBJ_FILES-y:.o=.c)
131BINS := $(addprefix $(obj),$(BIN_FILES-y))
132LIBFDT_OBJS := $(addprefix $(obj),$(LIBFDT_OBJ_FILES-y))
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200133
wdenkefee1702002-07-20 20:14:13 +0000134#
135# Use native tools and options
136#
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200137CPPFLAGS = -idirafter $(SRCTREE)/include \
138 -idirafter $(OBJTREE)/include2 \
139 -idirafter $(OBJTREE)/include \
Peter Tyser988f02c2009-03-13 18:54:44 -0500140 -I $(SRCTREE)/libfdt \
Peter Tyserd4de1b22009-03-13 18:54:42 -0500141 -I $(SRCTREE)/tools \
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200142 -DTEXT_BASE=$(TEXT_BASE) -DUSE_HOSTCC
wdenkefee1702002-07-20 20:14:13 +0000143CFLAGS = $(HOST_CFLAGS) $(CPPFLAGS) -O
Bartlomiej Sieka61250862008-02-29 16:00:24 +0100144
145# No -pedantic switch to avoid libfdt compilation warnings
146FIT_CFLAGS = -Wall $(CPPFLAGS) -O
147
wdenkefee1702002-07-20 20:14:13 +0000148AFLAGS = -D__ASSEMBLY__ $(CPPFLAGS)
149CC = $(HOSTCC)
150STRIP = $(HOSTSTRIP)
151MAKEDEPEND = makedepend
152
Peter Tyserce7626d2009-03-13 18:54:35 -0500153all: $(obj).depend $(BINS) $(LOGO-y) subdirs
wdenkefee1702002-07-20 20:14:13 +0000154
Jean-Christophe PLAGNIOL-VILLARD4436c1e2008-09-10 22:48:01 +0200155$(obj)envcrc$(SFX): $(obj)envcrc.o $(obj)crc32.o $(obj)env_embedded.o $(obj)sha1.o
Peter Tyser2f84bc12009-03-13 18:54:33 -0500156 $(CC) $(CFLAGS) -o $@ $^
wdenkefee1702002-07-20 20:14:13 +0000157
Heiko Schocher633e03a2007-06-22 19:11:54 +0200158$(obj)ubsha1$(SFX): $(obj)ubsha1.o $(obj)sha1.o
Peter Tyser2f84bc12009-03-13 18:54:33 -0500159 $(CC) $(CFLAGS) -o $@ $^
Heiko Schocher633e03a2007-06-22 19:11:54 +0200160
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200161$(obj)img2srec$(SFX): $(obj)img2srec.o
Peter Tyser2f84bc12009-03-13 18:54:33 -0500162 $(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
163 $(STRIP) $@
wdenkefee1702002-07-20 20:14:13 +0000164
Peter Tyser2f84bc12009-03-13 18:54:33 -0500165$(obj)mkimage$(SFX): $(obj)mkimage.o $(obj)crc32.o $(obj)image.o $(obj)md5.o \
Peter Tyser5b3c54d2009-03-13 18:54:34 -0500166 $(obj)sha1.o $(LIBFDT_OBJS)
Peter Tyser2f84bc12009-03-13 18:54:33 -0500167 $(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
168 $(STRIP) $@
wdenkefee1702002-07-20 20:14:13 +0000169
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200170$(obj)ncb$(SFX): $(obj)ncb.o
Peter Tyser2f84bc12009-03-13 18:54:33 -0500171 $(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
172 $(STRIP) $@
wdenka0ebde52004-09-08 22:03:11 +0000173
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200174$(obj)gen_eth_addr$(SFX): $(obj)gen_eth_addr.o
Peter Tyser2f84bc12009-03-13 18:54:33 -0500175 $(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
176 $(STRIP) $@
wdenkefee1702002-07-20 20:14:13 +0000177
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200178$(obj)bmp_logo$(SFX): $(obj)bmp_logo.o
Peter Tyser2f84bc12009-03-13 18:54:33 -0500179 $(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
180 $(STRIP) $@
wdenkefee1702002-07-20 20:14:13 +0000181
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200182$(obj)inca-swap-bytes$(SFX): $(obj)inca-swap-bytes.o
Peter Tyser2f84bc12009-03-13 18:54:33 -0500183 $(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
184 $(STRIP) $@
wdenkb02744a2003-04-05 00:53:31 +0000185
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200186$(obj)mpc86x_clk$(SFX): $(obj)mpc86x_clk.o
Peter Tyser2f84bc12009-03-13 18:54:33 -0500187 $(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
188 $(STRIP) $@
wdenk1ee550e2003-10-08 22:14:02 +0000189
Harald Welte5708dbf2008-07-09 22:30:30 +0800190$(obj)bin2header$(SFX): $(obj)bin2header.o
Peter Tyser2f84bc12009-03-13 18:54:33 -0500191 $(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
192 $(STRIP) $@
Harald Welte5708dbf2008-07-09 22:30:30 +0800193
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200194$(obj)envcrc.o: $(src)envcrc.c
Peter Tyser2f84bc12009-03-13 18:54:33 -0500195 $(CC) -g $(CFLAGS) -c -o $@ $<
wdenkefee1702002-07-20 20:14:13 +0000196
Heiko Schocher633e03a2007-06-22 19:11:54 +0200197$(obj)ubsha1.o: $(src)ubsha1.c
Peter Tyser2f84bc12009-03-13 18:54:33 -0500198 $(CC) -g $(CFLAGS) -c -o $@ $<
Heiko Schocher633e03a2007-06-22 19:11:54 +0200199
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200200$(obj)crc32.o: $(obj)crc32.c
Peter Tyser2f84bc12009-03-13 18:54:33 -0500201 $(CC) -g $(CFLAGS) -c -o $@ $<
wdenkefee1702002-07-20 20:14:13 +0000202
Bartlomiej Sieka2e6f2852008-03-14 16:22:34 +0100203$(obj)md5.o: $(obj)md5.c
Peter Tyser2f84bc12009-03-13 18:54:33 -0500204 $(CC) -g $(CFLAGS) -c -o $@ $<
Bartlomiej Sieka2e6f2852008-03-14 16:22:34 +0100205
Heiko Schocher633e03a2007-06-22 19:11:54 +0200206$(obj)sha1.o: $(obj)sha1.c
Peter Tyser2f84bc12009-03-13 18:54:33 -0500207 $(CC) -g $(CFLAGS) -c -o $@ $<
Heiko Schocher633e03a2007-06-22 19:11:54 +0200208
Marian Balakowicz41d71ed2008-01-08 18:14:09 +0100209$(obj)image.o: $(obj)image.c
Peter Tyser2f84bc12009-03-13 18:54:33 -0500210 $(CC) -g $(FIT_CFLAGS) -c -o $@ $<
Marian Balakowicz41d71ed2008-01-08 18:14:09 +0100211
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200212$(obj)mkimage.o: $(src)mkimage.c
Peter Tyser2f84bc12009-03-13 18:54:33 -0500213 $(CC) -g $(FIT_CFLAGS) -c -o $@ $<
wdenkefee1702002-07-20 20:14:13 +0000214
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200215$(obj)ncb.o: $(src)ncb.c
Peter Tyser2f84bc12009-03-13 18:54:33 -0500216 $(CC) -g $(CFLAGS) -c -o $@ $<
wdenka0ebde52004-09-08 22:03:11 +0000217
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200218$(obj)gen_eth_addr.o: $(src)gen_eth_addr.c
Peter Tyser2f84bc12009-03-13 18:54:33 -0500219 $(CC) -g $(CFLAGS) -c -o $@ $<
wdenkefee1702002-07-20 20:14:13 +0000220
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200221$(obj)inca-swap-bytes.o: $(src)inca-swap-bytes.c
Peter Tyser2f84bc12009-03-13 18:54:33 -0500222 $(CC) -g $(CFLAGS) -c -o $@ $<
wdenkb02744a2003-04-05 00:53:31 +0000223
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200224$(obj)mpc86x_clk.o: $(src)mpc86x_clk.c
Peter Tyser2f84bc12009-03-13 18:54:33 -0500225 $(CC) -g $(CFLAGS) -c -o $@ $<
wdenk1ee550e2003-10-08 22:14:02 +0000226
Peter Tyserd0c23bf2009-03-13 18:54:45 -0500227$(obj)fdt.o: $(LIBFDT_DIR)fdt.c $(SRCTREE)/libfdt/libfdt_internal.h
Peter Tyser2f84bc12009-03-13 18:54:33 -0500228 $(CC) -g $(FIT_CFLAGS) -c -o $@ $<
Bartlomiej Sieka61250862008-02-29 16:00:24 +0100229
Peter Tyserd0c23bf2009-03-13 18:54:45 -0500230$(obj)fdt_ro.o: $(LIBFDT_DIR)fdt_ro.c $(SRCTREE)/libfdt/libfdt_internal.h
Peter Tyser2f84bc12009-03-13 18:54:33 -0500231 $(CC) -g $(FIT_CFLAGS) -c -o $@ $<
Bartlomiej Sieka61250862008-02-29 16:00:24 +0100232
Peter Tyserd0c23bf2009-03-13 18:54:45 -0500233$(obj)fdt_rw.o: $(LIBFDT_DIR)fdt_rw.c $(SRCTREE)/libfdt/libfdt_internal.h
Peter Tyser2f84bc12009-03-13 18:54:33 -0500234 $(CC) -g $(FIT_CFLAGS) -c -o $@ $<
Bartlomiej Sieka61250862008-02-29 16:00:24 +0100235
Peter Tyserd0c23bf2009-03-13 18:54:45 -0500236$(obj)fdt_strerror.o: $(LIBFDT_DIR)fdt_strerror.c \
237 $(SRCTREE)/libfdt/libfdt_internal.h
Peter Tyser2f84bc12009-03-13 18:54:33 -0500238 $(CC) -g $(FIT_CFLAGS) -c -o $@ $<
Bartlomiej Sieka61250862008-02-29 16:00:24 +0100239
Peter Tyserd0c23bf2009-03-13 18:54:45 -0500240$(obj)fdt_wip.o: $(LIBFDT_DIR)fdt_wip.c $(SRCTREE)/libfdt/libfdt_internal.h
Peter Tyser2f84bc12009-03-13 18:54:33 -0500241 $(CC) -g $(FIT_CFLAGS) -c -o $@ $<
Bartlomiej Sieka61250862008-02-29 16:00:24 +0100242
wdenkefee1702002-07-20 20:14:13 +0000243subdirs:
wdenk5d841732003-08-17 18:55:18 +0000244ifeq ($(TOOLSUBDIRS),)
Peter Tyser2f84bc12009-03-13 18:54:33 -0500245 @:
wdenk5d841732003-08-17 18:55:18 +0000246else
Peter Tyser2f84bc12009-03-13 18:54:33 -0500247 @for dir in $(TOOLSUBDIRS) ; do \
248 $(MAKE) \
249 HOSTOS=$(HOSTOS) \
250 HOSTARCH=$(HOSTARCH) \
251 HOST_CFLAGS="$(HOST_CFLAGS)" \
252 HOST_LDFLAGS="$(HOST_LDFLAGS)" \
253 -C $$dir || exit 1 ; \
254 done
wdenk5d841732003-08-17 18:55:18 +0000255endif
256
Jean-Christophe PLAGNIOL-VILLARD4436c1e2008-09-10 22:48:01 +0200257$(obj)env_embedded.c:
Peter Tyser2f84bc12009-03-13 18:54:33 -0500258 @rm -f $(obj)env_embedded.c
259 ln -s $(src)../common/env_embedded.c $(obj)env_embedded.c
wdenkefee1702002-07-20 20:14:13 +0000260
Jean-Christophe PLAGNIOL-VILLARD4436c1e2008-09-10 22:48:01 +0200261$(obj)env_embedded.o: $(obj)env_embedded.c
Peter Tyser2f84bc12009-03-13 18:54:33 -0500262 $(CC) -g $(HOST_ENVIRO_CFLAGS) $(CPPFLAGS) -c -o $@ $<
wdenkefee1702002-07-20 20:14:13 +0000263
Peter Tyser23808ae2009-03-13 18:54:43 -0500264$(obj)crc32.c: $(SRCTREE)/include/u-boot/zlib.h
Peter Tyser2f84bc12009-03-13 18:54:33 -0500265 @rm -f $(obj)crc32.c
266 ln -s $(src)../lib_generic/crc32.c $(obj)crc32.c
wdenkefee1702002-07-20 20:14:13 +0000267
Bartlomiej Sieka2e6f2852008-03-14 16:22:34 +0100268$(obj)md5.c:
Peter Tyser2f84bc12009-03-13 18:54:33 -0500269 @rm -f $(obj)md5.c
270 ln -s $(src)../lib_generic/md5.c $(obj)md5.c
Bartlomiej Sieka2e6f2852008-03-14 16:22:34 +0100271
Heiko Schocher633e03a2007-06-22 19:11:54 +0200272$(obj)sha1.c:
Peter Tyser2f84bc12009-03-13 18:54:33 -0500273 @rm -f $(obj)sha1.c
274 ln -s $(src)../lib_generic/sha1.c $(obj)sha1.c
Heiko Schocher633e03a2007-06-22 19:11:54 +0200275
Marian Balakowicz41d71ed2008-01-08 18:14:09 +0100276$(obj)image.c:
Peter Tyser2f84bc12009-03-13 18:54:33 -0500277 @rm -f $(obj)image.c
278 ln -s $(src)../common/image.c $(obj)image.c
Marian Balakowicz41d71ed2008-01-08 18:14:09 +0100279
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200280$(LOGO_H): $(obj)bmp_logo $(LOGO_BMP)
Peter Tyser2f84bc12009-03-13 18:54:33 -0500281 $(obj)./bmp_logo $(LOGO_BMP) >$@
wdenkefee1702002-07-20 20:14:13 +0000282
283#########################################################################
284
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200285# defines $(obj).depend target
286include $(SRCTREE)/rules.mk
wdenkefee1702002-07-20 20:14:13 +0000287
Marian Balakowiczd62379d2006-09-01 19:49:50 +0200288sinclude $(obj).depend
wdenkefee1702002-07-20 20:14:13 +0000289
290#########################################################################