xref: /rk3399_rockchip-uboot/tools/Makefile (revision c0170175393b94560fa7a5da6dd31377df5f4a72)
1#
2# (C) Copyright 2000-2006
3# 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
24TOOLSUBDIRS =
25LIBFDT_DIR = $(SRCTREE)/libfdt/
26
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)
40HOST_CFLAGS = -traditional-cpp -Wall
41HOST_LDFLAGS =-multiply_defined suppress
42HOST_ENVIRO_CFLAGS =
43
44else
45ifeq ($(HOSTOS)-$(HOSTARCH),netbsd-ppc)
46HOST_CFLAGS = -Wall -pedantic
47HOST_LDFLAGS =
48HOST_ENVIRO_CFLAGS =
49
50#
51# Everyone else
52#
53else
54HOST_CFLAGS = -Wall -pedantic
55HOST_LDFLAGS =
56HOST_ENVIRO_CFLAGS =
57endif
58endif
59
60#
61# Cygwin needs .exe files :-(
62#
63ifeq ($(HOSTOS),cygwin)
64SFX = .exe
65HOST_CFLAGS += -ansi
66else
67SFX =
68endif
69
70#
71# Include this after HOSTOS HOSTARCH check
72# so that we can act intelligently.
73#
74include $(TOPDIR)/config.mk
75
76# Generated executable files
77BIN_FILES-$(CONFIG_CMD_LOADS) += img2srec$(SFX)
78BIN_FILES-y += mkimage$(SFX)
79BIN_FILES-$(CONFIG_ENV_IS_EMBEDDED) += envcrc$(SFX)
80BIN_FILES-$(CONFIG_SHA1_CHECK_UB_IMG) += ubsha1$(SFX)
81BIN_FILES-$(CONFIG_CMD_NET) += gen_eth_addr$(SFX)
82BIN_FILES-$(CONFIG_LCD_LOGO) += bmp_logo$(SFX)
83BIN_FILES-$(CONFIG_VIDEO_LOGO) += bmp_logo$(SFX)
84BIN_FILES-$(CONFIG_INCA_IP) += inca-swap-bytes$(SFX)
85BIN_FILES-$(CONFIG_NETCONSOLE) += ncb$(SFX)
86
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
94OBJ_FILES-$(CONFIG_CMD_LOADS) += img2srec.o
95OBJ_FILES-y += mkimage.o
96OBJ_FILES-$(CONFIG_ENV_IS_EMBEDDED) += envcrc.o
97OBJ_FILES-$(CONFIG_SHA1_CHECK_UB_IMG) += ubsha1.o
98OBJ_FILES-$(CONFIG_CMD_NET) += gen_eth_addr.o
99OBJ_FILES-$(CONFIG_LCD_LOGO) += bmp_logo.o
100OBJ_FILES-$(CONFIG_VIDEO_LOGO) += bmp_logo.o
101OBJ_FILES-$(CONFIG_INCA_IP) += inca-swap-bytes.o
102OBJ_FILES-$(CONFIG_NETCONSOLE) += ncb.o
103
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
117# Generated LCD/video logo
118LOGO_H = $(OBJTREE)/include/bmp_logo.h
119LOGO-$(CONFIG_LCD_LOGO) += $(LOGO_H)
120LOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_H)
121
122ifeq ($(LOGO_BMP),)
123LOGO_BMP= logos/denx.bmp
124endif
125ifeq ($(VENDOR),atmel)
126LOGO_BMP= logos/atmel.bmp
127endif
128
129# now $(obj) is defined
130SRCS	:= $(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))
133
134#
135# Use native tools and options
136#
137CPPFLAGS   = -idirafter $(SRCTREE)/include \
138		-idirafter $(OBJTREE)/include2 \
139		-idirafter $(OBJTREE)/include \
140	        -I $(SRCTREE)/libfdt \
141		-I $(SRCTREE)/tools \
142		-DTEXT_BASE=$(TEXT_BASE) -DUSE_HOSTCC
143CFLAGS     = $(HOST_CFLAGS) $(CPPFLAGS) -O
144
145# No -pedantic switch to avoid libfdt compilation warnings
146FIT_CFLAGS = -Wall $(CPPFLAGS) -O
147
148AFLAGS	   = -D__ASSEMBLY__ $(CPPFLAGS)
149CC	   = $(HOSTCC)
150STRIP	   = $(HOSTSTRIP)
151MAKEDEPEND = makedepend
152
153all:	$(obj).depend $(BINS) $(LOGO-y) subdirs
154
155$(obj)envcrc$(SFX):	$(obj)envcrc.o $(obj)crc32.o $(obj)env_embedded.o $(obj)sha1.o
156	$(CC) $(CFLAGS) -o $@ $^
157
158$(obj)ubsha1$(SFX):	$(obj)ubsha1.o $(obj)sha1.o
159	$(CC) $(CFLAGS) -o $@ $^
160
161$(obj)img2srec$(SFX):	$(obj)img2srec.o
162	$(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
163	$(STRIP) $@
164
165$(obj)mkimage$(SFX):	$(obj)mkimage.o $(obj)crc32.o $(obj)image.o $(obj)md5.o \
166			$(obj)sha1.o $(LIBFDT_OBJS)
167	$(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
168	$(STRIP) $@
169
170$(obj)ncb$(SFX):	$(obj)ncb.o
171	$(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
172	$(STRIP) $@
173
174$(obj)gen_eth_addr$(SFX):	$(obj)gen_eth_addr.o
175	$(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
176	$(STRIP) $@
177
178$(obj)bmp_logo$(SFX):	$(obj)bmp_logo.o
179	$(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
180	$(STRIP) $@
181
182$(obj)inca-swap-bytes$(SFX):	$(obj)inca-swap-bytes.o
183	$(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
184	$(STRIP) $@
185
186$(obj)mpc86x_clk$(SFX):	$(obj)mpc86x_clk.o
187	$(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
188	$(STRIP) $@
189
190$(obj)bin2header$(SFX): $(obj)bin2header.o
191	$(CC) $(CFLAGS) $(HOST_LDFLAGS) -o $@ $^
192	$(STRIP) $@
193
194$(obj)envcrc.o:	$(src)envcrc.c
195	$(CC) -g $(CFLAGS) -c -o $@ $<
196
197$(obj)ubsha1.o:	$(src)ubsha1.c
198	$(CC) -g $(CFLAGS) -c -o $@ $<
199
200$(obj)crc32.o:	$(obj)crc32.c
201	$(CC) -g $(CFLAGS) -c -o $@ $<
202
203$(obj)md5.o:	$(obj)md5.c
204	$(CC) -g $(CFLAGS) -c -o $@ $<
205
206$(obj)sha1.o:	$(obj)sha1.c
207	$(CC) -g $(CFLAGS) -c -o $@ $<
208
209$(obj)image.o:	$(obj)image.c
210	$(CC) -g $(FIT_CFLAGS) -c -o $@ $<
211
212$(obj)mkimage.o:	$(src)mkimage.c
213	$(CC) -g $(FIT_CFLAGS) -c -o $@ $<
214
215$(obj)ncb.o:		$(src)ncb.c
216	$(CC) -g $(CFLAGS) -c -o $@ $<
217
218$(obj)gen_eth_addr.o:	$(src)gen_eth_addr.c
219	$(CC) -g $(CFLAGS) -c -o $@ $<
220
221$(obj)inca-swap-bytes.o:	$(src)inca-swap-bytes.c
222	$(CC) -g $(CFLAGS) -c -o $@ $<
223
224$(obj)mpc86x_clk.o:	$(src)mpc86x_clk.c
225	$(CC) -g $(CFLAGS) -c -o $@ $<
226
227$(obj)fdt.o:	$(LIBFDT_DIR)fdt.c $(SRCTREE)/libfdt/libfdt_internal.h
228	$(CC) -g $(FIT_CFLAGS) -c -o $@ $<
229
230$(obj)fdt_ro.o:	$(LIBFDT_DIR)fdt_ro.c $(SRCTREE)/libfdt/libfdt_internal.h
231	$(CC) -g $(FIT_CFLAGS) -c -o $@ $<
232
233$(obj)fdt_rw.o:	$(LIBFDT_DIR)fdt_rw.c $(SRCTREE)/libfdt/libfdt_internal.h
234	$(CC) -g $(FIT_CFLAGS) -c -o $@ $<
235
236$(obj)fdt_strerror.o: $(LIBFDT_DIR)fdt_strerror.c \
237			$(SRCTREE)/libfdt/libfdt_internal.h
238	$(CC) -g $(FIT_CFLAGS) -c -o $@ $<
239
240$(obj)fdt_wip.o: $(LIBFDT_DIR)fdt_wip.c $(SRCTREE)/libfdt/libfdt_internal.h
241	$(CC) -g $(FIT_CFLAGS) -c -o $@ $<
242
243subdirs:
244ifeq ($(TOOLSUBDIRS),)
245	@:
246else
247	@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
255endif
256
257$(obj)env_embedded.c:
258	@rm -f $(obj)env_embedded.c
259	ln -s $(src)../common/env_embedded.c $(obj)env_embedded.c
260
261$(obj)env_embedded.o:	$(obj)env_embedded.c
262	$(CC) -g $(HOST_ENVIRO_CFLAGS) $(CPPFLAGS) -c -o $@ $<
263
264$(obj)crc32.c: $(SRCTREE)/include/u-boot/zlib.h
265	@rm -f $(obj)crc32.c
266	ln -s $(src)../lib_generic/crc32.c $(obj)crc32.c
267
268$(obj)md5.c:
269	@rm -f $(obj)md5.c
270	ln -s $(src)../lib_generic/md5.c $(obj)md5.c
271
272$(obj)sha1.c:
273	@rm -f $(obj)sha1.c
274	ln -s $(src)../lib_generic/sha1.c $(obj)sha1.c
275
276$(obj)image.c:
277	@rm -f $(obj)image.c
278	ln -s $(src)../common/image.c $(obj)image.c
279
280$(LOGO_H):	$(obj)bmp_logo $(LOGO_BMP)
281	$(obj)./bmp_logo $(LOGO_BMP) >$@
282
283#########################################################################
284
285# defines $(obj).depend target
286include $(SRCTREE)/rules.mk
287
288sinclude $(obj).depend
289
290#########################################################################
291