xref: /openbmc/u-boot/tools/Makefile (revision 6c59c116fa67c0158fba9534b4c18adba9cab1bb)
183d290c5STom Rini# SPDX-License-Identifier: GPL-2.0+
2efee1709Swdenk#
3f9328639SMarian Balakowicz# (C) Copyright 2000-2006
4efee1709Swdenk# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
5efee1709Swdenk
6c7c0d542SMike Frysinger# Enable all the config-independent tools
7c7c0d542SMike Frysingerifneq ($(HOST_TOOLS_ALL),)
85473eb6dSTuomas TynkkynenCONFIG_KIRKWOOD = y
9c7c0d542SMike FrysingerCONFIG_LCD_LOGO = y
10570d7d50SMike FrysingerCONFIG_CMD_LOADS = y
11c7c0d542SMike FrysingerCONFIG_CMD_NET = y
1260b74bdeSDaniel SchwierzeckCONFIG_XWAY_SWAP_BYTES = y
13c7c0d542SMike FrysingerCONFIG_NETCONSOLE = y
14c7c0d542SMike FrysingerCONFIG_SHA1_CHECK_UB_IMG = y
15d8c0d99eSAndre PrzywaraCONFIG_ARCH_SUNXI = y
16c7c0d542SMike Frysingerendif
17c7c0d542SMike Frysinger
182887c473SMasahiro Yamadasubdir-$(HOST_TOOLS_ALL) += easylogo
192887c473SMasahiro Yamadasubdir-$(HOST_TOOLS_ALL) += gdb
202887c473SMasahiro Yamada
212ad6e27dSMike Frysinger# Merge all the different vars for envcrc into one
222ad6e27dSMike FrysingerENVCRC-$(CONFIG_ENV_IS_EMBEDDED) = y
232ad6e27dSMike FrysingerENVCRC-$(CONFIG_ENV_IS_IN_EEPROM) = y
242ad6e27dSMike FrysingerENVCRC-$(CONFIG_ENV_IS_IN_FLASH) = y
252ad6e27dSMike FrysingerENVCRC-$(CONFIG_ENV_IS_IN_ONENAND) = y
262ad6e27dSMike FrysingerENVCRC-$(CONFIG_ENV_IS_IN_NAND) = y
272ad6e27dSMike FrysingerENVCRC-$(CONFIG_ENV_IS_IN_NVRAM) = y
282ad6e27dSMike FrysingerENVCRC-$(CONFIG_ENV_IS_IN_SPI_FLASH) = y
292ad6e27dSMike FrysingerCONFIG_BUILD_ENVCRC ?= $(ENVCRC-y)
302ad6e27dSMike Frysinger
3196b09a97SMasahiro Yamadahostprogs-$(CONFIG_SPL_GENERATE_ATMEL_PMECC_HEADER) += atmel_pmecc_params
325c390a5bSAndreas Bießmann
3396b09a97SMasahiro Yamadahostprogs-$(CONFIG_LCD_LOGO) += bmp_logo
3496b09a97SMasahiro Yamadahostprogs-$(CONFIG_VIDEO_LOGO) += bmp_logo
3596b09a97SMasahiro YamadaHOSTCFLAGS_bmp_logo.o := -pedantic
36ee3584a5SPeter Tyser
3796b09a97SMasahiro Yamadahostprogs-$(CONFIG_BUILD_ENVCRC) += envcrc
380649cd0dSSimon Glassenvcrc-objs := envcrc.o lib/crc32.o env/embedded.o lib/sha1.o
39940db16dSMasahiro Yamada
4096b09a97SMasahiro Yamadahostprogs-$(CONFIG_CMD_NET) += gen_eth_addr
4196b09a97SMasahiro YamadaHOSTCFLAGS_gen_eth_addr.o := -pedantic
42940db16dSMasahiro Yamada
43c25f01a6Soliver@schinagl.nlhostprogs-$(CONFIG_CMD_NET) += gen_ethaddr_crc
44c25f01a6Soliver@schinagl.nlgen_ethaddr_crc-objs := gen_ethaddr_crc.o lib/crc8.o
45c25f01a6Soliver@schinagl.nlHOSTCFLAGS_gen_ethaddr_crc.o := -pedantic
46c25f01a6Soliver@schinagl.nl
4796b09a97SMasahiro Yamadahostprogs-$(CONFIG_CMD_LOADS) += img2srec
4896b09a97SMasahiro YamadaHOSTCFLAGS_img2srec.o := -pedantic
49940db16dSMasahiro Yamada
5096b09a97SMasahiro Yamadahostprogs-$(CONFIG_XWAY_SWAP_BYTES) += xway-swap-bytes
5196b09a97SMasahiro YamadaHOSTCFLAGS_xway-swap-bytes.o := -pedantic
52940db16dSMasahiro Yamada
5396b09a97SMasahiro Yamadahostprogs-y += mkenvimage
5496b09a97SMasahiro Yamadamkenvimage-objs := mkenvimage.o os_support.o lib/crc32.o
55940db16dSMasahiro Yamada
5696b09a97SMasahiro Yamadahostprogs-y += dumpimage mkimage
5796b09a97SMasahiro Yamadahostprogs-$(CONFIG_FIT_SIGNATURE) += fit_info fit_check_sign
58940db16dSMasahiro Yamada
59ac020196SHeinrich Schuchardthostprogs-$(CONFIG_CMD_BOOTEFI_SELFTEST) += file2include
60ac020196SHeinrich Schuchardt
61ad80c4a3SMasahiro YamadaFIT_SIG_OBJS-$(CONFIG_FIT_SIGNATURE) := common/image-sig.o
62ee95d10bSSimon Glass
63b38ad663SMasahiro Yamada# The following files are synced with upstream DTC.
64b38ad663SMasahiro Yamada# Use synced versions from scripts/dtc/libfdt/.
65ae9ace70SMasahiro YamadaLIBFDT_SRCS_SYNCED := fdt.c fdt_wip.c fdt_sw.c fdt_rw.c \
66ae9ace70SMasahiro Yamada		fdt_strerror.c fdt_empty_tree.c fdt_addresses.c fdt_overlay.c
67b38ad663SMasahiro Yamada# The following files are locally modified for U-Boot (unfotunately).
68b38ad663SMasahiro Yamada# Use U-Boot own versions from lib/libfdt/.
69ae9ace70SMasahiro YamadaLIBFDT_SRCS_UNSYNCED := fdt_ro.c fdt_region.c
70b38ad663SMasahiro Yamada
71b38ad663SMasahiro YamadaLIBFDT_OBJS := $(addprefix libfdt/, $(patsubst %.c, %.o, $(LIBFDT_SRCS_SYNCED))) \
72b38ad663SMasahiro Yamada	       $(addprefix lib/libfdt/, $(patsubst %.c, %.o, $(LIBFDT_SRCS_UNSYNCED)))
73330274f1SSimon Glass
74ad80c4a3SMasahiro YamadaRSA_OBJS-$(CONFIG_FIT_SIGNATURE) := $(addprefix lib/rsa/, \
75fc2f4246SRuchika Gupta					rsa-sign.o rsa-verify.o rsa-checksum.o \
76fc2f4246SRuchika Gupta					rsa-mod-exp.o)
77940db16dSMasahiro Yamada
789b03701aSSimon GlassROCKCHIP_OBS = lib/rc4.o rkcommon.o rkimage.o rksd.o rkspi.o
79a131c1f4SSimon Glass
80940db16dSMasahiro Yamada# common objs for dumpimage and mkimage
81940db16dSMasahiro Yamadadumpimage-mkimage-objs := aisimage.o \
827b1a4117SAndreas Bießmann			atmelimage.o \
83940db16dSMasahiro Yamada			$(FIT_SIG_OBJS-y) \
84ea51a628SSimon Glass			common/bootm.o \
85ad80c4a3SMasahiro Yamada			lib/crc32.o \
86940db16dSMasahiro Yamada			default_image.o \
87b047d671SHeiko Schocher			lib/fdtdec_common.o \
88ad80c4a3SMasahiro Yamada			lib/fdtdec.o \
896bf4ca07SHeiko Schocher			fit_common.o \
90940db16dSMasahiro Yamada			fit_image.o \
91ad80c4a3SMasahiro Yamada			common/image-fit.o \
92940db16dSMasahiro Yamada			image-host.o \
93ad80c4a3SMasahiro Yamada			common/image.o \
94940db16dSMasahiro Yamada			imagetool.o \
95940db16dSMasahiro Yamada			imximage.o \
96a2b96eceSPeng Fan			imx8image.o \
976609c266SPeng Fan			imx8mimage.o \
98940db16dSMasahiro Yamada			kwbimage.o \
99ad80c4a3SMasahiro Yamada			lib/md5.o \
10039f520bbSAlbert ARIBAUD \(3ADEV\)			lpc32xximage.o \
101940db16dSMasahiro Yamada			mxsimage.o \
102940db16dSMasahiro Yamada			omapimage.o \
103940db16dSMasahiro Yamada			os_support.o \
104940db16dSMasahiro Yamada			pblimage.o \
105abbc67eeSCharles Manning			pbl_crc32.o \
106ed0c2c0aSAlbert ARIBAUD \(3ADEV\)			vybridimage.o \
10781260e33SPatrick Delaunay			stm32image.o \
108a131c1f4SSimon Glass			$(ROCKCHIP_OBS) \
109832472a9SCharles Manning			socfpgaimage.o \
11051c2345bSPhilipp Tomsich			lib/crc16.o \
111ad80c4a3SMasahiro Yamada			lib/sha1.o \
112ad80c4a3SMasahiro Yamada			lib/sha256.o \
113e9221d03SReuben Dowle			lib/sha512.o \
1142dd90027SRuchika Gupta			common/hash.o \
115940db16dSMasahiro Yamada			ublimage.o \
11666eef1e7SNathan Rossi			zynqimage.o \
117d9b58b30SMichal Simek			zynqmpimage.o \
1186915dcf3SAlexander Graf			zynqmpbif.o \
119940db16dSMasahiro Yamada			$(LIBFDT_OBJS) \
120969cd1faSStefano Babic			gpimage.o \
121969cd1faSStefano Babic			gpimage-common.o \
1223b975a14SRyder Lee			mtk_image.o \
123940db16dSMasahiro Yamada			$(RSA_OBJS-y)
124940db16dSMasahiro Yamada
12596b09a97SMasahiro Yamadadumpimage-objs := $(dumpimage-mkimage-objs) dumpimage.o
12696b09a97SMasahiro Yamadamkimage-objs   := $(dumpimage-mkimage-objs) mkimage.o
12796b09a97SMasahiro Yamadafit_info-objs   := $(dumpimage-mkimage-objs) fit_info.o
12896b09a97SMasahiro Yamadafit_check_sign-objs   := $(dumpimage-mkimage-objs) fit_check_sign.o
129ac020196SHeinrich Schuchardtfile2include-objs := file2include.o
130940db16dSMasahiro Yamada
13180870e2aSOtavio Salvadorifneq ($(CONFIG_MX23)$(CONFIG_MX28)$(CONFIG_FIT_SIGNATURE),)
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
14172239fc8STeddy ReedHOST_EXTRACFLAGS	+= -DCONFIG_FIT_SIGNATURE_MAX_SIZE=$(CONFIG_FIT_SIGNATURE_MAX_SIZE)
142940db16dSMasahiro Yamadaendif
143940db16dSMasahiro Yamada
1447ddf8cfbSStefan Roeseifdef CONFIG_SYS_U_BOOT_OFFS
1457ddf8cfbSStefan RoeseHOSTCFLAGS_kwbimage.o += -DCONFIG_SYS_U_BOOT_OFFS=$(CONFIG_SYS_U_BOOT_OFFS)
146e35c6c79STom Riniendif
147e35c6c79STom Rini
148a1b6b0a9SMario Sixifneq ($(CONFIG_ARMADA_38X)$(CONFIG_ARMADA_39X),)
149a1b6b0a9SMario SixHOSTCFLAGS_kwbimage.o += -DCONFIG_KWB_SECURE
150a1b6b0a9SMario Sixendif
151a1b6b0a9SMario Six
15297cb4e54SMasahiro Yamada# MXSImage needs LibSSL
153a1b6b0a9SMario Sixifneq ($(CONFIG_MX23)$(CONFIG_MX28)$(CONFIG_ARMADA_38X)$(CONFIG_ARMADA_39X)$(CONFIG_FIT_SIGNATURE),)
1544839836aSThomas PetazzoniHOSTLOADLIBES_mkimage += \
1554839836aSThomas Petazzoni	$(shell pkg-config --libs libssl libcrypto 2> /dev/null || echo "-lssl -lcrypto")
156c6e3e821SAndreas Bießmann
157c6e3e821SAndreas Bießmann# OS X deprecate openssl in favour of CommonCrypto, supress deprecation
158c6e3e821SAndreas Bießmann# warnings on those systems
159c6e3e821SAndreas Bießmannifeq ($(HOSTOS),darwin)
160c6e3e821SAndreas BießmannHOSTCFLAGS_mxsimage.o += -Wno-deprecated-declarations
161c6e3e821SAndreas BießmannHOSTCFLAGS_image-sig.o += -Wno-deprecated-declarations
162*6c59c116SJoel Stanleyendif
163*6c59c116SJoel Stanleyendif
164*6c59c116SJoel Stanley
165*6c59c116SJoel Stanley# Disable warnings on systems with OpenSSL 3.0
166c6e3e821SAndreas BießmannHOSTCFLAGS_rsa-sign.o += -Wno-deprecated-declarations
16797cb4e54SMasahiro Yamada
1681f6049e2STom RiniHOSTCFLAGS_fit_image.o += -DMKIMAGE_DTC=\"$(CONFIG_MKIMAGE_DTC_PATH)\"
16947a52cd1SEmmanuel Vadot
17096b09a97SMasahiro YamadaHOSTLOADLIBES_dumpimage := $(HOSTLOADLIBES_mkimage)
17196b09a97SMasahiro YamadaHOSTLOADLIBES_fit_info := $(HOSTLOADLIBES_mkimage)
17296b09a97SMasahiro YamadaHOSTLOADLIBES_fit_check_sign := $(HOSTLOADLIBES_mkimage)
17397cb4e54SMasahiro Yamada
17496b09a97SMasahiro Yamadahostprogs-$(CONFIG_EXYNOS5250) += mkexynosspl
17596b09a97SMasahiro Yamadahostprogs-$(CONFIG_EXYNOS5420) += mkexynosspl
17696b09a97SMasahiro YamadaHOSTCFLAGS_mkexynosspl.o := -pedantic
177940db16dSMasahiro Yamada
17831eca697SSimon Glassifdtool-objs := $(LIBFDT_OBJS) ifdtool.o
179cd392fe8SSimon Glasshostprogs-$(CONFIG_X86) += ifdtool
180cd392fe8SSimon Glass
18196b09a97SMasahiro Yamadahostprogs-$(CONFIG_MX23) += mxsboot
18296b09a97SMasahiro Yamadahostprogs-$(CONFIG_MX28) += mxsboot
18396b09a97SMasahiro YamadaHOSTCFLAGS_mxsboot.o := -pedantic
184940db16dSMasahiro Yamada
185aec9a0f1SJagan Tekihostprogs-$(CONFIG_ARCH_SUNXI) += mksunxiboot
186594b4cc7SMaxime Ripardhostprogs-$(CONFIG_ARCH_SUNXI) += sunxi-spl-image-builder
187594b4cc7SMaxime Ripardsunxi-spl-image-builder-objs := sunxi-spl-image-builder.o lib/bch.o
18850827a59SIan Campbell
18996b09a97SMasahiro Yamadahostprogs-$(CONFIG_NETCONSOLE) += ncb
19096b09a97SMasahiro Yamadahostprogs-$(CONFIG_SHA1_CHECK_UB_IMG) += ubsha1
191940db16dSMasahiro Yamada
19296b09a97SMasahiro Yamadaubsha1-objs := os_support.o ubsha1.o lib/sha1.o
193940db16dSMasahiro Yamada
194940db16dSMasahiro YamadaHOSTCFLAGS_ubsha1.o := -pedantic
195940db16dSMasahiro Yamada
19696b09a97SMasahiro Yamadahostprogs-$(CONFIG_KIRKWOOD) += kwboot
19781e33f4bSStefan Roesehostprogs-$(CONFIG_ARCH_MVEBU) += kwboot
19896b09a97SMasahiro Yamadahostprogs-y += proftool
19996b09a97SMasahiro Yamadahostprogs-$(CONFIG_STATIC_RELA) += relocate-rela
20042ac26f2SRick Chenhostprogs-$(CONFIG_RISCV) += prelink-riscv
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
215e9221d03SReuben DowleHOSTCFLAGS_sha512.o := -pedantic -DCONFIG_SHA512 -DCONFIG_SHA384
216ee3584a5SPeter Tyser
217ad80c4a3SMasahiro Yamadaquiet_cmd_wrap = WRAP    $@
218ffe29ebcSMasahiro Yamadacmd_wrap = echo "\#include <../$(patsubst $(obj)/%,%,$@)>" >$@
219ad80c4a3SMasahiro Yamada
2200649cd0dSSimon Glass$(obj)/lib/%.c $(obj)/common/%.c $(obj)/env/%.c:
221ad80c4a3SMasahiro Yamada	$(call cmd,wrap)
222ad80c4a3SMasahiro Yamada
223ad80c4a3SMasahiro Yamadaclean-dirs := lib common
224ad80c4a3SMasahiro Yamada
225940db16dSMasahiro Yamadaalways := $(hostprogs-y)
22619c402afSSimon Glass
227335ffe7eSPeter Tyser# Generated LCD/video logo
2289e414032SMasahiro YamadaLOGO_H = $(objtree)/include/bmp_logo.h
2299e414032SMasahiro YamadaLOGO_DATA_H = $(objtree)/include/bmp_logo_data.h
230335ffe7eSPeter TyserLOGO-$(CONFIG_LCD_LOGO) += $(LOGO_H)
231c270730fSChe-Liang ChiouLOGO-$(CONFIG_LCD_LOGO) += $(LOGO_DATA_H)
232335ffe7eSPeter TyserLOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_H)
233c270730fSChe-Liang ChiouLOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_DATA_H)
234ee3584a5SPeter Tyser
23596903daeSOtavio Salvador# Generic logo
236ee3584a5SPeter Tyserifeq ($(LOGO_BMP),)
2379e414032SMasahiro YamadaLOGO_BMP= $(srctree)/$(src)/logos/denx.bmp
23896903daeSOtavio Salvador
23996903daeSOtavio Salvador# Use board logo and fallback to vendor
240603f51cbSMasahiro Yamadaifneq ($(wildcard $(srctree)/$(src)/logos/$(BOARD).bmp),)
2419e414032SMasahiro YamadaLOGO_BMP= $(srctree)/$(src)/logos/$(BOARD).bmp
24296903daeSOtavio Salvadorelse
243603f51cbSMasahiro Yamadaifneq ($(wildcard $(srctree)/$(src)/logos/$(VENDOR).bmp),)
2449e414032SMasahiro YamadaLOGO_BMP= $(srctree)/$(src)/logos/$(VENDOR).bmp
245ee3584a5SPeter Tyserendif
246ee3584a5SPeter Tyserendif
24796903daeSOtavio Salvador
24896903daeSOtavio Salvadorendif # !LOGO_BMP
249ee3584a5SPeter Tyser
250efee1709Swdenk#
251efee1709Swdenk# Use native tools and options
2522f8d396bSPeter Tyser# Define __KERNEL_STRICT_NAMES to prevent typedef overlaps
2532db1c3fcSYork Sun# Define _GNU_SOURCE to obtain the getline prototype from stdio.h
254efee1709Swdenk#
25566228220SMasahiro YamadaHOST_EXTRACFLAGS += -include $(srctree)/include/compiler.h \
25651148790SMasahiro Yamada		$(patsubst -I%,-idirafter%, $(filter -I%, $(UBOOTINCLUDE))) \
257e0d20dc1SPaul Kocialkowski		-I$(srctree)/scripts/dtc/libfdt \
25801286329SMasahiro Yamada		-I$(srctree)/tools \
25914d0a02aSWolfgang Denk		-DUSE_HOSTCC \
2602db1c3fcSYork Sun		-D__KERNEL_STRICT_NAMES \
261d7edeba7SThomas Petazzoni		-D_GNU_SOURCE \
262d7edeba7SThomas Petazzoni		-std=gnu99
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