xref: /rk3399_rockchip-uboot/tools/Makefile (revision b48bfc74ee410b1e6681c620633ffef32aafaba0)
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_DATAFLASH) = y
252ad6e27dSMike FrysingerENVCRC-$(CONFIG_ENV_IS_IN_EEPROM) = y
262ad6e27dSMike FrysingerENVCRC-$(CONFIG_ENV_IS_IN_FLASH) = y
272ad6e27dSMike FrysingerENVCRC-$(CONFIG_ENV_IS_IN_ONENAND) = y
282ad6e27dSMike FrysingerENVCRC-$(CONFIG_ENV_IS_IN_NAND) = y
292ad6e27dSMike FrysingerENVCRC-$(CONFIG_ENV_IS_IN_NVRAM) = y
302ad6e27dSMike FrysingerENVCRC-$(CONFIG_ENV_IS_IN_SPI_FLASH) = y
312ad6e27dSMike FrysingerCONFIG_BUILD_ENVCRC ?= $(ENVCRC-y)
322ad6e27dSMike Frysinger
3396b09a97SMasahiro Yamadahostprogs-$(CONFIG_SPL_GENERATE_ATMEL_PMECC_HEADER) += atmel_pmecc_params
345c390a5bSAndreas Bießmann
3596b09a97SMasahiro Yamadahostprogs-$(CONFIG_LCD_LOGO) += bmp_logo
3696b09a97SMasahiro Yamadahostprogs-$(CONFIG_VIDEO_LOGO) += bmp_logo
3796b09a97SMasahiro YamadaHOSTCFLAGS_bmp_logo.o := -pedantic
38ee3584a5SPeter Tyser
3996b09a97SMasahiro Yamadahostprogs-$(CONFIG_BUILD_ENVCRC) += envcrc
4096b09a97SMasahiro Yamadaenvcrc-objs := envcrc.o lib/crc32.o common/env_embedded.o lib/sha1.o
41940db16dSMasahiro Yamada
4296b09a97SMasahiro Yamadahostprogs-$(CONFIG_CMD_NET) += gen_eth_addr
4396b09a97SMasahiro YamadaHOSTCFLAGS_gen_eth_addr.o := -pedantic
44940db16dSMasahiro Yamada
45c25f01a6Soliver@schinagl.nlhostprogs-$(CONFIG_CMD_NET) += gen_ethaddr_crc
46c25f01a6Soliver@schinagl.nlgen_ethaddr_crc-objs := gen_ethaddr_crc.o lib/crc8.o
47c25f01a6Soliver@schinagl.nlHOSTCFLAGS_gen_ethaddr_crc.o := -pedantic
48c25f01a6Soliver@schinagl.nl
4996b09a97SMasahiro Yamadahostprogs-$(CONFIG_CMD_LOADS) += img2srec
5096b09a97SMasahiro YamadaHOSTCFLAGS_img2srec.o := -pedantic
51940db16dSMasahiro Yamada
5296b09a97SMasahiro Yamadahostprogs-$(CONFIG_XWAY_SWAP_BYTES) += xway-swap-bytes
5396b09a97SMasahiro YamadaHOSTCFLAGS_xway-swap-bytes.o := -pedantic
54940db16dSMasahiro Yamada
5596b09a97SMasahiro Yamadahostprogs-y += mkenvimage
5696b09a97SMasahiro Yamadamkenvimage-objs := mkenvimage.o os_support.o lib/crc32.o
57940db16dSMasahiro Yamada
5896b09a97SMasahiro Yamadahostprogs-y += dumpimage mkimage
5996b09a97SMasahiro Yamadahostprogs-$(CONFIG_FIT_SIGNATURE) += fit_info fit_check_sign
60940db16dSMasahiro Yamada
61ad80c4a3SMasahiro YamadaFIT_SIG_OBJS-$(CONFIG_FIT_SIGNATURE) := common/image-sig.o
62940db16dSMasahiro Yamada# Flattened device tree objects
63ad80c4a3SMasahiro YamadaLIBFDT_OBJS := $(addprefix lib/libfdt/, \
641043d0a0SSimon Glass			fdt.o fdt_ro.o fdt_rw.o fdt_strerror.o fdt_wip.o \
65e2070a89SSimon Glass			fdt_region.o fdt_sw.o)
66ad80c4a3SMasahiro YamadaRSA_OBJS-$(CONFIG_FIT_SIGNATURE) := $(addprefix lib/rsa/, \
67fc2f4246SRuchika Gupta					rsa-sign.o rsa-verify.o rsa-checksum.o \
68fc2f4246SRuchika Gupta					rsa-mod-exp.o)
69940db16dSMasahiro Yamada
709b03701aSSimon GlassROCKCHIP_OBS = lib/rc4.o rkcommon.o rkimage.o rksd.o rkspi.o
71a131c1f4SSimon Glass
72940db16dSMasahiro Yamada# common objs for dumpimage and mkimage
73940db16dSMasahiro Yamadadumpimage-mkimage-objs := aisimage.o \
747b1a4117SAndreas Bießmann			atmelimage.o \
75940db16dSMasahiro Yamada			$(FIT_SIG_OBJS-y) \
76ea51a628SSimon Glass			common/bootm.o \
77ad80c4a3SMasahiro Yamada			lib/crc32.o \
78940db16dSMasahiro Yamada			default_image.o \
79b047d671SHeiko Schocher			lib/fdtdec_common.o \
80ad80c4a3SMasahiro Yamada			lib/fdtdec.o \
816bf4ca07SHeiko Schocher			fit_common.o \
82940db16dSMasahiro Yamada			fit_image.o \
83ad80c4a3SMasahiro Yamada			common/image-fit.o \
84940db16dSMasahiro Yamada			image-host.o \
85ad80c4a3SMasahiro Yamada			common/image.o \
86940db16dSMasahiro Yamada			imagetool.o \
87940db16dSMasahiro Yamada			imximage.o \
88940db16dSMasahiro Yamada			kwbimage.o \
89ad80c4a3SMasahiro Yamada			lib/md5.o \
9039f520bbSAlbert ARIBAUD \(3ADEV\)			lpc32xximage.o \
91940db16dSMasahiro Yamada			mxsimage.o \
92940db16dSMasahiro Yamada			omapimage.o \
93940db16dSMasahiro Yamada			os_support.o \
94940db16dSMasahiro Yamada			pblimage.o \
95abbc67eeSCharles Manning			pbl_crc32.o \
96ed0c2c0aSAlbert ARIBAUD \(3ADEV\)			vybridimage.o \
97a131c1f4SSimon Glass			$(ROCKCHIP_OBS) \
98832472a9SCharles Manning			socfpgaimage.o \
99ad80c4a3SMasahiro Yamada			lib/sha1.o \
100ad80c4a3SMasahiro Yamada			lib/sha256.o \
1012dd90027SRuchika Gupta			common/hash.o \
102940db16dSMasahiro Yamada			ublimage.o \
10366eef1e7SNathan Rossi			zynqimage.o \
104d9b58b30SMichal Simek			zynqmpimage.o \
105940db16dSMasahiro Yamada			$(LIBFDT_OBJS) \
106969cd1faSStefano Babic			gpimage.o \
107969cd1faSStefano Babic			gpimage-common.o \
108940db16dSMasahiro Yamada			$(RSA_OBJS-y)
109940db16dSMasahiro Yamada
11096b09a97SMasahiro Yamadadumpimage-objs := $(dumpimage-mkimage-objs) dumpimage.o
11196b09a97SMasahiro Yamadamkimage-objs   := $(dumpimage-mkimage-objs) mkimage.o
11296b09a97SMasahiro Yamadafit_info-objs   := $(dumpimage-mkimage-objs) fit_info.o
11396b09a97SMasahiro Yamadafit_check_sign-objs   := $(dumpimage-mkimage-objs) fit_check_sign.o
114940db16dSMasahiro Yamada
115162a7a42SSimon Glass# Build a libfdt Python module if swig is available
116162a7a42SSimon Glass# Use 'sudo apt-get install swig libpython-dev' to enable this
1171905c8fcSEmmanuel Vadothostprogs-y += \
118d0fc6dc5SAndre Przywara	$(if $(shell which swig 2> /dev/null),_libfdt.so)
11976bce10dSSimon Glass_libfdt.so-sharedobjs += $(LIBFDT_OBJS)
12076bce10dSSimon Glasslibfdt:
12176bce10dSSimon Glass
12276bce10dSSimon Glasstools/_libfdt.so: $(patsubst %.o,%.c,$(LIBFDT_OBJS)) tools/libfdt_wrap.c
123*b48bfc74SStefano Babic	LDFLAGS="$(HOSTLDFLAGS)" CFLAGS= ${PYTHON} $(srctree)/lib/libfdt/setup.py \
12455be9b36STom Rini		"$(_hostc_flags)" $^
12576bce10dSSimon Glass	mv _libfdt.so $@
12676bce10dSSimon Glass
12776bce10dSSimon Glasstools/libfdt_wrap.c: $(srctree)/lib/libfdt/libfdt.swig
12876bce10dSSimon Glass	swig -python -o $@ $<
12976bce10dSSimon Glass
130940db16dSMasahiro Yamada# TODO(sjg@chromium.org): Is this correct on Mac OS?
131940db16dSMasahiro Yamada
132940db16dSMasahiro Yamadaifneq ($(CONFIG_MX23)$(CONFIG_MX28),)
133940db16dSMasahiro Yamada# Add CONFIG_MXS into host CFLAGS, so we can check whether or not register
134940db16dSMasahiro Yamada# the mxsimage support within tools/mxsimage.c .
1356825a95bSMasahiro YamadaHOSTCFLAGS_mxsimage.o += -DCONFIG_MXS
136940db16dSMasahiro Yamadaendif
137940db16dSMasahiro Yamada
138940db16dSMasahiro Yamadaifdef CONFIG_FIT_SIGNATURE
139940db16dSMasahiro Yamada# This affects include/image.h, but including the board config file
140940db16dSMasahiro Yamada# is tricky, so manually define this options here.
141940db16dSMasahiro YamadaHOST_EXTRACFLAGS	+= -DCONFIG_FIT_SIGNATURE
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
162c6e3e821SAndreas BießmannHOSTCFLAGS_rsa-sign.o += -Wno-deprecated-declarations
163c6e3e821SAndreas Bießmannendif
16497cb4e54SMasahiro Yamadaendif
16597cb4e54SMasahiro Yamada
16696b09a97SMasahiro YamadaHOSTLOADLIBES_dumpimage := $(HOSTLOADLIBES_mkimage)
16796b09a97SMasahiro YamadaHOSTLOADLIBES_fit_info := $(HOSTLOADLIBES_mkimage)
16896b09a97SMasahiro YamadaHOSTLOADLIBES_fit_check_sign := $(HOSTLOADLIBES_mkimage)
16997cb4e54SMasahiro Yamada
17096b09a97SMasahiro Yamadahostprogs-$(CONFIG_EXYNOS5250) += mkexynosspl
17196b09a97SMasahiro Yamadahostprogs-$(CONFIG_EXYNOS5420) += mkexynosspl
17296b09a97SMasahiro YamadaHOSTCFLAGS_mkexynosspl.o := -pedantic
173940db16dSMasahiro Yamada
17431eca697SSimon Glassifdtool-objs := $(LIBFDT_OBJS) ifdtool.o
175cd392fe8SSimon Glasshostprogs-$(CONFIG_X86) += ifdtool
176cd392fe8SSimon Glass
17796b09a97SMasahiro Yamadahostprogs-$(CONFIG_MX23) += mxsboot
17896b09a97SMasahiro Yamadahostprogs-$(CONFIG_MX28) += mxsboot
17996b09a97SMasahiro YamadaHOSTCFLAGS_mxsboot.o := -pedantic
180940db16dSMasahiro Yamada
181aec9a0f1SJagan Tekihostprogs-$(CONFIG_ARCH_SUNXI) += mksunxiboot
182594b4cc7SMaxime Ripardhostprogs-$(CONFIG_ARCH_SUNXI) += sunxi-spl-image-builder
183594b4cc7SMaxime Ripardsunxi-spl-image-builder-objs := sunxi-spl-image-builder.o lib/bch.o
18450827a59SIan Campbell
18596b09a97SMasahiro Yamadahostprogs-$(CONFIG_NETCONSOLE) += ncb
18696b09a97SMasahiro Yamadahostprogs-$(CONFIG_SHA1_CHECK_UB_IMG) += ubsha1
187940db16dSMasahiro Yamada
18896b09a97SMasahiro Yamadaubsha1-objs := os_support.o ubsha1.o lib/sha1.o
189940db16dSMasahiro Yamada
190940db16dSMasahiro YamadaHOSTCFLAGS_ubsha1.o := -pedantic
191940db16dSMasahiro Yamada
19296b09a97SMasahiro Yamadahostprogs-$(CONFIG_KIRKWOOD) += kwboot
19381e33f4bSStefan Roesehostprogs-$(CONFIG_ARCH_MVEBU) += kwboot
19496b09a97SMasahiro Yamadahostprogs-y += proftool
19596b09a97SMasahiro Yamadahostprogs-$(CONFIG_STATIC_RELA) += relocate-rela
196940db16dSMasahiro Yamada
1971043d0a0SSimon Glasshostprogs-y += fdtgrep
1981043d0a0SSimon Glassfdtgrep-objs += $(LIBFDT_OBJS) fdtgrep.o
1991043d0a0SSimon Glass
200940db16dSMasahiro Yamada# We build some files with extra pedantic flags to try to minimize things
201940db16dSMasahiro Yamada# that won't build on some weird host compiler -- though there are lots of
202940db16dSMasahiro Yamada# exceptions for files that aren't complaint.
203940db16dSMasahiro YamadaHOSTCFLAGS_crc32.o := -pedantic
2041d3c5392Soliver@schinagl.nlHOSTCFLAGS_crc8.o := -pedantic
205940db16dSMasahiro YamadaHOSTCFLAGS_md5.o := -pedantic
206940db16dSMasahiro YamadaHOSTCFLAGS_sha1.o := -pedantic
2072842c1c2SHeiko SchocherHOSTCFLAGS_sha256.o := -pedantic
208ee3584a5SPeter Tyser
209ad80c4a3SMasahiro Yamadaquiet_cmd_wrap = WRAP    $@
210ffe29ebcSMasahiro Yamadacmd_wrap = echo "\#include <../$(patsubst $(obj)/%,%,$@)>" >$@
211ad80c4a3SMasahiro Yamada
212ad80c4a3SMasahiro Yamada$(obj)/lib/%.c $(obj)/common/%.c:
213ad80c4a3SMasahiro Yamada	$(call cmd,wrap)
214ad80c4a3SMasahiro Yamada
215ad80c4a3SMasahiro Yamadaclean-dirs := lib common
216ad80c4a3SMasahiro Yamada
217940db16dSMasahiro Yamadaalways := $(hostprogs-y)
21819c402afSSimon Glass
219335ffe7eSPeter Tyser# Generated LCD/video logo
2209e414032SMasahiro YamadaLOGO_H = $(objtree)/include/bmp_logo.h
2219e414032SMasahiro YamadaLOGO_DATA_H = $(objtree)/include/bmp_logo_data.h
222335ffe7eSPeter TyserLOGO-$(CONFIG_LCD_LOGO) += $(LOGO_H)
223c270730fSChe-Liang ChiouLOGO-$(CONFIG_LCD_LOGO) += $(LOGO_DATA_H)
224335ffe7eSPeter TyserLOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_H)
225c270730fSChe-Liang ChiouLOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_DATA_H)
226ee3584a5SPeter Tyser
22796903daeSOtavio Salvador# Generic logo
228ee3584a5SPeter Tyserifeq ($(LOGO_BMP),)
2299e414032SMasahiro YamadaLOGO_BMP= $(srctree)/$(src)/logos/denx.bmp
23096903daeSOtavio Salvador
23196903daeSOtavio Salvador# Use board logo and fallback to vendor
232603f51cbSMasahiro Yamadaifneq ($(wildcard $(srctree)/$(src)/logos/$(BOARD).bmp),)
2339e414032SMasahiro YamadaLOGO_BMP= $(srctree)/$(src)/logos/$(BOARD).bmp
23496903daeSOtavio Salvadorelse
235603f51cbSMasahiro Yamadaifneq ($(wildcard $(srctree)/$(src)/logos/$(VENDOR).bmp),)
2369e414032SMasahiro YamadaLOGO_BMP= $(srctree)/$(src)/logos/$(VENDOR).bmp
237ee3584a5SPeter Tyserendif
238ee3584a5SPeter Tyserendif
23996903daeSOtavio Salvador
24096903daeSOtavio Salvadorendif # !LOGO_BMP
241ee3584a5SPeter Tyser
242efee1709Swdenk#
243efee1709Swdenk# Use native tools and options
2442f8d396bSPeter Tyser# Define __KERNEL_STRICT_NAMES to prevent typedef overlaps
2452db1c3fcSYork Sun# Define _GNU_SOURCE to obtain the getline prototype from stdio.h
246efee1709Swdenk#
24701286329SMasahiro YamadaHOST_EXTRACFLAGS += -include $(srctree)/include/libfdt_env.h \
24851148790SMasahiro Yamada		$(patsubst -I%,-idirafter%, $(filter -I%, $(UBOOTINCLUDE))) \
24901286329SMasahiro Yamada		-I$(srctree)/lib/libfdt \
25001286329SMasahiro Yamada		-I$(srctree)/tools \
25114d0a02aSWolfgang Denk		-DUSE_HOSTCC \
2522db1c3fcSYork Sun		-D__KERNEL_STRICT_NAMES \
2532db1c3fcSYork Sun		-D_GNU_SOURCE
2548cf30809SBartlomiej Sieka
255d726f225SMasahiro Yamada__build:	$(LOGO-y)
256efee1709Swdenk
2579e414032SMasahiro Yamada$(LOGO_H):	$(obj)/bmp_logo $(LOGO_BMP)
2589e414032SMasahiro Yamada	$(obj)/bmp_logo --gen-info $(LOGO_BMP) > $@
259c270730fSChe-Liang Chiou
2609e414032SMasahiro Yamada$(LOGO_DATA_H):	$(obj)/bmp_logo $(LOGO_BMP)
2619e414032SMasahiro Yamada	$(obj)/bmp_logo --gen-data $(LOGO_BMP) > $@
2622887c473SMasahiro Yamada
2632887c473SMasahiro Yamada# Let clean descend into subdirs
2642887c473SMasahiro Yamadasubdir- += env
265db5b339cSMasahiro Yamada
266db5b339cSMasahiro Yamadaifneq ($(CROSS_BUILD_TOOLS),)
2673b082529SMasahiro Yamadaoverride HOSTCC = $(CC)
268db5b339cSMasahiro Yamada
269db5b339cSMasahiro Yamadaquiet_cmd_crosstools_strip = STRIP   $^
270db5b339cSMasahiro Yamada      cmd_crosstools_strip = $(STRIP) $^; touch $@
271db5b339cSMasahiro Yamada$(obj)/.strip: $(call objectify,$(filter $(always),$(hostprogs-y)))
272db5b339cSMasahiro Yamada	$(call cmd,crosstools_strip)
273db5b339cSMasahiro Yamada
274db5b339cSMasahiro Yamadaalways += .strip
275db5b339cSMasahiro Yamadaendif
276db5b339cSMasahiro Yamadaclean-files += .strip
277