xref: /rk3399_rockchip-uboot/tools/Makefile (revision 473221da5a5a767b650f97c0a6e63b0854c2221a)
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
16CONFIG_ARCH_SUNXI = y
17endif
18
19subdir-$(HOST_TOOLS_ALL) += easylogo
20subdir-$(HOST_TOOLS_ALL) += gdb
21
22# Merge all the different vars for envcrc into one
23ENVCRC-$(CONFIG_ENV_IS_EMBEDDED) = 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_LCD_LOGO) += bmp_logo
35hostprogs-$(CONFIG_VIDEO_LOGO) += bmp_logo
36HOSTCFLAGS_bmp_logo.o := -pedantic
37
38hostprogs-$(CONFIG_BUILD_ENVCRC) += envcrc
39envcrc-objs := envcrc.o lib/crc32.o env/embedded.o lib/sha1.o
40
41hostprogs-$(CONFIG_CMD_NET) += gen_eth_addr
42HOSTCFLAGS_gen_eth_addr.o := -pedantic
43
44hostprogs-$(CONFIG_CMD_NET) += gen_ethaddr_crc
45gen_ethaddr_crc-objs := gen_ethaddr_crc.o lib/crc8.o
46HOSTCFLAGS_gen_ethaddr_crc.o := -pedantic
47
48hostprogs-$(CONFIG_CMD_LOADS) += img2srec
49HOSTCFLAGS_img2srec.o := -pedantic
50
51hostprogs-$(CONFIG_XWAY_SWAP_BYTES) += xway-swap-bytes
52HOSTCFLAGS_xway-swap-bytes.o := -pedantic
53
54hostprogs-y += mkenvimage
55mkenvimage-objs := mkenvimage.o os_support.o lib/crc32.o
56
57hostprogs-y += dumpimage mkimage
58hostprogs-$(CONFIG_FIT_SIGNATURE) += fit_info fit_check_sign
59
60# Rockchip pack tools
61ifdef CONFIG_ARCH_ROCKCHIP
62hostprogs-y += boot_merger
63hostprogs-y += trust_merger
64hostprogs-y += loaderimage
65hostprogs-y += resource_tool
66
67boot_merger-objs := rockchip/boot_merger.o rockchip/sha2.o lib/sha256.o
68trust_merger-objs := rockchip/trust_merger.o rockchip/sha2.o lib/sha256.o
69loaderimage-objs := rockchip/loaderimage.o rockchip/sha.o lib/sha256.o rockchip/crc32_rk.o
70resource_tool-objs := rockchip/resource_tool.o
71endif
72
73FIT_SIG_OBJS-$(CONFIG_FIT_SIGNATURE) := common/image-sig.o
74
75# The following files are synced with upstream DTC.
76# Use synced versions from scripts/dtc/libfdt/.
77LIBFDT_SRCS_SYNCED := fdt.c fdt_wip.c fdt_sw.c fdt_rw.c \
78		fdt_strerror.c fdt_empty_tree.c fdt_addresses.c fdt_overlay.c
79# The following files are locally modified for U-Boot (unfotunately).
80# Use U-Boot own versions from lib/libfdt/.
81LIBFDT_SRCS_UNSYNCED := fdt_ro.c fdt_region.c
82
83LIBFDT_OBJS := $(addprefix libfdt/, $(patsubst %.c, %.o, $(LIBFDT_SRCS_SYNCED))) \
84	       $(addprefix lib/libfdt/, $(patsubst %.c, %.o, $(LIBFDT_SRCS_UNSYNCED)))
85
86RSA_OBJS-$(CONFIG_FIT_SIGNATURE) := $(addprefix lib/rsa/, \
87					rsa-sign.o rsa-verify.o rsa-checksum.o \
88					rsa-mod-exp.o)
89
90ROCKCHIP_OBS = lib/rc4.o rkcommon.o rkimage.o rknand.o rksd.o rkspi.o
91
92# common objs for dumpimage and mkimage
93dumpimage-mkimage-objs := aisimage.o \
94			atmelimage.o \
95			$(FIT_SIG_OBJS-y) \
96			common/bootm.o \
97			lib/crc32.o \
98			default_image.o \
99			lib/fdtdec_common.o \
100			lib/fdtdec.o \
101			fit_common.o \
102			fit_image.o \
103			common/image-fit.o \
104			image-host.o \
105			common/image.o \
106			imagetool.o \
107			imximage.o \
108			kwbimage.o \
109			lib/md5.o \
110			lpc32xximage.o \
111			mxsimage.o \
112			omapimage.o \
113			os_support.o \
114			pblimage.o \
115			pbl_crc32.o \
116			vybridimage.o \
117			$(ROCKCHIP_OBS) \
118			socfpgaimage.o \
119			lib/sha1.o \
120			lib/sha256.o \
121			common/hash.o \
122			ublimage.o \
123			zynqimage.o \
124			zynqmpimage.o \
125			$(LIBFDT_OBJS) \
126			gpimage.o \
127			gpimage-common.o \
128			$(RSA_OBJS-y)
129
130dumpimage-objs := $(dumpimage-mkimage-objs) dumpimage.o
131mkimage-objs   := $(dumpimage-mkimage-objs) mkimage.o
132fit_info-objs   := $(dumpimage-mkimage-objs) fit_info.o
133fit_check_sign-objs   := $(dumpimage-mkimage-objs) fit_check_sign.o
134
135ifneq ($(CONFIG_MX23)$(CONFIG_MX28),)
136# Add CONFIG_MXS into host CFLAGS, so we can check whether or not register
137# the mxsimage support within tools/mxsimage.c .
138HOSTCFLAGS_mxsimage.o += -DCONFIG_MXS
139endif
140
141ifdef CONFIG_FIT_SIGNATURE
142# This affects include/image.h, but including the board config file
143# is tricky, so manually define this options here.
144HOST_EXTRACFLAGS	+= -DCONFIG_FIT_SIGNATURE
145endif
146
147ifdef CONFIG_SYS_U_BOOT_OFFS
148HOSTCFLAGS_kwbimage.o += -DCONFIG_SYS_U_BOOT_OFFS=$(CONFIG_SYS_U_BOOT_OFFS)
149endif
150
151ifneq ($(CONFIG_ARMADA_38X)$(CONFIG_ARMADA_39X),)
152HOSTCFLAGS_kwbimage.o += -DCONFIG_KWB_SECURE
153endif
154
155# MXSImage needs LibSSL
156ifneq ($(CONFIG_MX23)$(CONFIG_MX28)$(CONFIG_ARMADA_38X)$(CONFIG_ARMADA_39X)$(CONFIG_FIT_SIGNATURE),)
157HOSTLOADLIBES_mkimage += \
158	$(shell pkg-config --libs libssl libcrypto 2> /dev/null || echo "-lssl -lcrypto")
159
160# OS X deprecate openssl in favour of CommonCrypto, supress deprecation
161# warnings on those systems
162ifeq ($(HOSTOS),darwin)
163HOSTCFLAGS_mxsimage.o += -Wno-deprecated-declarations
164HOSTCFLAGS_image-sig.o += -Wno-deprecated-declarations
165HOSTCFLAGS_rsa-sign.o += -Wno-deprecated-declarations
166endif
167endif
168
169HOSTCFLAGS_fit_image.o += -DMKIMAGE_DTC=\"$(CONFIG_MKIMAGE_DTC_PATH)\"
170
171HOSTLOADLIBES_dumpimage := $(HOSTLOADLIBES_mkimage)
172HOSTLOADLIBES_fit_info := $(HOSTLOADLIBES_mkimage)
173HOSTLOADLIBES_fit_check_sign := $(HOSTLOADLIBES_mkimage)
174
175hostprogs-$(CONFIG_EXYNOS5250) += mkexynosspl
176hostprogs-$(CONFIG_EXYNOS5420) += mkexynosspl
177HOSTCFLAGS_mkexynosspl.o := -pedantic
178
179ifdtool-objs := $(LIBFDT_OBJS) ifdtool.o
180hostprogs-$(CONFIG_X86) += ifdtool
181
182hostprogs-$(CONFIG_MX23) += mxsboot
183hostprogs-$(CONFIG_MX28) += mxsboot
184HOSTCFLAGS_mxsboot.o := -pedantic
185
186hostprogs-$(CONFIG_ARCH_SUNXI) += mksunxiboot
187hostprogs-$(CONFIG_ARCH_SUNXI) += sunxi-spl-image-builder
188sunxi-spl-image-builder-objs := sunxi-spl-image-builder.o lib/bch.o
189
190hostprogs-$(CONFIG_NETCONSOLE) += ncb
191hostprogs-$(CONFIG_SHA1_CHECK_UB_IMG) += ubsha1
192
193ubsha1-objs := os_support.o ubsha1.o lib/sha1.o
194
195HOSTCFLAGS_ubsha1.o := -pedantic
196
197hostprogs-$(CONFIG_KIRKWOOD) += kwboot
198hostprogs-$(CONFIG_ARCH_MVEBU) += kwboot
199hostprogs-y += proftool
200hostprogs-$(CONFIG_STATIC_RELA) += relocate-rela
201
202hostprogs-y += fdtgrep
203fdtgrep-objs += $(LIBFDT_OBJS) fdtgrep.o
204
205hostprogs-$(CONFIG_MIPS) += mips-relocs
206
207# We build some files with extra pedantic flags to try to minimize things
208# that won't build on some weird host compiler -- though there are lots of
209# exceptions for files that aren't complaint.
210HOSTCFLAGS_crc32.o := -pedantic
211HOSTCFLAGS_crc8.o := -pedantic
212HOSTCFLAGS_md5.o := -pedantic
213HOSTCFLAGS_sha1.o := -pedantic
214HOSTCFLAGS_sha256.o := -pedantic
215
216quiet_cmd_wrap = WRAP    $@
217cmd_wrap = echo "\#include <../$(patsubst $(obj)/%,%,$@)>" >$@
218
219$(obj)/lib/%.c $(obj)/common/%.c $(obj)/env/%.c:
220	$(call cmd,wrap)
221
222clean-dirs := lib common
223
224always := $(hostprogs-y)
225
226# Generated LCD/video logo
227LOGO_H = $(objtree)/include/bmp_logo.h
228LOGO_DATA_H = $(objtree)/include/bmp_logo_data.h
229LOGO-$(CONFIG_LCD_LOGO) += $(LOGO_H)
230LOGO-$(CONFIG_LCD_LOGO) += $(LOGO_DATA_H)
231LOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_H)
232LOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_DATA_H)
233
234# Generic logo
235ifeq ($(LOGO_BMP),)
236LOGO_BMP= $(srctree)/$(src)/logos/denx.bmp
237
238# Use board logo and fallback to vendor
239ifneq ($(wildcard $(srctree)/$(src)/logos/$(BOARD).bmp),)
240LOGO_BMP= $(srctree)/$(src)/logos/$(BOARD).bmp
241else
242ifneq ($(wildcard $(srctree)/$(src)/logos/$(VENDOR).bmp),)
243LOGO_BMP= $(srctree)/$(src)/logos/$(VENDOR).bmp
244endif
245endif
246
247endif # !LOGO_BMP
248
249#
250# Use native tools and options
251# Define __KERNEL_STRICT_NAMES to prevent typedef overlaps
252# Define _GNU_SOURCE to obtain the getline prototype from stdio.h
253#
254HOST_EXTRACFLAGS += -include $(srctree)/include/compiler.h \
255		$(patsubst -I%,-idirafter%, $(filter -I%, $(UBOOTINCLUDE))) \
256		-I$(srctree)/scripts/dtc/libfdt \
257		-I$(srctree)/tools \
258		-DUSE_HOSTCC \
259		-D__KERNEL_STRICT_NAMES \
260		-D_GNU_SOURCE
261
262__build:	$(LOGO-y)
263
264$(LOGO_H):	$(obj)/bmp_logo $(LOGO_BMP)
265	$(obj)/bmp_logo --gen-info $(LOGO_BMP) > $@
266
267$(LOGO_DATA_H):	$(obj)/bmp_logo $(LOGO_BMP)
268	$(obj)/bmp_logo --gen-data $(LOGO_BMP) > $@
269
270# Let clean descend into subdirs
271subdir- += env
272
273ifneq ($(CROSS_BUILD_TOOLS),)
274override HOSTCC = $(CC)
275
276quiet_cmd_crosstools_strip = STRIP   $^
277      cmd_crosstools_strip = $(STRIP) $^; touch $@
278$(obj)/.strip: $(call objectify,$(filter $(always),$(hostprogs-y)))
279	$(call cmd,crosstools_strip)
280
281always += .strip
282endif
283clean-files += .strip
284