blob: b7a30b28eb306c24ddc2754d531b2631793d62ae [file] [log] [blame]
wdenkefee1702002-07-20 20:14:13 +00001#
Marian Balakowiczf9328632006-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 =
25
26#
27# Mac OS X / Darwin's C preprocessor is Apple specific. It
28# generates numerous errors and warnings. We want to bypass it
29# and use GNU C's cpp. To do this we pass the -traditional-cpp
30# option to the compiler. Note that the -traditional-cpp flag
31# DOES NOT have the same semantics as GNU C's flag, all it does
32# is invoke the GNU preprocessor in stock ANSI/ISO C fashion.
33#
34# Apple's linker is similar, thanks to the new 2 stage linking
35# multiple symbol definitions are treated as errors, hence the
36# -multiply_defined suppress option to turn off this error.
37#
38ifeq ($(HOSTOS)-$(HOSTARCH),darwin-ppc)
wdenkefee1702002-07-20 20:14:13 +000039HOST_CFLAGS = -traditional-cpp -Wall
40HOST_LDFLAGS =-multiply_defined suppress
Aubrey.Li5dfaa502007-05-14 11:47:35 +080041HOST_ENVIRO_CFLAGS =
wdenkefee1702002-07-20 20:14:13 +000042
43else
wdenkefee1702002-07-20 20:14:13 +000044ifeq ($(HOSTOS)-$(HOSTARCH),netbsd-ppc)
45HOST_CFLAGS = -Wall -pedantic
46HOST_LDFLAGS =
47HOST_ENVIRO_CFLAGS =
48
49#
50# Everyone else
51#
52else
wdenkefee1702002-07-20 20:14:13 +000053HOST_CFLAGS = -Wall -pedantic
54HOST_LDFLAGS =
55HOST_ENVIRO_CFLAGS =
56endif
57endif
58
59#
60# Cygwin needs .exe files :-(
61#
62ifeq ($(HOSTOS),cygwin)
63SFX = .exe
raptorbrino@aim.com883e3922007-12-13 21:23:28 -050064HOST_CFLAGS += -ansi
wdenkefee1702002-07-20 20:14:13 +000065else
66SFX =
67endif
68
wdenkefee1702002-07-20 20:14:13 +000069#
70# Include this after HOSTOS HOSTARCH check
71# so that we can act intelligently.
72#
73include $(TOPDIR)/config.mk
74
Peter Tyseree3584a2009-03-13 18:54:34 -050075# Generated executable files
Peter Tysereeba8612009-03-13 18:54:36 -050076BIN_FILES-$(CONFIG_CMD_LOADS) += img2srec$(SFX)
Peter Tyseree3584a2009-03-13 18:54:34 -050077BIN_FILES-y += mkimage$(SFX)
Peter Tyser4d93a0a2009-03-13 18:54:39 -050078BIN_FILES-$(CONFIG_ENV_IS_EMBEDDED) += envcrc$(SFX)
Peter Tyser7cd5cbc2009-03-13 18:54:37 -050079BIN_FILES-$(CONFIG_SHA1_CHECK_UB_IMG) += ubsha1$(SFX)
Peter Tyser123c48a2009-03-13 18:54:40 -050080BIN_FILES-$(CONFIG_CMD_NET) += gen_eth_addr$(SFX)
Peter Tyser335ffe72009-03-13 18:54:35 -050081BIN_FILES-$(CONFIG_LCD_LOGO) += bmp_logo$(SFX)
82BIN_FILES-$(CONFIG_VIDEO_LOGO) += bmp_logo$(SFX)
Peter Tysercd26a312009-03-13 18:54:38 -050083BIN_FILES-$(CONFIG_INCA_IP) += inca-swap-bytes$(SFX)
Peter Tyser1cd300d2009-03-13 18:54:41 -050084BIN_FILES-$(CONFIG_NETCONSOLE) += ncb$(SFX)
Peter Tyseree3584a2009-03-13 18:54:34 -050085
Peter Tyserfb8b33c2009-03-13 18:54:47 -050086# Source files which exist outside the tools directory
87EXT_OBJ_FILES-y += common/env_embedded.o
88EXT_OBJ_FILES-y += lib_generic/crc32.o
89EXT_OBJ_FILES-y += lib_generic/md5.o
90EXT_OBJ_FILES-y += lib_generic/sha1.o
91EXT_OBJ_FILES-y += common/image.o
Peter Tyseree3584a2009-03-13 18:54:34 -050092
93# Source files located in the tools directory
Peter Tysereeba8612009-03-13 18:54:36 -050094OBJ_FILES-$(CONFIG_CMD_LOADS) += img2srec.o
Peter Tyseree3584a2009-03-13 18:54:34 -050095OBJ_FILES-y += mkimage.o
Peter Tyser4d93a0a2009-03-13 18:54:39 -050096OBJ_FILES-$(CONFIG_ENV_IS_EMBEDDED) += envcrc.o
Peter Tyser7cd5cbc2009-03-13 18:54:37 -050097OBJ_FILES-$(CONFIG_SHA1_CHECK_UB_IMG) += ubsha1.o
Peter Tyser123c48a2009-03-13 18:54:40 -050098OBJ_FILES-$(CONFIG_CMD_NET) += gen_eth_addr.o
Peter Tyser335ffe72009-03-13 18:54:35 -050099OBJ_FILES-$(CONFIG_LCD_LOGO) += bmp_logo.o
100OBJ_FILES-$(CONFIG_VIDEO_LOGO) += bmp_logo.o
Peter Tysercd26a312009-03-13 18:54:38 -0500101OBJ_FILES-$(CONFIG_INCA_IP) += inca-swap-bytes.o
Peter Tyser1cd300d2009-03-13 18:54:41 -0500102OBJ_FILES-$(CONFIG_NETCONSOLE) += ncb.o
Peter Tyseree3584a2009-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 Tyser335ffe72009-03-13 18:54:35 -0500117# Generated LCD/video logo
Peter Tyseree3584a2009-03-13 18:54:34 -0500118LOGO_H = $(OBJTREE)/include/bmp_logo.h
Peter Tyser335ffe72009-03-13 18:54:35 -0500119LOGO-$(CONFIG_LCD_LOGO) += $(LOGO_H)
120LOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_H)
Peter Tyseree3584a2009-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 Balakowiczf9328632006-09-01 19:49:50 +0200129# now $(obj) is defined
Peter Tyserfb8b33c2009-03-13 18:54:47 -0500130SRCS += $(addprefix $(SRCTREE)/,$(EXT_OBJ_FILES-y:.o=.c))
131SRCS += $(OBJ_FILES-y:.o=.c)
Peter Tysereed07332009-03-13 18:54:46 -0500132SRCS += $(addprefix $(SRCTREE)/libfdt/,$(LIBFDT_OBJ_FILES-y:.o=.c))
Peter Tyseree3584a2009-03-13 18:54:34 -0500133BINS := $(addprefix $(obj),$(BIN_FILES-y))
134LIBFDT_OBJS := $(addprefix $(obj),$(LIBFDT_OBJ_FILES-y))
Marian Balakowiczf9328632006-09-01 19:49:50 +0200135
wdenkefee1702002-07-20 20:14:13 +0000136#
137# Use native tools and options
138#
Marian Balakowiczf9328632006-09-01 19:49:50 +0200139CPPFLAGS = -idirafter $(SRCTREE)/include \
140 -idirafter $(OBJTREE)/include2 \
141 -idirafter $(OBJTREE)/include \
Peter Tyser45d6bdf2009-03-13 18:54:44 -0500142 -I $(SRCTREE)/libfdt \
Peter Tyser40b8d902009-03-13 18:54:42 -0500143 -I $(SRCTREE)/tools \
Marian Balakowiczf9328632006-09-01 19:49:50 +0200144 -DTEXT_BASE=$(TEXT_BASE) -DUSE_HOSTCC
wdenkefee1702002-07-20 20:14:13 +0000145CFLAGS = $(HOST_CFLAGS) $(CPPFLAGS) -O
Bartlomiej Sieka8cf30802008-02-29 16:00:24 +0100146
147# No -pedantic switch to avoid libfdt compilation warnings
148FIT_CFLAGS = -Wall $(CPPFLAGS) -O
149
wdenkefee1702002-07-20 20:14:13 +0000150AFLAGS = -D__ASSEMBLY__ $(CPPFLAGS)
151CC = $(HOSTCC)
152STRIP = $(HOSTSTRIP)
153MAKEDEPEND = makedepend
154
Peter Tyser335ffe72009-03-13 18:54:35 -0500155all: $(obj).depend $(BINS) $(LOGO-y) subdirs
wdenkefee1702002-07-20 20:14:13 +0000156
Jean-Christophe PLAGNIOL-VILLARD0cf4fd32008-09-10 22:48:01 +0200157$(obj)envcrc$(SFX): $(obj)envcrc.o $(obj)crc32.o $(obj)env_embedded.o $(obj)sha1.o
Peter Tyser21d28e92009-03-13 18:54:33 -0500158 $(CC) $(CFLAGS) -o $@ $^
Heiko Schocher566a4942007-06-22 19:11:54 +0200159
160$(obj)ubsha1$(SFX): $(obj)ubsha1.o $(obj)sha1.o
Peter Tyser21d28e92009-03-13 18:54:33 -0500161 $(CC) $(CFLAGS) -o $@ $^
wdenkefee1702002-07-20 20:14:13 +0000162
Marian Balakowiczf9328632006-09-01 19:49:50 +0200163$(obj)img2srec$(SFX): $(obj)img2srec.o
Peter Tyser21d28e92009-03-13 18:54:33 -0500164 $(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
165 $(STRIP) $@
wdenkefee1702002-07-20 20:14:13 +0000166
Peter Tyser21d28e92009-03-13 18:54:33 -0500167$(obj)mkimage$(SFX): $(obj)mkimage.o $(obj)crc32.o $(obj)image.o $(obj)md5.o \
Peter Tyseree3584a2009-03-13 18:54:34 -0500168 $(obj)sha1.o $(LIBFDT_OBJS)
Peter Tyser21d28e92009-03-13 18:54:33 -0500169 $(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
170 $(STRIP) $@
wdenkefee1702002-07-20 20:14:13 +0000171
Marian Balakowiczf9328632006-09-01 19:49:50 +0200172$(obj)ncb$(SFX): $(obj)ncb.o
Peter Tyser21d28e92009-03-13 18:54:33 -0500173 $(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
174 $(STRIP) $@
wdenkeedcd072004-09-08 22:03:11 +0000175
Marian Balakowiczf9328632006-09-01 19:49:50 +0200176$(obj)gen_eth_addr$(SFX): $(obj)gen_eth_addr.o
Peter Tyser21d28e92009-03-13 18:54:33 -0500177 $(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
178 $(STRIP) $@
wdenkefee1702002-07-20 20:14:13 +0000179
Marian Balakowiczf9328632006-09-01 19:49:50 +0200180$(obj)bmp_logo$(SFX): $(obj)bmp_logo.o
Peter Tyser21d28e92009-03-13 18:54:33 -0500181 $(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
182 $(STRIP) $@
wdenkefee1702002-07-20 20:14:13 +0000183
Marian Balakowiczf9328632006-09-01 19:49:50 +0200184$(obj)inca-swap-bytes$(SFX): $(obj)inca-swap-bytes.o
Peter Tyser21d28e92009-03-13 18:54:33 -0500185 $(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
186 $(STRIP) $@
wdenk3e386912003-04-05 00:53:31 +0000187
Marian Balakowiczf9328632006-09-01 19:49:50 +0200188$(obj)mpc86x_clk$(SFX): $(obj)mpc86x_clk.o
Peter Tyser21d28e92009-03-13 18:54:33 -0500189 $(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
190 $(STRIP) $@
wdenkef1464c2003-10-08 22:14:02 +0000191
Harald Welte0a823aa2008-07-09 22:30:30 +0800192$(obj)bin2header$(SFX): $(obj)bin2header.o
Peter Tyser21d28e92009-03-13 18:54:33 -0500193 $(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
194 $(STRIP) $@
Harald Welte0a823aa2008-07-09 22:30:30 +0800195
Peter Tyser273174d2009-03-13 18:54:48 -0500196$(obj)envcrc.o:
Peter Tyser21d28e92009-03-13 18:54:33 -0500197 $(CC) -g $(CFLAGS) -c -o $@ $<
wdenkefee1702002-07-20 20:14:13 +0000198
Peter Tyser273174d2009-03-13 18:54:48 -0500199$(obj)ubsha1.o:
Peter Tyser21d28e92009-03-13 18:54:33 -0500200 $(CC) -g $(CFLAGS) -c -o $@ $<
Heiko Schocher566a4942007-06-22 19:11:54 +0200201
Peter Tyser273174d2009-03-13 18:54:48 -0500202$(obj)crc32.o:
Peter Tyser21d28e92009-03-13 18:54:33 -0500203 $(CC) -g $(CFLAGS) -c -o $@ $<
wdenkefee1702002-07-20 20:14:13 +0000204
Peter Tyser273174d2009-03-13 18:54:48 -0500205$(obj)md5.o:
Peter Tyser21d28e92009-03-13 18:54:33 -0500206 $(CC) -g $(CFLAGS) -c -o $@ $<
Bartlomiej Sieka766529f2008-03-14 16:22:34 +0100207
Peter Tyser273174d2009-03-13 18:54:48 -0500208$(obj)sha1.o:
Peter Tyser21d28e92009-03-13 18:54:33 -0500209 $(CC) -g $(CFLAGS) -c -o $@ $<
Heiko Schocher566a4942007-06-22 19:11:54 +0200210
Peter Tyser273174d2009-03-13 18:54:48 -0500211$(obj)image.o:
Peter Tyser21d28e92009-03-13 18:54:33 -0500212 $(CC) -g $(FIT_CFLAGS) -c -o $@ $<
Marian Balakowiczb97a2a02008-01-08 18:14:09 +0100213
Peter Tyser273174d2009-03-13 18:54:48 -0500214$(obj)mkimage.o:
Peter Tyser21d28e92009-03-13 18:54:33 -0500215 $(CC) -g $(FIT_CFLAGS) -c -o $@ $<
wdenkefee1702002-07-20 20:14:13 +0000216
Peter Tyser273174d2009-03-13 18:54:48 -0500217$(obj)ncb.o:
Peter Tyser21d28e92009-03-13 18:54:33 -0500218 $(CC) -g $(CFLAGS) -c -o $@ $<
wdenkeedcd072004-09-08 22:03:11 +0000219
Peter Tyser273174d2009-03-13 18:54:48 -0500220$(obj)gen_eth_addr.o:
Peter Tyser21d28e92009-03-13 18:54:33 -0500221 $(CC) -g $(CFLAGS) -c -o $@ $<
wdenkefee1702002-07-20 20:14:13 +0000222
Peter Tyser273174d2009-03-13 18:54:48 -0500223$(obj)inca-swap-bytes.o:
Peter Tyser21d28e92009-03-13 18:54:33 -0500224 $(CC) -g $(CFLAGS) -c -o $@ $<
wdenk3e386912003-04-05 00:53:31 +0000225
Peter Tyser273174d2009-03-13 18:54:48 -0500226$(obj)mpc86x_clk.o:
Peter Tyser21d28e92009-03-13 18:54:33 -0500227 $(CC) -g $(CFLAGS) -c -o $@ $<
wdenkef1464c2003-10-08 22:14:02 +0000228
Peter Tysereed07332009-03-13 18:54:46 -0500229$(obj)fdt.o:
Peter Tyser21d28e92009-03-13 18:54:33 -0500230 $(CC) -g $(FIT_CFLAGS) -c -o $@ $<
Bartlomiej Sieka8cf30802008-02-29 16:00:24 +0100231
Peter Tysereed07332009-03-13 18:54:46 -0500232$(obj)fdt_ro.o:
Peter Tyser21d28e92009-03-13 18:54:33 -0500233 $(CC) -g $(FIT_CFLAGS) -c -o $@ $<
Bartlomiej Sieka8cf30802008-02-29 16:00:24 +0100234
Peter Tysereed07332009-03-13 18:54:46 -0500235$(obj)fdt_rw.o:
Peter Tyser21d28e92009-03-13 18:54:33 -0500236 $(CC) -g $(FIT_CFLAGS) -c -o $@ $<
Bartlomiej Sieka8cf30802008-02-29 16:00:24 +0100237
Peter Tysereed07332009-03-13 18:54:46 -0500238$(obj)fdt_strerror.o:
Peter Tyser21d28e92009-03-13 18:54:33 -0500239 $(CC) -g $(FIT_CFLAGS) -c -o $@ $<
Bartlomiej Sieka8cf30802008-02-29 16:00:24 +0100240
Peter Tysereed07332009-03-13 18:54:46 -0500241$(obj)fdt_wip.o:
Peter Tyser21d28e92009-03-13 18:54:33 -0500242 $(CC) -g $(FIT_CFLAGS) -c -o $@ $<
Bartlomiej Sieka8cf30802008-02-29 16:00:24 +0100243
wdenkefee1702002-07-20 20:14:13 +0000244subdirs:
wdenke0ac62d2003-08-17 18:55:18 +0000245ifeq ($(TOOLSUBDIRS),)
Peter Tyser21d28e92009-03-13 18:54:33 -0500246 @:
wdenke0ac62d2003-08-17 18:55:18 +0000247else
Peter Tyser21d28e92009-03-13 18:54:33 -0500248 @for dir in $(TOOLSUBDIRS) ; do \
249 $(MAKE) \
250 HOSTOS=$(HOSTOS) \
251 HOSTARCH=$(HOSTARCH) \
252 HOST_CFLAGS="$(HOST_CFLAGS)" \
253 HOST_LDFLAGS="$(HOST_LDFLAGS)" \
254 -C $$dir || exit 1 ; \
255 done
wdenke0ac62d2003-08-17 18:55:18 +0000256endif
257
Peter Tyser273174d2009-03-13 18:54:48 -0500258$(obj)env_embedded.o:
Peter Tyser21d28e92009-03-13 18:54:33 -0500259 $(CC) -g $(HOST_ENVIRO_CFLAGS) $(CPPFLAGS) -c -o $@ $<
wdenkefee1702002-07-20 20:14:13 +0000260
Marian Balakowiczf9328632006-09-01 19:49:50 +0200261$(LOGO_H): $(obj)bmp_logo $(LOGO_BMP)
Peter Tyser21d28e92009-03-13 18:54:33 -0500262 $(obj)./bmp_logo $(LOGO_BMP) >$@
wdenkefee1702002-07-20 20:14:13 +0000263
264#########################################################################
265
Marian Balakowiczf9328632006-09-01 19:49:50 +0200266# defines $(obj).depend target
267include $(SRCTREE)/rules.mk
wdenkefee1702002-07-20 20:14:13 +0000268
Marian Balakowiczf9328632006-09-01 19:49:50 +0200269sinclude $(obj).depend
wdenkefee1702002-07-20 20:14:13 +0000270
271#########################################################################