xref: /rk3399_rockchip-uboot/tools/Makefile (revision 57807e00eb29ef2e37a73a55ae80cd9d3766ec08)
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 += resource_tool
63*0466543cSWenping Zhanghostprogs-y += bmp2gray16
6423ba6841SJoseph Chen
65467d16dbSJoseph Chenresource_tool-objs := rockchip/resource_tool.o
66*0466543cSWenping Zhangbmp2gray16-objs := rockchip/bmp2gray16.o
6723ba6841SJoseph Chenendif
6823ba6841SJoseph Chen
69ad80c4a3SMasahiro YamadaFIT_SIG_OBJS-$(CONFIG_FIT_SIGNATURE) := common/image-sig.o
70ee95d10bSSimon Glass
71141b0784SMasahiro Yamada# The following files are synced with upstream DTC.
72141b0784SMasahiro Yamada# Use synced versions from scripts/dtc/libfdt/.
734e2c3b8cSMasahiro YamadaLIBFDT_SRCS_SYNCED := fdt.c fdt_wip.c fdt_sw.c fdt_rw.c \
744e2c3b8cSMasahiro Yamada		fdt_strerror.c fdt_empty_tree.c fdt_addresses.c fdt_overlay.c
75141b0784SMasahiro Yamada# The following files are locally modified for U-Boot (unfotunately).
76141b0784SMasahiro Yamada# Use U-Boot own versions from lib/libfdt/.
774e2c3b8cSMasahiro YamadaLIBFDT_SRCS_UNSYNCED := fdt_ro.c fdt_region.c
78141b0784SMasahiro Yamada
79141b0784SMasahiro YamadaLIBFDT_OBJS := $(addprefix libfdt/, $(patsubst %.c, %.o, $(LIBFDT_SRCS_SYNCED))) \
80141b0784SMasahiro Yamada	       $(addprefix lib/libfdt/, $(patsubst %.c, %.o, $(LIBFDT_SRCS_UNSYNCED)))
81330274f1SSimon Glass
82ad80c4a3SMasahiro YamadaRSA_OBJS-$(CONFIG_FIT_SIGNATURE) := $(addprefix lib/rsa/, \
83fc2f4246SRuchika Gupta					rsa-sign.o rsa-verify.o rsa-checksum.o \
84fc2f4246SRuchika Gupta					rsa-mod-exp.o)
85940db16dSMasahiro Yamada
866f14746bSPaweł JaroszROCKCHIP_OBS = lib/rc4.o rkcommon.o rkimage.o rknand.o rksd.o rkspi.o
87a131c1f4SSimon Glass
88940db16dSMasahiro Yamada# common objs for dumpimage and mkimage
89940db16dSMasahiro Yamadadumpimage-mkimage-objs := aisimage.o \
907b1a4117SAndreas Bießmann			atmelimage.o \
91940db16dSMasahiro Yamada			$(FIT_SIG_OBJS-y) \
92ea51a628SSimon Glass			common/bootm.o \
93ad80c4a3SMasahiro Yamada			lib/crc32.o \
94940db16dSMasahiro Yamada			default_image.o \
95b047d671SHeiko Schocher			lib/fdtdec_common.o \
96ad80c4a3SMasahiro Yamada			lib/fdtdec.o \
976bf4ca07SHeiko Schocher			fit_common.o \
98940db16dSMasahiro Yamada			fit_image.o \
99ad80c4a3SMasahiro Yamada			common/image-fit.o \
100940db16dSMasahiro Yamada			image-host.o \
101ad80c4a3SMasahiro Yamada			common/image.o \
102940db16dSMasahiro Yamada			imagetool.o \
103940db16dSMasahiro Yamada			imximage.o \
104940db16dSMasahiro Yamada			kwbimage.o \
105ad80c4a3SMasahiro Yamada			lib/md5.o \
10639f520bbSAlbert ARIBAUD \(3ADEV\)			lpc32xximage.o \
107940db16dSMasahiro Yamada			mxsimage.o \
108940db16dSMasahiro Yamada			omapimage.o \
109940db16dSMasahiro Yamada			os_support.o \
110940db16dSMasahiro Yamada			pblimage.o \
111abbc67eeSCharles Manning			pbl_crc32.o \
112ed0c2c0aSAlbert ARIBAUD \(3ADEV\)			vybridimage.o \
113a131c1f4SSimon Glass			$(ROCKCHIP_OBS) \
114832472a9SCharles Manning			socfpgaimage.o \
115ad80c4a3SMasahiro Yamada			lib/sha1.o \
116ad80c4a3SMasahiro Yamada			lib/sha256.o \
1172dd90027SRuchika Gupta			common/hash.o \
118940db16dSMasahiro Yamada			ublimage.o \
11966eef1e7SNathan Rossi			zynqimage.o \
120d9b58b30SMichal Simek			zynqmpimage.o \
121940db16dSMasahiro Yamada			$(LIBFDT_OBJS) \
122969cd1faSStefano Babic			gpimage.o \
123969cd1faSStefano Babic			gpimage-common.o \
124940db16dSMasahiro Yamada			$(RSA_OBJS-y)
125940db16dSMasahiro Yamada
12696b09a97SMasahiro Yamadadumpimage-objs := $(dumpimage-mkimage-objs) dumpimage.o
12796b09a97SMasahiro Yamadamkimage-objs   := $(dumpimage-mkimage-objs) mkimage.o
12896b09a97SMasahiro Yamadafit_info-objs   := $(dumpimage-mkimage-objs) fit_info.o
12996b09a97SMasahiro Yamadafit_check_sign-objs   := $(dumpimage-mkimage-objs) fit_check_sign.o
130940db16dSMasahiro Yamada
131940db16dSMasahiro Yamadaifneq ($(CONFIG_MX23)$(CONFIG_MX28),)
132940db16dSMasahiro Yamada# Add CONFIG_MXS into host CFLAGS, so we can check whether or not register
133940db16dSMasahiro Yamada# the mxsimage support within tools/mxsimage.c .
1346825a95bSMasahiro YamadaHOSTCFLAGS_mxsimage.o += -DCONFIG_MXS
135940db16dSMasahiro Yamadaendif
136940db16dSMasahiro Yamada
137940db16dSMasahiro Yamadaifdef CONFIG_FIT_SIGNATURE
138940db16dSMasahiro Yamada# This affects include/image.h, but including the board config file
139940db16dSMasahiro Yamada# is tricky, so manually define this options here.
140940db16dSMasahiro YamadaHOST_EXTRACFLAGS	+= -DCONFIG_FIT_SIGNATURE
141940db16dSMasahiro Yamadaendif
142940db16dSMasahiro Yamada
1437ddf8cfbSStefan Roeseifdef CONFIG_SYS_U_BOOT_OFFS
1447ddf8cfbSStefan RoeseHOSTCFLAGS_kwbimage.o += -DCONFIG_SYS_U_BOOT_OFFS=$(CONFIG_SYS_U_BOOT_OFFS)
145e35c6c79STom Riniendif
146e35c6c79STom Rini
147a1b6b0a9SMario Sixifneq ($(CONFIG_ARMADA_38X)$(CONFIG_ARMADA_39X),)
148a1b6b0a9SMario SixHOSTCFLAGS_kwbimage.o += -DCONFIG_KWB_SECURE
149a1b6b0a9SMario Sixendif
150a1b6b0a9SMario Six
15197cb4e54SMasahiro Yamada# MXSImage needs LibSSL
152a1b6b0a9SMario Sixifneq ($(CONFIG_MX23)$(CONFIG_MX28)$(CONFIG_ARMADA_38X)$(CONFIG_ARMADA_39X)$(CONFIG_FIT_SIGNATURE),)
1534839836aSThomas PetazzoniHOSTLOADLIBES_mkimage += \
1544839836aSThomas Petazzoni	$(shell pkg-config --libs libssl libcrypto 2> /dev/null || echo "-lssl -lcrypto")
155c6e3e821SAndreas Bießmann
156c6e3e821SAndreas Bießmann# OS X deprecate openssl in favour of CommonCrypto, supress deprecation
157c6e3e821SAndreas Bießmann# warnings on those systems
158c6e3e821SAndreas Bießmannifeq ($(HOSTOS),darwin)
159c6e3e821SAndreas BießmannHOSTCFLAGS_mxsimage.o += -Wno-deprecated-declarations
160c6e3e821SAndreas BießmannHOSTCFLAGS_image-sig.o += -Wno-deprecated-declarations
161c6e3e821SAndreas BießmannHOSTCFLAGS_rsa-sign.o += -Wno-deprecated-declarations
162c6e3e821SAndreas Bießmannendif
16397cb4e54SMasahiro Yamadaendif
16497cb4e54SMasahiro Yamada
165f8470aeeSTom RiniHOSTCFLAGS_fit_image.o += -DMKIMAGE_DTC=\"$(CONFIG_MKIMAGE_DTC_PATH)\"
16647a52cd1SEmmanuel Vadot
16796b09a97SMasahiro YamadaHOSTLOADLIBES_dumpimage := $(HOSTLOADLIBES_mkimage)
16896b09a97SMasahiro YamadaHOSTLOADLIBES_fit_info := $(HOSTLOADLIBES_mkimage)
16996b09a97SMasahiro YamadaHOSTLOADLIBES_fit_check_sign := $(HOSTLOADLIBES_mkimage)
17097cb4e54SMasahiro Yamada
17196b09a97SMasahiro Yamadahostprogs-$(CONFIG_EXYNOS5250) += mkexynosspl
17296b09a97SMasahiro Yamadahostprogs-$(CONFIG_EXYNOS5420) += mkexynosspl
17396b09a97SMasahiro YamadaHOSTCFLAGS_mkexynosspl.o := -pedantic
174940db16dSMasahiro Yamada
17531eca697SSimon Glassifdtool-objs := $(LIBFDT_OBJS) ifdtool.o
176cd392fe8SSimon Glasshostprogs-$(CONFIG_X86) += ifdtool
177cd392fe8SSimon Glass
17896b09a97SMasahiro Yamadahostprogs-$(CONFIG_MX23) += mxsboot
17996b09a97SMasahiro Yamadahostprogs-$(CONFIG_MX28) += mxsboot
18096b09a97SMasahiro YamadaHOSTCFLAGS_mxsboot.o := -pedantic
181940db16dSMasahiro Yamada
182aec9a0f1SJagan Tekihostprogs-$(CONFIG_ARCH_SUNXI) += mksunxiboot
183594b4cc7SMaxime Ripardhostprogs-$(CONFIG_ARCH_SUNXI) += sunxi-spl-image-builder
184594b4cc7SMaxime Ripardsunxi-spl-image-builder-objs := sunxi-spl-image-builder.o lib/bch.o
18550827a59SIan Campbell
18696b09a97SMasahiro Yamadahostprogs-$(CONFIG_NETCONSOLE) += ncb
18796b09a97SMasahiro Yamadahostprogs-$(CONFIG_SHA1_CHECK_UB_IMG) += ubsha1
188940db16dSMasahiro Yamada
18996b09a97SMasahiro Yamadaubsha1-objs := os_support.o ubsha1.o lib/sha1.o
190940db16dSMasahiro Yamada
191940db16dSMasahiro YamadaHOSTCFLAGS_ubsha1.o := -pedantic
192940db16dSMasahiro Yamada
19396b09a97SMasahiro Yamadahostprogs-$(CONFIG_KIRKWOOD) += kwboot
19481e33f4bSStefan Roesehostprogs-$(CONFIG_ARCH_MVEBU) += kwboot
19596b09a97SMasahiro Yamadahostprogs-y += proftool
19696b09a97SMasahiro Yamadahostprogs-$(CONFIG_STATIC_RELA) += relocate-rela
197940db16dSMasahiro Yamada
1981043d0a0SSimon Glasshostprogs-y += fdtgrep
1991043d0a0SSimon Glassfdtgrep-objs += $(LIBFDT_OBJS) fdtgrep.o
2001043d0a0SSimon Glass
201703ec9ddSPaul Burtonhostprogs-$(CONFIG_MIPS) += mips-relocs
202703ec9ddSPaul Burton
203940db16dSMasahiro Yamada# We build some files with extra pedantic flags to try to minimize things
204940db16dSMasahiro Yamada# that won't build on some weird host compiler -- though there are lots of
205940db16dSMasahiro Yamada# exceptions for files that aren't complaint.
206940db16dSMasahiro YamadaHOSTCFLAGS_crc32.o := -pedantic
2071d3c5392Soliver@schinagl.nlHOSTCFLAGS_crc8.o := -pedantic
208940db16dSMasahiro YamadaHOSTCFLAGS_md5.o := -pedantic
209940db16dSMasahiro YamadaHOSTCFLAGS_sha1.o := -pedantic
2102842c1c2SHeiko SchocherHOSTCFLAGS_sha256.o := -pedantic
211ee3584a5SPeter Tyser
212ad80c4a3SMasahiro Yamadaquiet_cmd_wrap = WRAP    $@
213ffe29ebcSMasahiro Yamadacmd_wrap = echo "\#include <../$(patsubst $(obj)/%,%,$@)>" >$@
214ad80c4a3SMasahiro Yamada
2150649cd0dSSimon Glass$(obj)/lib/%.c $(obj)/common/%.c $(obj)/env/%.c:
216ad80c4a3SMasahiro Yamada	$(call cmd,wrap)
217ad80c4a3SMasahiro Yamada
218ad80c4a3SMasahiro Yamadaclean-dirs := lib common
219ad80c4a3SMasahiro Yamada
220940db16dSMasahiro Yamadaalways := $(hostprogs-y)
22119c402afSSimon Glass
222335ffe7eSPeter Tyser# Generated LCD/video logo
2239e414032SMasahiro YamadaLOGO_H = $(objtree)/include/bmp_logo.h
2249e414032SMasahiro YamadaLOGO_DATA_H = $(objtree)/include/bmp_logo_data.h
225335ffe7eSPeter TyserLOGO-$(CONFIG_LCD_LOGO) += $(LOGO_H)
226c270730fSChe-Liang ChiouLOGO-$(CONFIG_LCD_LOGO) += $(LOGO_DATA_H)
227335ffe7eSPeter TyserLOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_H)
228c270730fSChe-Liang ChiouLOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_DATA_H)
229ee3584a5SPeter Tyser
23096903daeSOtavio Salvador# Generic logo
231ee3584a5SPeter Tyserifeq ($(LOGO_BMP),)
2329e414032SMasahiro YamadaLOGO_BMP= $(srctree)/$(src)/logos/denx.bmp
23396903daeSOtavio Salvador
23496903daeSOtavio Salvador# Use board logo and fallback to vendor
235603f51cbSMasahiro Yamadaifneq ($(wildcard $(srctree)/$(src)/logos/$(BOARD).bmp),)
2369e414032SMasahiro YamadaLOGO_BMP= $(srctree)/$(src)/logos/$(BOARD).bmp
23796903daeSOtavio Salvadorelse
238603f51cbSMasahiro Yamadaifneq ($(wildcard $(srctree)/$(src)/logos/$(VENDOR).bmp),)
2399e414032SMasahiro YamadaLOGO_BMP= $(srctree)/$(src)/logos/$(VENDOR).bmp
240ee3584a5SPeter Tyserendif
241ee3584a5SPeter Tyserendif
24296903daeSOtavio Salvador
24396903daeSOtavio Salvadorendif # !LOGO_BMP
244ee3584a5SPeter Tyser
245efee1709Swdenk#
246efee1709Swdenk# Use native tools and options
2472f8d396bSPeter Tyser# Define __KERNEL_STRICT_NAMES to prevent typedef overlaps
2482db1c3fcSYork Sun# Define _GNU_SOURCE to obtain the getline prototype from stdio.h
249efee1709Swdenk#
250fbedfcfbSMasahiro YamadaHOST_EXTRACFLAGS += -include $(srctree)/include/compiler.h \
25151148790SMasahiro Yamada		$(patsubst -I%,-idirafter%, $(filter -I%, $(UBOOTINCLUDE))) \
252fe47e2a1SPaul Kocialkowski		-I$(srctree)/scripts/dtc/libfdt \
25301286329SMasahiro Yamada		-I$(srctree)/tools \
25414d0a02aSWolfgang Denk		-DUSE_HOSTCC \
2552db1c3fcSYork Sun		-D__KERNEL_STRICT_NAMES \
2562db1c3fcSYork Sun		-D_GNU_SOURCE
2578cf30809SBartlomiej Sieka
258d726f225SMasahiro Yamada__build:	$(LOGO-y)
259efee1709Swdenk
2609e414032SMasahiro Yamada$(LOGO_H):	$(obj)/bmp_logo $(LOGO_BMP)
2619e414032SMasahiro Yamada	$(obj)/bmp_logo --gen-info $(LOGO_BMP) > $@
262c270730fSChe-Liang Chiou
2639e414032SMasahiro Yamada$(LOGO_DATA_H):	$(obj)/bmp_logo $(LOGO_BMP)
2649e414032SMasahiro Yamada	$(obj)/bmp_logo --gen-data $(LOGO_BMP) > $@
2652887c473SMasahiro Yamada
2662887c473SMasahiro Yamada# Let clean descend into subdirs
2672887c473SMasahiro Yamadasubdir- += env
268db5b339cSMasahiro Yamada
269db5b339cSMasahiro Yamadaifneq ($(CROSS_BUILD_TOOLS),)
2703b082529SMasahiro Yamadaoverride HOSTCC = $(CC)
271db5b339cSMasahiro Yamada
272db5b339cSMasahiro Yamadaquiet_cmd_crosstools_strip = STRIP   $^
273db5b339cSMasahiro Yamada      cmd_crosstools_strip = $(STRIP) $^; touch $@
274db5b339cSMasahiro Yamada$(obj)/.strip: $(call objectify,$(filter $(always),$(hostprogs-y)))
275db5b339cSMasahiro Yamada	$(call cmd,crosstools_strip)
276db5b339cSMasahiro Yamada
277db5b339cSMasahiro Yamadaalways += .strip
278db5b339cSMasahiro Yamadaendif
279db5b339cSMasahiro Yamadaclean-files += .strip
280