xref: /rk3399_rockchip-uboot/tools/Makefile (revision 76bce10d2131938fcd5b1bbb0479cdb66daffa29)
1#
2# (C) Copyright 2000-2006
3# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
4#
5# SPDX-License-Identifier:	GPL-2.0+
6#
7
8# Enable all the config-independent tools
9ifneq ($(HOST_TOOLS_ALL),)
10CONFIG_LCD_LOGO = y
11CONFIG_CMD_LOADS = y
12CONFIG_CMD_NET = y
13CONFIG_XWAY_SWAP_BYTES = y
14CONFIG_NETCONSOLE = y
15CONFIG_SHA1_CHECK_UB_IMG = y
16endif
17
18subdir-$(HOST_TOOLS_ALL) += easylogo
19subdir-$(HOST_TOOLS_ALL) += gdb
20
21# Merge all the different vars for envcrc into one
22ENVCRC-$(CONFIG_ENV_IS_EMBEDDED) = y
23ENVCRC-$(CONFIG_ENV_IS_IN_DATAFLASH) = y
24ENVCRC-$(CONFIG_ENV_IS_IN_EEPROM) = y
25ENVCRC-$(CONFIG_ENV_IS_IN_FLASH) = y
26ENVCRC-$(CONFIG_ENV_IS_IN_ONENAND) = y
27ENVCRC-$(CONFIG_ENV_IS_IN_NAND) = y
28ENVCRC-$(CONFIG_ENV_IS_IN_NVRAM) = y
29ENVCRC-$(CONFIG_ENV_IS_IN_SPI_FLASH) = y
30CONFIG_BUILD_ENVCRC ?= $(ENVCRC-y)
31
32hostprogs-$(CONFIG_SPL_GENERATE_ATMEL_PMECC_HEADER) += atmel_pmecc_params
33
34hostprogs-$(CONFIG_CMD_LICENSE) += bin2header
35hostprogs-$(CONFIG_LCD_LOGO) += bmp_logo
36hostprogs-$(CONFIG_VIDEO_LOGO) += bmp_logo
37HOSTCFLAGS_bmp_logo.o := -pedantic
38
39hostprogs-$(CONFIG_BUILD_ENVCRC) += envcrc
40envcrc-objs := envcrc.o lib/crc32.o common/env_embedded.o lib/sha1.o
41
42hostprogs-$(CONFIG_CMD_NET) += gen_eth_addr
43HOSTCFLAGS_gen_eth_addr.o := -pedantic
44
45hostprogs-$(CONFIG_CMD_LOADS) += img2srec
46HOSTCFLAGS_img2srec.o := -pedantic
47
48hostprogs-$(CONFIG_XWAY_SWAP_BYTES) += xway-swap-bytes
49HOSTCFLAGS_xway-swap-bytes.o := -pedantic
50
51hostprogs-y += mkenvimage
52mkenvimage-objs := mkenvimage.o os_support.o lib/crc32.o
53
54hostprogs-y += dumpimage mkimage
55hostprogs-$(CONFIG_FIT_SIGNATURE) += fit_info fit_check_sign
56
57FIT_SIG_OBJS-$(CONFIG_FIT_SIGNATURE) := common/image-sig.o
58# Flattened device tree objects
59LIBFDT_OBJS := $(addprefix lib/libfdt/, \
60			fdt.o fdt_ro.o fdt_rw.o fdt_strerror.o fdt_wip.o \
61			fdt_region.o fdt_sw.o)
62RSA_OBJS-$(CONFIG_FIT_SIGNATURE) := $(addprefix lib/rsa/, \
63					rsa-sign.o rsa-verify.o rsa-checksum.o \
64					rsa-mod-exp.o)
65
66ROCKCHIP_OBS = lib/rc4.o rkcommon.o rkimage.o rksd.o rkspi.o
67
68# common objs for dumpimage and mkimage
69dumpimage-mkimage-objs := aisimage.o \
70			atmelimage.o \
71			$(FIT_SIG_OBJS-y) \
72			common/bootm.o \
73			lib/crc32.o \
74			default_image.o \
75			lib/fdtdec_common.o \
76			lib/fdtdec.o \
77			fit_common.o \
78			fit_image.o \
79			common/image-fit.o \
80			image-host.o \
81			common/image.o \
82			imagetool.o \
83			imximage.o \
84			kwbimage.o \
85			lib/md5.o \
86			lpc32xximage.o \
87			mxsimage.o \
88			omapimage.o \
89			os_support.o \
90			pblimage.o \
91			pbl_crc32.o \
92			$(ROCKCHIP_OBS) \
93			socfpgaimage.o \
94			lib/sha1.o \
95			lib/sha256.o \
96			common/hash.o \
97			ublimage.o \
98			zynqimage.o \
99			zynqmpimage.o \
100			$(LIBFDT_OBJS) \
101			gpimage.o \
102			gpimage-common.o \
103			$(RSA_OBJS-y)
104
105dumpimage-objs := $(dumpimage-mkimage-objs) dumpimage.o
106mkimage-objs   := $(dumpimage-mkimage-objs) mkimage.o
107fit_info-objs   := $(dumpimage-mkimage-objs) fit_info.o
108fit_check_sign-objs   := $(dumpimage-mkimage-objs) fit_check_sign.o
109
110hostprogs-$(CONFIG_SPL_OF_PLATDATA) += _libfdt.so
111_libfdt.so-sharedobjs += $(LIBFDT_OBJS)
112libfdt:
113
114tools/_libfdt.so: $(patsubst %.o,%.c,$(LIBFDT_OBJS)) tools/libfdt_wrap.c
115	python $(srctree)/lib/libfdt/setup.py "$(_hostc_flags)" $^
116	mv _libfdt.so $@
117
118tools/libfdt_wrap.c: $(srctree)/lib/libfdt/libfdt.swig
119	swig -python -o $@ $<
120
121# TODO(sjg@chromium.org): Is this correct on Mac OS?
122
123ifneq ($(CONFIG_MX23)$(CONFIG_MX28),)
124# Add CONFIG_MXS into host CFLAGS, so we can check whether or not register
125# the mxsimage support within tools/mxsimage.c .
126HOSTCFLAGS_mxsimage.o += -DCONFIG_MXS
127endif
128
129ifdef CONFIG_FIT_SIGNATURE
130# This affects include/image.h, but including the board config file
131# is tricky, so manually define this options here.
132HOST_EXTRACFLAGS	+= -DCONFIG_FIT_SIGNATURE
133endif
134
135ifdef CONFIG_SYS_U_BOOT_OFFS
136HOSTCFLAGS_kwbimage.o += -DCONFIG_SYS_U_BOOT_OFFS=$(CONFIG_SYS_U_BOOT_OFFS)
137endif
138
139# MXSImage needs LibSSL
140ifneq ($(CONFIG_MX23)$(CONFIG_MX28)$(CONFIG_FIT_SIGNATURE),)
141HOSTLOADLIBES_mkimage += \
142	$(shell pkg-config --libs libssl libcrypto 2> /dev/null || echo "-lssl -lcrypto")
143
144# OS X deprecate openssl in favour of CommonCrypto, supress deprecation
145# warnings on those systems
146ifeq ($(HOSTOS),darwin)
147HOSTCFLAGS_mxsimage.o += -Wno-deprecated-declarations
148HOSTCFLAGS_image-sig.o += -Wno-deprecated-declarations
149HOSTCFLAGS_rsa-sign.o += -Wno-deprecated-declarations
150endif
151endif
152
153HOSTLOADLIBES_dumpimage := $(HOSTLOADLIBES_mkimage)
154HOSTLOADLIBES_fit_info := $(HOSTLOADLIBES_mkimage)
155HOSTLOADLIBES_fit_check_sign := $(HOSTLOADLIBES_mkimage)
156
157hostprogs-$(CONFIG_EXYNOS5250) += mkexynosspl
158hostprogs-$(CONFIG_EXYNOS5420) += mkexynosspl
159HOSTCFLAGS_mkexynosspl.o := -pedantic
160
161ifdtool-objs := $(LIBFDT_OBJS) ifdtool.o
162hostprogs-$(CONFIG_X86) += ifdtool
163
164hostprogs-$(CONFIG_MX23) += mxsboot
165hostprogs-$(CONFIG_MX28) += mxsboot
166HOSTCFLAGS_mxsboot.o := -pedantic
167
168hostprogs-$(CONFIG_SUNXI) += mksunxiboot
169
170hostprogs-$(CONFIG_NETCONSOLE) += ncb
171hostprogs-$(CONFIG_SHA1_CHECK_UB_IMG) += ubsha1
172
173ubsha1-objs := os_support.o ubsha1.o lib/sha1.o
174
175HOSTCFLAGS_ubsha1.o := -pedantic
176
177hostprogs-$(CONFIG_KIRKWOOD) += kwboot
178hostprogs-$(CONFIG_ARCH_MVEBU) += kwboot
179hostprogs-y += proftool
180hostprogs-$(CONFIG_STATIC_RELA) += relocate-rela
181
182hostprogs-y += fdtgrep
183fdtgrep-objs += $(LIBFDT_OBJS) fdtgrep.o
184
185# We build some files with extra pedantic flags to try to minimize things
186# that won't build on some weird host compiler -- though there are lots of
187# exceptions for files that aren't complaint.
188HOSTCFLAGS_crc32.o := -pedantic
189HOSTCFLAGS_md5.o := -pedantic
190HOSTCFLAGS_sha1.o := -pedantic
191HOSTCFLAGS_sha256.o := -pedantic
192
193quiet_cmd_wrap = WRAP    $@
194cmd_wrap = echo "\#include <../$(patsubst $(obj)/%,%,$@)>" >$@
195
196$(obj)/lib/%.c $(obj)/common/%.c:
197	$(call cmd,wrap)
198
199clean-dirs := lib common
200
201always := $(hostprogs-y)
202
203# Generated LCD/video logo
204LOGO_H = $(objtree)/include/bmp_logo.h
205LOGO_DATA_H = $(objtree)/include/bmp_logo_data.h
206LOGO-$(CONFIG_LCD_LOGO) += $(LOGO_H)
207LOGO-$(CONFIG_LCD_LOGO) += $(LOGO_DATA_H)
208LOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_H)
209LOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_DATA_H)
210
211# Generic logo
212ifeq ($(LOGO_BMP),)
213LOGO_BMP= $(srctree)/$(src)/logos/denx.bmp
214
215# Use board logo and fallback to vendor
216ifneq ($(wildcard $(srctree)/$(src)/logos/$(BOARD).bmp),)
217LOGO_BMP= $(srctree)/$(src)/logos/$(BOARD).bmp
218else
219ifneq ($(wildcard $(srctree)/$(src)/logos/$(VENDOR).bmp),)
220LOGO_BMP= $(srctree)/$(src)/logos/$(VENDOR).bmp
221endif
222endif
223
224endif # !LOGO_BMP
225
226# Generated gziped GPL-2.0 license text
227LICENSE_H = $(objtree)/include/license.h
228LICENSE-$(CONFIG_CMD_LICENSE) += $(LICENSE_H)
229
230#
231# Use native tools and options
232# Define __KERNEL_STRICT_NAMES to prevent typedef overlaps
233# Define _GNU_SOURCE to obtain the getline prototype from stdio.h
234#
235HOST_EXTRACFLAGS += -include $(srctree)/include/libfdt_env.h \
236		$(patsubst -I%,-idirafter%, $(filter -I%, $(UBOOTINCLUDE))) \
237		-I$(srctree)/lib/libfdt \
238		-I$(srctree)/tools \
239		-DCONFIG_SYS_TEXT_BASE=$(CONFIG_SYS_TEXT_BASE) \
240		-DUSE_HOSTCC \
241		-D__KERNEL_STRICT_NAMES \
242		-D_GNU_SOURCE
243
244__build:	$(LOGO-y) $(LICENSE-y)
245
246$(LOGO_H):	$(obj)/bmp_logo $(LOGO_BMP)
247	$(obj)/bmp_logo --gen-info $(LOGO_BMP) > $@
248
249$(LOGO_DATA_H):	$(obj)/bmp_logo $(LOGO_BMP)
250	$(obj)/bmp_logo --gen-data $(LOGO_BMP) > $@
251
252$(LICENSE_H): $(obj)/bin2header $(srctree)/Licenses/gpl-2.0.txt
253	cat $(srctree)/Licenses/gpl-2.0.txt | gzip -9 -c | \
254		$(obj)/bin2header license_gzip > $(LICENSE_H)
255
256# Let clean descend into subdirs
257subdir- += env
258
259ifneq ($(CROSS_BUILD_TOOLS),)
260HOSTCC = $(CC)
261
262quiet_cmd_crosstools_strip = STRIP   $^
263      cmd_crosstools_strip = $(STRIP) $^; touch $@
264$(obj)/.strip: $(call objectify,$(filter $(always),$(hostprogs-y)))
265	$(call cmd,crosstools_strip)
266
267always += .strip
268endif
269clean-files += .strip
270