xref: /rk3399_rockchip-uboot/tools/Makefile (revision fbedfcfba2a6f4d773323cde922570a76c1ef357)
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 Chenhostprogs-y += checksum
6723ba6841SJoseph Chen
6823ba6841SJoseph Chenboot_merger-objs := rockchip/boot_merger.o rockchip/sha2.o lib/sha256.o
6923ba6841SJoseph Chentrust_merger-objs := rockchip/trust_merger.o rockchip/sha2.o lib/sha256.o
7023ba6841SJoseph Chenloaderimage-objs := rockchip/loaderimage.o rockchip/sha.o lib/sha256.o rockchip/crc32_rk.o
7123ba6841SJoseph Chenresource_tool-objs := rockchip/resource_tool.o
7223ba6841SJoseph Chenchecksum-objs := rockchip/checksum.o rockchip/crc32_rk.o
7323ba6841SJoseph Chenendif
7423ba6841SJoseph Chen
75ad80c4a3SMasahiro YamadaFIT_SIG_OBJS-$(CONFIG_FIT_SIGNATURE) := common/image-sig.o
76ee95d10bSSimon Glass
77141b0784SMasahiro Yamada# The following files are synced with upstream DTC.
78141b0784SMasahiro Yamada# Use synced versions from scripts/dtc/libfdt/.
7970b70db6SMasahiro YamadaLIBFDT_SRCS_SYNCED := fdt.c fdt_wip.c fdt_sw.c fdt_strerror.c fdt_empty_tree.c \
80141b0784SMasahiro Yamada		      fdt_addresses.c fdt_overlay.c
81141b0784SMasahiro Yamada# The following files are locally modified for U-Boot (unfotunately).
82141b0784SMasahiro Yamada# Use U-Boot own versions from lib/libfdt/.
8370b70db6SMasahiro YamadaLIBFDT_SRCS_UNSYNCED := fdt_ro.c fdt_rw.c fdt_region.c
84141b0784SMasahiro Yamada
85141b0784SMasahiro YamadaLIBFDT_OBJS := $(addprefix libfdt/, $(patsubst %.c, %.o, $(LIBFDT_SRCS_SYNCED))) \
86141b0784SMasahiro Yamada	       $(addprefix lib/libfdt/, $(patsubst %.c, %.o, $(LIBFDT_SRCS_UNSYNCED)))
87330274f1SSimon Glass
88ad80c4a3SMasahiro YamadaRSA_OBJS-$(CONFIG_FIT_SIGNATURE) := $(addprefix lib/rsa/, \
89fc2f4246SRuchika Gupta					rsa-sign.o rsa-verify.o rsa-checksum.o \
90fc2f4246SRuchika Gupta					rsa-mod-exp.o)
91940db16dSMasahiro Yamada
926f14746bSPaweł JaroszROCKCHIP_OBS = lib/rc4.o rkcommon.o rkimage.o rknand.o rksd.o rkspi.o
93a131c1f4SSimon Glass
94940db16dSMasahiro Yamada# common objs for dumpimage and mkimage
95940db16dSMasahiro Yamadadumpimage-mkimage-objs := aisimage.o \
967b1a4117SAndreas Bießmann			atmelimage.o \
97940db16dSMasahiro Yamada			$(FIT_SIG_OBJS-y) \
98ea51a628SSimon Glass			common/bootm.o \
99ad80c4a3SMasahiro Yamada			lib/crc32.o \
100940db16dSMasahiro Yamada			default_image.o \
101b047d671SHeiko Schocher			lib/fdtdec_common.o \
102ad80c4a3SMasahiro Yamada			lib/fdtdec.o \
1036bf4ca07SHeiko Schocher			fit_common.o \
104940db16dSMasahiro Yamada			fit_image.o \
105ad80c4a3SMasahiro Yamada			common/image-fit.o \
106940db16dSMasahiro Yamada			image-host.o \
107ad80c4a3SMasahiro Yamada			common/image.o \
108940db16dSMasahiro Yamada			imagetool.o \
109940db16dSMasahiro Yamada			imximage.o \
110940db16dSMasahiro Yamada			kwbimage.o \
111ad80c4a3SMasahiro Yamada			lib/md5.o \
11239f520bbSAlbert ARIBAUD \(3ADEV\)			lpc32xximage.o \
113940db16dSMasahiro Yamada			mxsimage.o \
114940db16dSMasahiro Yamada			omapimage.o \
115940db16dSMasahiro Yamada			os_support.o \
116940db16dSMasahiro Yamada			pblimage.o \
117abbc67eeSCharles Manning			pbl_crc32.o \
118ed0c2c0aSAlbert ARIBAUD \(3ADEV\)			vybridimage.o \
119a131c1f4SSimon Glass			$(ROCKCHIP_OBS) \
120832472a9SCharles Manning			socfpgaimage.o \
121ad80c4a3SMasahiro Yamada			lib/sha1.o \
122ad80c4a3SMasahiro Yamada			lib/sha256.o \
1232dd90027SRuchika Gupta			common/hash.o \
124940db16dSMasahiro Yamada			ublimage.o \
12566eef1e7SNathan Rossi			zynqimage.o \
126d9b58b30SMichal Simek			zynqmpimage.o \
127940db16dSMasahiro Yamada			$(LIBFDT_OBJS) \
128969cd1faSStefano Babic			gpimage.o \
129969cd1faSStefano Babic			gpimage-common.o \
130940db16dSMasahiro Yamada			$(RSA_OBJS-y)
131940db16dSMasahiro Yamada
13296b09a97SMasahiro Yamadadumpimage-objs := $(dumpimage-mkimage-objs) dumpimage.o
13396b09a97SMasahiro Yamadamkimage-objs   := $(dumpimage-mkimage-objs) mkimage.o
13496b09a97SMasahiro Yamadafit_info-objs   := $(dumpimage-mkimage-objs) fit_info.o
13596b09a97SMasahiro Yamadafit_check_sign-objs   := $(dumpimage-mkimage-objs) fit_check_sign.o
136940db16dSMasahiro Yamada
137940db16dSMasahiro Yamadaifneq ($(CONFIG_MX23)$(CONFIG_MX28),)
138940db16dSMasahiro Yamada# Add CONFIG_MXS into host CFLAGS, so we can check whether or not register
139940db16dSMasahiro Yamada# the mxsimage support within tools/mxsimage.c .
1406825a95bSMasahiro YamadaHOSTCFLAGS_mxsimage.o += -DCONFIG_MXS
141940db16dSMasahiro Yamadaendif
142940db16dSMasahiro Yamada
143940db16dSMasahiro Yamadaifdef CONFIG_FIT_SIGNATURE
144940db16dSMasahiro Yamada# This affects include/image.h, but including the board config file
145940db16dSMasahiro Yamada# is tricky, so manually define this options here.
146940db16dSMasahiro YamadaHOST_EXTRACFLAGS	+= -DCONFIG_FIT_SIGNATURE
147940db16dSMasahiro Yamadaendif
148940db16dSMasahiro Yamada
1497ddf8cfbSStefan Roeseifdef CONFIG_SYS_U_BOOT_OFFS
1507ddf8cfbSStefan RoeseHOSTCFLAGS_kwbimage.o += -DCONFIG_SYS_U_BOOT_OFFS=$(CONFIG_SYS_U_BOOT_OFFS)
151e35c6c79STom Riniendif
152e35c6c79STom Rini
153a1b6b0a9SMario Sixifneq ($(CONFIG_ARMADA_38X)$(CONFIG_ARMADA_39X),)
154a1b6b0a9SMario SixHOSTCFLAGS_kwbimage.o += -DCONFIG_KWB_SECURE
155a1b6b0a9SMario Sixendif
156a1b6b0a9SMario Six
15797cb4e54SMasahiro Yamada# MXSImage needs LibSSL
158a1b6b0a9SMario Sixifneq ($(CONFIG_MX23)$(CONFIG_MX28)$(CONFIG_ARMADA_38X)$(CONFIG_ARMADA_39X)$(CONFIG_FIT_SIGNATURE),)
1594839836aSThomas PetazzoniHOSTLOADLIBES_mkimage += \
1604839836aSThomas Petazzoni	$(shell pkg-config --libs libssl libcrypto 2> /dev/null || echo "-lssl -lcrypto")
161c6e3e821SAndreas Bießmann
162c6e3e821SAndreas Bießmann# OS X deprecate openssl in favour of CommonCrypto, supress deprecation
163c6e3e821SAndreas Bießmann# warnings on those systems
164c6e3e821SAndreas Bießmannifeq ($(HOSTOS),darwin)
165c6e3e821SAndreas BießmannHOSTCFLAGS_mxsimage.o += -Wno-deprecated-declarations
166c6e3e821SAndreas BießmannHOSTCFLAGS_image-sig.o += -Wno-deprecated-declarations
167c6e3e821SAndreas BießmannHOSTCFLAGS_rsa-sign.o += -Wno-deprecated-declarations
168c6e3e821SAndreas Bießmannendif
16997cb4e54SMasahiro Yamadaendif
17097cb4e54SMasahiro Yamada
171f8470aeeSTom RiniHOSTCFLAGS_fit_image.o += -DMKIMAGE_DTC=\"$(CONFIG_MKIMAGE_DTC_PATH)\"
17247a52cd1SEmmanuel Vadot
17396b09a97SMasahiro YamadaHOSTLOADLIBES_dumpimage := $(HOSTLOADLIBES_mkimage)
17496b09a97SMasahiro YamadaHOSTLOADLIBES_fit_info := $(HOSTLOADLIBES_mkimage)
17596b09a97SMasahiro YamadaHOSTLOADLIBES_fit_check_sign := $(HOSTLOADLIBES_mkimage)
17697cb4e54SMasahiro Yamada
17796b09a97SMasahiro Yamadahostprogs-$(CONFIG_EXYNOS5250) += mkexynosspl
17896b09a97SMasahiro Yamadahostprogs-$(CONFIG_EXYNOS5420) += mkexynosspl
17996b09a97SMasahiro YamadaHOSTCFLAGS_mkexynosspl.o := -pedantic
180940db16dSMasahiro Yamada
18131eca697SSimon Glassifdtool-objs := $(LIBFDT_OBJS) ifdtool.o
182cd392fe8SSimon Glasshostprogs-$(CONFIG_X86) += ifdtool
183cd392fe8SSimon Glass
18496b09a97SMasahiro Yamadahostprogs-$(CONFIG_MX23) += mxsboot
18596b09a97SMasahiro Yamadahostprogs-$(CONFIG_MX28) += mxsboot
18696b09a97SMasahiro YamadaHOSTCFLAGS_mxsboot.o := -pedantic
187940db16dSMasahiro Yamada
188aec9a0f1SJagan Tekihostprogs-$(CONFIG_ARCH_SUNXI) += mksunxiboot
189594b4cc7SMaxime Ripardhostprogs-$(CONFIG_ARCH_SUNXI) += sunxi-spl-image-builder
190594b4cc7SMaxime Ripardsunxi-spl-image-builder-objs := sunxi-spl-image-builder.o lib/bch.o
19150827a59SIan Campbell
19296b09a97SMasahiro Yamadahostprogs-$(CONFIG_NETCONSOLE) += ncb
19396b09a97SMasahiro Yamadahostprogs-$(CONFIG_SHA1_CHECK_UB_IMG) += ubsha1
194940db16dSMasahiro Yamada
19596b09a97SMasahiro Yamadaubsha1-objs := os_support.o ubsha1.o lib/sha1.o
196940db16dSMasahiro Yamada
197940db16dSMasahiro YamadaHOSTCFLAGS_ubsha1.o := -pedantic
198940db16dSMasahiro Yamada
19996b09a97SMasahiro Yamadahostprogs-$(CONFIG_KIRKWOOD) += kwboot
20081e33f4bSStefan Roesehostprogs-$(CONFIG_ARCH_MVEBU) += kwboot
20196b09a97SMasahiro Yamadahostprogs-y += proftool
20296b09a97SMasahiro Yamadahostprogs-$(CONFIG_STATIC_RELA) += relocate-rela
203940db16dSMasahiro Yamada
2041043d0a0SSimon Glasshostprogs-y += fdtgrep
2051043d0a0SSimon Glassfdtgrep-objs += $(LIBFDT_OBJS) fdtgrep.o
2061043d0a0SSimon Glass
207703ec9ddSPaul Burtonhostprogs-$(CONFIG_MIPS) += mips-relocs
208703ec9ddSPaul Burton
209940db16dSMasahiro Yamada# We build some files with extra pedantic flags to try to minimize things
210940db16dSMasahiro Yamada# that won't build on some weird host compiler -- though there are lots of
211940db16dSMasahiro Yamada# exceptions for files that aren't complaint.
212940db16dSMasahiro YamadaHOSTCFLAGS_crc32.o := -pedantic
2131d3c5392Soliver@schinagl.nlHOSTCFLAGS_crc8.o := -pedantic
214940db16dSMasahiro YamadaHOSTCFLAGS_md5.o := -pedantic
215940db16dSMasahiro YamadaHOSTCFLAGS_sha1.o := -pedantic
2162842c1c2SHeiko SchocherHOSTCFLAGS_sha256.o := -pedantic
217ee3584a5SPeter Tyser
218ad80c4a3SMasahiro Yamadaquiet_cmd_wrap = WRAP    $@
219ffe29ebcSMasahiro Yamadacmd_wrap = echo "\#include <../$(patsubst $(obj)/%,%,$@)>" >$@
220ad80c4a3SMasahiro Yamada
2210649cd0dSSimon Glass$(obj)/lib/%.c $(obj)/common/%.c $(obj)/env/%.c:
222ad80c4a3SMasahiro Yamada	$(call cmd,wrap)
223ad80c4a3SMasahiro Yamada
224ad80c4a3SMasahiro Yamadaclean-dirs := lib common
225ad80c4a3SMasahiro Yamada
226940db16dSMasahiro Yamadaalways := $(hostprogs-y)
22719c402afSSimon Glass
228335ffe7eSPeter Tyser# Generated LCD/video logo
2299e414032SMasahiro YamadaLOGO_H = $(objtree)/include/bmp_logo.h
2309e414032SMasahiro YamadaLOGO_DATA_H = $(objtree)/include/bmp_logo_data.h
231335ffe7eSPeter TyserLOGO-$(CONFIG_LCD_LOGO) += $(LOGO_H)
232c270730fSChe-Liang ChiouLOGO-$(CONFIG_LCD_LOGO) += $(LOGO_DATA_H)
233335ffe7eSPeter TyserLOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_H)
234c270730fSChe-Liang ChiouLOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_DATA_H)
235ee3584a5SPeter Tyser
23696903daeSOtavio Salvador# Generic logo
237ee3584a5SPeter Tyserifeq ($(LOGO_BMP),)
2389e414032SMasahiro YamadaLOGO_BMP= $(srctree)/$(src)/logos/denx.bmp
23996903daeSOtavio Salvador
24096903daeSOtavio Salvador# Use board logo and fallback to vendor
241603f51cbSMasahiro Yamadaifneq ($(wildcard $(srctree)/$(src)/logos/$(BOARD).bmp),)
2429e414032SMasahiro YamadaLOGO_BMP= $(srctree)/$(src)/logos/$(BOARD).bmp
24396903daeSOtavio Salvadorelse
244603f51cbSMasahiro Yamadaifneq ($(wildcard $(srctree)/$(src)/logos/$(VENDOR).bmp),)
2459e414032SMasahiro YamadaLOGO_BMP= $(srctree)/$(src)/logos/$(VENDOR).bmp
246ee3584a5SPeter Tyserendif
247ee3584a5SPeter Tyserendif
24896903daeSOtavio Salvador
24996903daeSOtavio Salvadorendif # !LOGO_BMP
250ee3584a5SPeter Tyser
251efee1709Swdenk#
252efee1709Swdenk# Use native tools and options
2532f8d396bSPeter Tyser# Define __KERNEL_STRICT_NAMES to prevent typedef overlaps
2542db1c3fcSYork Sun# Define _GNU_SOURCE to obtain the getline prototype from stdio.h
255efee1709Swdenk#
256*fbedfcfbSMasahiro YamadaHOST_EXTRACFLAGS += -include $(srctree)/include/compiler.h \
25751148790SMasahiro Yamada		$(patsubst -I%,-idirafter%, $(filter -I%, $(UBOOTINCLUDE))) \
25801286329SMasahiro Yamada		-I$(srctree)/lib/libfdt \
25901286329SMasahiro Yamada		-I$(srctree)/tools \
26014d0a02aSWolfgang Denk		-DUSE_HOSTCC \
2612db1c3fcSYork Sun		-D__KERNEL_STRICT_NAMES \
2622db1c3fcSYork Sun		-D_GNU_SOURCE
2638cf30809SBartlomiej Sieka
264d726f225SMasahiro Yamada__build:	$(LOGO-y)
265efee1709Swdenk
2669e414032SMasahiro Yamada$(LOGO_H):	$(obj)/bmp_logo $(LOGO_BMP)
2679e414032SMasahiro Yamada	$(obj)/bmp_logo --gen-info $(LOGO_BMP) > $@
268c270730fSChe-Liang Chiou
2699e414032SMasahiro Yamada$(LOGO_DATA_H):	$(obj)/bmp_logo $(LOGO_BMP)
2709e414032SMasahiro Yamada	$(obj)/bmp_logo --gen-data $(LOGO_BMP) > $@
2712887c473SMasahiro Yamada
2722887c473SMasahiro Yamada# Let clean descend into subdirs
2732887c473SMasahiro Yamadasubdir- += env
274db5b339cSMasahiro Yamada
275db5b339cSMasahiro Yamadaifneq ($(CROSS_BUILD_TOOLS),)
2763b082529SMasahiro Yamadaoverride HOSTCC = $(CC)
277db5b339cSMasahiro Yamada
278db5b339cSMasahiro Yamadaquiet_cmd_crosstools_strip = STRIP   $^
279db5b339cSMasahiro Yamada      cmd_crosstools_strip = $(STRIP) $^; touch $@
280db5b339cSMasahiro Yamada$(obj)/.strip: $(call objectify,$(filter $(always),$(hostprogs-y)))
281db5b339cSMasahiro Yamada	$(call cmd,crosstools_strip)
282db5b339cSMasahiro Yamada
283db5b339cSMasahiro Yamadaalways += .strip
284db5b339cSMasahiro Yamadaendif
285db5b339cSMasahiro Yamadaclean-files += .strip
286