xref: /rk3399_rockchip-uboot/tools/Makefile (revision 467d16db4b9af3b408da34ab3df7febe3bd75929)
1efee1709Swdenk#
2f9328639SMarian Balakowicz# (C) Copyright 2000-2006
3efee1709Swdenk# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
4efee1709Swdenk#
51a459660SWolfgang Denk# SPDX-License-Identifier:	GPL-2.0+
6efee1709Swdenk#
7efee1709Swdenk
8c7c0d542SMike Frysinger# Enable all the config-independent tools
9c7c0d542SMike Frysingerifneq ($(HOST_TOOLS_ALL),)
10c7c0d542SMike FrysingerCONFIG_LCD_LOGO = y
11570d7d50SMike FrysingerCONFIG_CMD_LOADS = y
12c7c0d542SMike FrysingerCONFIG_CMD_NET = y
1360b74bdeSDaniel SchwierzeckCONFIG_XWAY_SWAP_BYTES = y
14c7c0d542SMike FrysingerCONFIG_NETCONSOLE = y
15c7c0d542SMike FrysingerCONFIG_SHA1_CHECK_UB_IMG = y
16d8c0d99eSAndre PrzywaraCONFIG_ARCH_SUNXI = y
17c7c0d542SMike Frysingerendif
18c7c0d542SMike Frysinger
192887c473SMasahiro Yamadasubdir-$(HOST_TOOLS_ALL) += easylogo
202887c473SMasahiro Yamadasubdir-$(HOST_TOOLS_ALL) += gdb
212887c473SMasahiro Yamada
222ad6e27dSMike Frysinger# Merge all the different vars for envcrc into one
232ad6e27dSMike FrysingerENVCRC-$(CONFIG_ENV_IS_EMBEDDED) = y
242ad6e27dSMike FrysingerENVCRC-$(CONFIG_ENV_IS_IN_EEPROM) = y
252ad6e27dSMike FrysingerENVCRC-$(CONFIG_ENV_IS_IN_FLASH) = y
262ad6e27dSMike FrysingerENVCRC-$(CONFIG_ENV_IS_IN_ONENAND) = y
272ad6e27dSMike FrysingerENVCRC-$(CONFIG_ENV_IS_IN_NAND) = y
282ad6e27dSMike FrysingerENVCRC-$(CONFIG_ENV_IS_IN_NVRAM) = y
292ad6e27dSMike FrysingerENVCRC-$(CONFIG_ENV_IS_IN_SPI_FLASH) = y
302ad6e27dSMike FrysingerCONFIG_BUILD_ENVCRC ?= $(ENVCRC-y)
312ad6e27dSMike Frysinger
3296b09a97SMasahiro Yamadahostprogs-$(CONFIG_SPL_GENERATE_ATMEL_PMECC_HEADER) += atmel_pmecc_params
335c390a5bSAndreas Bießmann
3496b09a97SMasahiro Yamadahostprogs-$(CONFIG_LCD_LOGO) += bmp_logo
3596b09a97SMasahiro Yamadahostprogs-$(CONFIG_VIDEO_LOGO) += bmp_logo
3696b09a97SMasahiro YamadaHOSTCFLAGS_bmp_logo.o := -pedantic
37ee3584a5SPeter Tyser
3896b09a97SMasahiro Yamadahostprogs-$(CONFIG_BUILD_ENVCRC) += envcrc
390649cd0dSSimon Glassenvcrc-objs := envcrc.o lib/crc32.o env/embedded.o lib/sha1.o
40940db16dSMasahiro Yamada
4196b09a97SMasahiro Yamadahostprogs-$(CONFIG_CMD_NET) += gen_eth_addr
4296b09a97SMasahiro YamadaHOSTCFLAGS_gen_eth_addr.o := -pedantic
43940db16dSMasahiro Yamada
44c25f01a6Soliver@schinagl.nlhostprogs-$(CONFIG_CMD_NET) += gen_ethaddr_crc
45c25f01a6Soliver@schinagl.nlgen_ethaddr_crc-objs := gen_ethaddr_crc.o lib/crc8.o
46c25f01a6Soliver@schinagl.nlHOSTCFLAGS_gen_ethaddr_crc.o := -pedantic
47c25f01a6Soliver@schinagl.nl
4896b09a97SMasahiro Yamadahostprogs-$(CONFIG_CMD_LOADS) += img2srec
4996b09a97SMasahiro YamadaHOSTCFLAGS_img2srec.o := -pedantic
50940db16dSMasahiro Yamada
5196b09a97SMasahiro Yamadahostprogs-$(CONFIG_XWAY_SWAP_BYTES) += xway-swap-bytes
5296b09a97SMasahiro YamadaHOSTCFLAGS_xway-swap-bytes.o := -pedantic
53940db16dSMasahiro Yamada
5496b09a97SMasahiro Yamadahostprogs-y += mkenvimage
5596b09a97SMasahiro Yamadamkenvimage-objs := mkenvimage.o os_support.o lib/crc32.o
56940db16dSMasahiro Yamada
5796b09a97SMasahiro Yamadahostprogs-y += dumpimage mkimage
5896b09a97SMasahiro Yamadahostprogs-$(CONFIG_FIT_SIGNATURE) += fit_info fit_check_sign
59940db16dSMasahiro Yamada
6023ba6841SJoseph Chen# Rockchip pack tools
6123ba6841SJoseph Chenifdef CONFIG_ARCH_ROCKCHIP
6223ba6841SJoseph Chenhostprogs-y += boot_merger
6323ba6841SJoseph Chenhostprogs-y += trust_merger
6423ba6841SJoseph Chenhostprogs-y += loaderimage
6523ba6841SJoseph Chenhostprogs-y += resource_tool
6623ba6841SJoseph Chen
6723ba6841SJoseph Chenboot_merger-objs := rockchip/boot_merger.o rockchip/sha2.o lib/sha256.o
6823ba6841SJoseph Chentrust_merger-objs := rockchip/trust_merger.o rockchip/sha2.o lib/sha256.o
6923ba6841SJoseph Chenloaderimage-objs := rockchip/loaderimage.o rockchip/sha.o lib/sha256.o rockchip/crc32_rk.o
70*467d16dbSJoseph Chenresource_tool-objs := rockchip/resource_tool.o
7123ba6841SJoseph Chenendif
7223ba6841SJoseph Chen
73ad80c4a3SMasahiro YamadaFIT_SIG_OBJS-$(CONFIG_FIT_SIGNATURE) := common/image-sig.o
74ee95d10bSSimon Glass
75141b0784SMasahiro Yamada# The following files are synced with upstream DTC.
76141b0784SMasahiro Yamada# Use synced versions from scripts/dtc/libfdt/.
774e2c3b8cSMasahiro YamadaLIBFDT_SRCS_SYNCED := fdt.c fdt_wip.c fdt_sw.c fdt_rw.c \
784e2c3b8cSMasahiro Yamada		fdt_strerror.c fdt_empty_tree.c fdt_addresses.c fdt_overlay.c
79141b0784SMasahiro Yamada# The following files are locally modified for U-Boot (unfotunately).
80141b0784SMasahiro Yamada# Use U-Boot own versions from lib/libfdt/.
814e2c3b8cSMasahiro YamadaLIBFDT_SRCS_UNSYNCED := fdt_ro.c fdt_region.c
82141b0784SMasahiro Yamada
83141b0784SMasahiro YamadaLIBFDT_OBJS := $(addprefix libfdt/, $(patsubst %.c, %.o, $(LIBFDT_SRCS_SYNCED))) \
84141b0784SMasahiro Yamada	       $(addprefix lib/libfdt/, $(patsubst %.c, %.o, $(LIBFDT_SRCS_UNSYNCED)))
85330274f1SSimon Glass
86ad80c4a3SMasahiro YamadaRSA_OBJS-$(CONFIG_FIT_SIGNATURE) := $(addprefix lib/rsa/, \
87fc2f4246SRuchika Gupta					rsa-sign.o rsa-verify.o rsa-checksum.o \
88fc2f4246SRuchika Gupta					rsa-mod-exp.o)
89940db16dSMasahiro Yamada
906f14746bSPaweł JaroszROCKCHIP_OBS = lib/rc4.o rkcommon.o rkimage.o rknand.o rksd.o rkspi.o
91a131c1f4SSimon Glass
92940db16dSMasahiro Yamada# common objs for dumpimage and mkimage
93940db16dSMasahiro Yamadadumpimage-mkimage-objs := aisimage.o \
947b1a4117SAndreas Bießmann			atmelimage.o \
95940db16dSMasahiro Yamada			$(FIT_SIG_OBJS-y) \
96ea51a628SSimon Glass			common/bootm.o \
97ad80c4a3SMasahiro Yamada			lib/crc32.o \
98940db16dSMasahiro Yamada			default_image.o \
99b047d671SHeiko Schocher			lib/fdtdec_common.o \
100ad80c4a3SMasahiro Yamada			lib/fdtdec.o \
1016bf4ca07SHeiko Schocher			fit_common.o \
102940db16dSMasahiro Yamada			fit_image.o \
103ad80c4a3SMasahiro Yamada			common/image-fit.o \
104940db16dSMasahiro Yamada			image-host.o \
105ad80c4a3SMasahiro Yamada			common/image.o \
106940db16dSMasahiro Yamada			imagetool.o \
107940db16dSMasahiro Yamada			imximage.o \
108940db16dSMasahiro Yamada			kwbimage.o \
109ad80c4a3SMasahiro Yamada			lib/md5.o \
11039f520bbSAlbert ARIBAUD \(3ADEV\)			lpc32xximage.o \
111940db16dSMasahiro Yamada			mxsimage.o \
112940db16dSMasahiro Yamada			omapimage.o \
113940db16dSMasahiro Yamada			os_support.o \
114940db16dSMasahiro Yamada			pblimage.o \
115abbc67eeSCharles Manning			pbl_crc32.o \
116ed0c2c0aSAlbert ARIBAUD \(3ADEV\)			vybridimage.o \
117a131c1f4SSimon Glass			$(ROCKCHIP_OBS) \
118832472a9SCharles Manning			socfpgaimage.o \
119ad80c4a3SMasahiro Yamada			lib/sha1.o \
120ad80c4a3SMasahiro Yamada			lib/sha256.o \
1212dd90027SRuchika Gupta			common/hash.o \
122940db16dSMasahiro Yamada			ublimage.o \
12366eef1e7SNathan Rossi			zynqimage.o \
124d9b58b30SMichal Simek			zynqmpimage.o \
125940db16dSMasahiro Yamada			$(LIBFDT_OBJS) \
126969cd1faSStefano Babic			gpimage.o \
127969cd1faSStefano Babic			gpimage-common.o \
128940db16dSMasahiro Yamada			$(RSA_OBJS-y)
129940db16dSMasahiro Yamada
13096b09a97SMasahiro Yamadadumpimage-objs := $(dumpimage-mkimage-objs) dumpimage.o
13196b09a97SMasahiro Yamadamkimage-objs   := $(dumpimage-mkimage-objs) mkimage.o
13296b09a97SMasahiro Yamadafit_info-objs   := $(dumpimage-mkimage-objs) fit_info.o
13396b09a97SMasahiro Yamadafit_check_sign-objs   := $(dumpimage-mkimage-objs) fit_check_sign.o
134940db16dSMasahiro Yamada
135940db16dSMasahiro Yamadaifneq ($(CONFIG_MX23)$(CONFIG_MX28),)
136940db16dSMasahiro Yamada# Add CONFIG_MXS into host CFLAGS, so we can check whether or not register
137940db16dSMasahiro Yamada# the mxsimage support within tools/mxsimage.c .
1386825a95bSMasahiro YamadaHOSTCFLAGS_mxsimage.o += -DCONFIG_MXS
139940db16dSMasahiro Yamadaendif
140940db16dSMasahiro Yamada
141940db16dSMasahiro Yamadaifdef CONFIG_FIT_SIGNATURE
142940db16dSMasahiro Yamada# This affects include/image.h, but including the board config file
143940db16dSMasahiro Yamada# is tricky, so manually define this options here.
144940db16dSMasahiro YamadaHOST_EXTRACFLAGS	+= -DCONFIG_FIT_SIGNATURE
145940db16dSMasahiro Yamadaendif
146940db16dSMasahiro Yamada
1477ddf8cfbSStefan Roeseifdef CONFIG_SYS_U_BOOT_OFFS
1487ddf8cfbSStefan RoeseHOSTCFLAGS_kwbimage.o += -DCONFIG_SYS_U_BOOT_OFFS=$(CONFIG_SYS_U_BOOT_OFFS)
149e35c6c79STom Riniendif
150e35c6c79STom Rini
151a1b6b0a9SMario Sixifneq ($(CONFIG_ARMADA_38X)$(CONFIG_ARMADA_39X),)
152a1b6b0a9SMario SixHOSTCFLAGS_kwbimage.o += -DCONFIG_KWB_SECURE
153a1b6b0a9SMario Sixendif
154a1b6b0a9SMario Six
15597cb4e54SMasahiro Yamada# MXSImage needs LibSSL
156a1b6b0a9SMario Sixifneq ($(CONFIG_MX23)$(CONFIG_MX28)$(CONFIG_ARMADA_38X)$(CONFIG_ARMADA_39X)$(CONFIG_FIT_SIGNATURE),)
1574839836aSThomas PetazzoniHOSTLOADLIBES_mkimage += \
1584839836aSThomas Petazzoni	$(shell pkg-config --libs libssl libcrypto 2> /dev/null || echo "-lssl -lcrypto")
159c6e3e821SAndreas Bießmann
160c6e3e821SAndreas Bießmann# OS X deprecate openssl in favour of CommonCrypto, supress deprecation
161c6e3e821SAndreas Bießmann# warnings on those systems
162c6e3e821SAndreas Bießmannifeq ($(HOSTOS),darwin)
163c6e3e821SAndreas BießmannHOSTCFLAGS_mxsimage.o += -Wno-deprecated-declarations
164c6e3e821SAndreas BießmannHOSTCFLAGS_image-sig.o += -Wno-deprecated-declarations
165c6e3e821SAndreas BießmannHOSTCFLAGS_rsa-sign.o += -Wno-deprecated-declarations
166c6e3e821SAndreas Bießmannendif
16797cb4e54SMasahiro Yamadaendif
16897cb4e54SMasahiro Yamada
169f8470aeeSTom RiniHOSTCFLAGS_fit_image.o += -DMKIMAGE_DTC=\"$(CONFIG_MKIMAGE_DTC_PATH)\"
17047a52cd1SEmmanuel Vadot
17196b09a97SMasahiro YamadaHOSTLOADLIBES_dumpimage := $(HOSTLOADLIBES_mkimage)
17296b09a97SMasahiro YamadaHOSTLOADLIBES_fit_info := $(HOSTLOADLIBES_mkimage)
17396b09a97SMasahiro YamadaHOSTLOADLIBES_fit_check_sign := $(HOSTLOADLIBES_mkimage)
17497cb4e54SMasahiro Yamada
17596b09a97SMasahiro Yamadahostprogs-$(CONFIG_EXYNOS5250) += mkexynosspl
17696b09a97SMasahiro Yamadahostprogs-$(CONFIG_EXYNOS5420) += mkexynosspl
17796b09a97SMasahiro YamadaHOSTCFLAGS_mkexynosspl.o := -pedantic
178940db16dSMasahiro Yamada
17931eca697SSimon Glassifdtool-objs := $(LIBFDT_OBJS) ifdtool.o
180cd392fe8SSimon Glasshostprogs-$(CONFIG_X86) += ifdtool
181cd392fe8SSimon Glass
18296b09a97SMasahiro Yamadahostprogs-$(CONFIG_MX23) += mxsboot
18396b09a97SMasahiro Yamadahostprogs-$(CONFIG_MX28) += mxsboot
18496b09a97SMasahiro YamadaHOSTCFLAGS_mxsboot.o := -pedantic
185940db16dSMasahiro Yamada
186aec9a0f1SJagan Tekihostprogs-$(CONFIG_ARCH_SUNXI) += mksunxiboot
187594b4cc7SMaxime Ripardhostprogs-$(CONFIG_ARCH_SUNXI) += sunxi-spl-image-builder
188594b4cc7SMaxime Ripardsunxi-spl-image-builder-objs := sunxi-spl-image-builder.o lib/bch.o
18950827a59SIan Campbell
19096b09a97SMasahiro Yamadahostprogs-$(CONFIG_NETCONSOLE) += ncb
19196b09a97SMasahiro Yamadahostprogs-$(CONFIG_SHA1_CHECK_UB_IMG) += ubsha1
192940db16dSMasahiro Yamada
19396b09a97SMasahiro Yamadaubsha1-objs := os_support.o ubsha1.o lib/sha1.o
194940db16dSMasahiro Yamada
195940db16dSMasahiro YamadaHOSTCFLAGS_ubsha1.o := -pedantic
196940db16dSMasahiro Yamada
19796b09a97SMasahiro Yamadahostprogs-$(CONFIG_KIRKWOOD) += kwboot
19881e33f4bSStefan Roesehostprogs-$(CONFIG_ARCH_MVEBU) += kwboot
19996b09a97SMasahiro Yamadahostprogs-y += proftool
20096b09a97SMasahiro Yamadahostprogs-$(CONFIG_STATIC_RELA) += relocate-rela
201940db16dSMasahiro Yamada
2021043d0a0SSimon Glasshostprogs-y += fdtgrep
2031043d0a0SSimon Glassfdtgrep-objs += $(LIBFDT_OBJS) fdtgrep.o
2041043d0a0SSimon Glass
205703ec9ddSPaul Burtonhostprogs-$(CONFIG_MIPS) += mips-relocs
206703ec9ddSPaul Burton
207940db16dSMasahiro Yamada# We build some files with extra pedantic flags to try to minimize things
208940db16dSMasahiro Yamada# that won't build on some weird host compiler -- though there are lots of
209940db16dSMasahiro Yamada# exceptions for files that aren't complaint.
210940db16dSMasahiro YamadaHOSTCFLAGS_crc32.o := -pedantic
2111d3c5392Soliver@schinagl.nlHOSTCFLAGS_crc8.o := -pedantic
212940db16dSMasahiro YamadaHOSTCFLAGS_md5.o := -pedantic
213940db16dSMasahiro YamadaHOSTCFLAGS_sha1.o := -pedantic
2142842c1c2SHeiko SchocherHOSTCFLAGS_sha256.o := -pedantic
215ee3584a5SPeter Tyser
216ad80c4a3SMasahiro Yamadaquiet_cmd_wrap = WRAP    $@
217ffe29ebcSMasahiro Yamadacmd_wrap = echo "\#include <../$(patsubst $(obj)/%,%,$@)>" >$@
218ad80c4a3SMasahiro Yamada
2190649cd0dSSimon Glass$(obj)/lib/%.c $(obj)/common/%.c $(obj)/env/%.c:
220ad80c4a3SMasahiro Yamada	$(call cmd,wrap)
221ad80c4a3SMasahiro Yamada
222ad80c4a3SMasahiro Yamadaclean-dirs := lib common
223ad80c4a3SMasahiro Yamada
224940db16dSMasahiro Yamadaalways := $(hostprogs-y)
22519c402afSSimon Glass
226335ffe7eSPeter Tyser# Generated LCD/video logo
2279e414032SMasahiro YamadaLOGO_H = $(objtree)/include/bmp_logo.h
2289e414032SMasahiro YamadaLOGO_DATA_H = $(objtree)/include/bmp_logo_data.h
229335ffe7eSPeter TyserLOGO-$(CONFIG_LCD_LOGO) += $(LOGO_H)
230c270730fSChe-Liang ChiouLOGO-$(CONFIG_LCD_LOGO) += $(LOGO_DATA_H)
231335ffe7eSPeter TyserLOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_H)
232c270730fSChe-Liang ChiouLOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_DATA_H)
233ee3584a5SPeter Tyser
23496903daeSOtavio Salvador# Generic logo
235ee3584a5SPeter Tyserifeq ($(LOGO_BMP),)
2369e414032SMasahiro YamadaLOGO_BMP= $(srctree)/$(src)/logos/denx.bmp
23796903daeSOtavio Salvador
23896903daeSOtavio Salvador# Use board logo and fallback to vendor
239603f51cbSMasahiro Yamadaifneq ($(wildcard $(srctree)/$(src)/logos/$(BOARD).bmp),)
2409e414032SMasahiro YamadaLOGO_BMP= $(srctree)/$(src)/logos/$(BOARD).bmp
24196903daeSOtavio Salvadorelse
242603f51cbSMasahiro Yamadaifneq ($(wildcard $(srctree)/$(src)/logos/$(VENDOR).bmp),)
2439e414032SMasahiro YamadaLOGO_BMP= $(srctree)/$(src)/logos/$(VENDOR).bmp
244ee3584a5SPeter Tyserendif
245ee3584a5SPeter Tyserendif
24696903daeSOtavio Salvador
24796903daeSOtavio Salvadorendif # !LOGO_BMP
248ee3584a5SPeter Tyser
249efee1709Swdenk#
250efee1709Swdenk# Use native tools and options
2512f8d396bSPeter Tyser# Define __KERNEL_STRICT_NAMES to prevent typedef overlaps
2522db1c3fcSYork Sun# Define _GNU_SOURCE to obtain the getline prototype from stdio.h
253efee1709Swdenk#
254fbedfcfbSMasahiro YamadaHOST_EXTRACFLAGS += -include $(srctree)/include/compiler.h \
25551148790SMasahiro Yamada		$(patsubst -I%,-idirafter%, $(filter -I%, $(UBOOTINCLUDE))) \
256fe47e2a1SPaul Kocialkowski		-I$(srctree)/scripts/dtc/libfdt \
25701286329SMasahiro Yamada		-I$(srctree)/tools \
25814d0a02aSWolfgang Denk		-DUSE_HOSTCC \
2592db1c3fcSYork Sun		-D__KERNEL_STRICT_NAMES \
2602db1c3fcSYork Sun		-D_GNU_SOURCE
2618cf30809SBartlomiej Sieka
262d726f225SMasahiro Yamada__build:	$(LOGO-y)
263efee1709Swdenk
2649e414032SMasahiro Yamada$(LOGO_H):	$(obj)/bmp_logo $(LOGO_BMP)
2659e414032SMasahiro Yamada	$(obj)/bmp_logo --gen-info $(LOGO_BMP) > $@
266c270730fSChe-Liang Chiou
2679e414032SMasahiro Yamada$(LOGO_DATA_H):	$(obj)/bmp_logo $(LOGO_BMP)
2689e414032SMasahiro Yamada	$(obj)/bmp_logo --gen-data $(LOGO_BMP) > $@
2692887c473SMasahiro Yamada
2702887c473SMasahiro Yamada# Let clean descend into subdirs
2712887c473SMasahiro Yamadasubdir- += env
272db5b339cSMasahiro Yamada
273db5b339cSMasahiro Yamadaifneq ($(CROSS_BUILD_TOOLS),)
2743b082529SMasahiro Yamadaoverride HOSTCC = $(CC)
275db5b339cSMasahiro Yamada
276db5b339cSMasahiro Yamadaquiet_cmd_crosstools_strip = STRIP   $^
277db5b339cSMasahiro Yamada      cmd_crosstools_strip = $(STRIP) $^; touch $@
278db5b339cSMasahiro Yamada$(obj)/.strip: $(call objectify,$(filter $(always),$(hostprogs-y)))
279db5b339cSMasahiro Yamada	$(call cmd,crosstools_strip)
280db5b339cSMasahiro Yamada
281db5b339cSMasahiro Yamadaalways += .strip
282db5b339cSMasahiro Yamadaendif
283db5b339cSMasahiro Yamadaclean-files += .strip
284