xref: /rk3399_rockchip-uboot/tools/Makefile (revision a1b6b0a9c1f91756b93e6d804837dc178d79d39e)
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_CMD_LICENSE) += bin2header
3696b09a97SMasahiro Yamadahostprogs-$(CONFIG_LCD_LOGO) += bmp_logo
3796b09a97SMasahiro Yamadahostprogs-$(CONFIG_VIDEO_LOGO) += bmp_logo
3896b09a97SMasahiro YamadaHOSTCFLAGS_bmp_logo.o := -pedantic
39ee3584a5SPeter Tyser
4096b09a97SMasahiro Yamadahostprogs-$(CONFIG_BUILD_ENVCRC) += envcrc
4196b09a97SMasahiro Yamadaenvcrc-objs := envcrc.o lib/crc32.o common/env_embedded.o lib/sha1.o
42940db16dSMasahiro Yamada
4396b09a97SMasahiro Yamadahostprogs-$(CONFIG_CMD_NET) += gen_eth_addr
4496b09a97SMasahiro YamadaHOSTCFLAGS_gen_eth_addr.o := -pedantic
45940db16dSMasahiro Yamada
4696b09a97SMasahiro Yamadahostprogs-$(CONFIG_CMD_LOADS) += img2srec
4796b09a97SMasahiro YamadaHOSTCFLAGS_img2srec.o := -pedantic
48940db16dSMasahiro Yamada
4996b09a97SMasahiro Yamadahostprogs-$(CONFIG_XWAY_SWAP_BYTES) += xway-swap-bytes
5096b09a97SMasahiro YamadaHOSTCFLAGS_xway-swap-bytes.o := -pedantic
51940db16dSMasahiro Yamada
5296b09a97SMasahiro Yamadahostprogs-y += mkenvimage
5396b09a97SMasahiro Yamadamkenvimage-objs := mkenvimage.o os_support.o lib/crc32.o
54940db16dSMasahiro Yamada
5596b09a97SMasahiro Yamadahostprogs-y += dumpimage mkimage
5696b09a97SMasahiro Yamadahostprogs-$(CONFIG_FIT_SIGNATURE) += fit_info fit_check_sign
57940db16dSMasahiro Yamada
58ad80c4a3SMasahiro YamadaFIT_SIG_OBJS-$(CONFIG_FIT_SIGNATURE) := common/image-sig.o
59940db16dSMasahiro Yamada# Flattened device tree objects
60ad80c4a3SMasahiro YamadaLIBFDT_OBJS := $(addprefix lib/libfdt/, \
611043d0a0SSimon Glass			fdt.o fdt_ro.o fdt_rw.o fdt_strerror.o fdt_wip.o \
62e2070a89SSimon Glass			fdt_region.o fdt_sw.o)
63ad80c4a3SMasahiro YamadaRSA_OBJS-$(CONFIG_FIT_SIGNATURE) := $(addprefix lib/rsa/, \
64fc2f4246SRuchika Gupta					rsa-sign.o rsa-verify.o rsa-checksum.o \
65fc2f4246SRuchika Gupta					rsa-mod-exp.o)
66940db16dSMasahiro Yamada
679b03701aSSimon GlassROCKCHIP_OBS = lib/rc4.o rkcommon.o rkimage.o rksd.o rkspi.o
68a131c1f4SSimon Glass
69940db16dSMasahiro Yamada# common objs for dumpimage and mkimage
70940db16dSMasahiro Yamadadumpimage-mkimage-objs := aisimage.o \
717b1a4117SAndreas Bießmann			atmelimage.o \
72940db16dSMasahiro Yamada			$(FIT_SIG_OBJS-y) \
73ea51a628SSimon Glass			common/bootm.o \
74ad80c4a3SMasahiro Yamada			lib/crc32.o \
75940db16dSMasahiro Yamada			default_image.o \
76b047d671SHeiko Schocher			lib/fdtdec_common.o \
77ad80c4a3SMasahiro Yamada			lib/fdtdec.o \
786bf4ca07SHeiko Schocher			fit_common.o \
79940db16dSMasahiro Yamada			fit_image.o \
80ad80c4a3SMasahiro Yamada			common/image-fit.o \
81940db16dSMasahiro Yamada			image-host.o \
82ad80c4a3SMasahiro Yamada			common/image.o \
83940db16dSMasahiro Yamada			imagetool.o \
84940db16dSMasahiro Yamada			imximage.o \
85940db16dSMasahiro Yamada			kwbimage.o \
86ad80c4a3SMasahiro Yamada			lib/md5.o \
8739f520bbSAlbert ARIBAUD \(3ADEV\)			lpc32xximage.o \
88940db16dSMasahiro Yamada			mxsimage.o \
89940db16dSMasahiro Yamada			omapimage.o \
90940db16dSMasahiro Yamada			os_support.o \
91940db16dSMasahiro Yamada			pblimage.o \
92abbc67eeSCharles Manning			pbl_crc32.o \
93ed0c2c0aSAlbert ARIBAUD \(3ADEV\)			vybridimage.o \
94a131c1f4SSimon Glass			$(ROCKCHIP_OBS) \
95832472a9SCharles Manning			socfpgaimage.o \
96ad80c4a3SMasahiro Yamada			lib/sha1.o \
97ad80c4a3SMasahiro Yamada			lib/sha256.o \
982dd90027SRuchika Gupta			common/hash.o \
99940db16dSMasahiro Yamada			ublimage.o \
10066eef1e7SNathan Rossi			zynqimage.o \
101d9b58b30SMichal Simek			zynqmpimage.o \
102940db16dSMasahiro Yamada			$(LIBFDT_OBJS) \
103969cd1faSStefano Babic			gpimage.o \
104969cd1faSStefano Babic			gpimage-common.o \
105940db16dSMasahiro Yamada			$(RSA_OBJS-y)
106940db16dSMasahiro Yamada
10796b09a97SMasahiro Yamadadumpimage-objs := $(dumpimage-mkimage-objs) dumpimage.o
10896b09a97SMasahiro Yamadamkimage-objs   := $(dumpimage-mkimage-objs) mkimage.o
10996b09a97SMasahiro Yamadafit_info-objs   := $(dumpimage-mkimage-objs) fit_info.o
11096b09a97SMasahiro Yamadafit_check_sign-objs   := $(dumpimage-mkimage-objs) fit_check_sign.o
111940db16dSMasahiro Yamada
112162a7a42SSimon Glass# Build a libfdt Python module if swig is available
113162a7a42SSimon Glass# Use 'sudo apt-get install swig libpython-dev' to enable this
1141905c8fcSEmmanuel Vadothostprogs-y += \
115d0fc6dc5SAndre Przywara	$(if $(shell which swig 2> /dev/null),_libfdt.so)
11676bce10dSSimon Glass_libfdt.so-sharedobjs += $(LIBFDT_OBJS)
11776bce10dSSimon Glasslibfdt:
11876bce10dSSimon Glass
11976bce10dSSimon Glasstools/_libfdt.so: $(patsubst %.o,%.c,$(LIBFDT_OBJS)) tools/libfdt_wrap.c
12055be9b36STom Rini	LDFLAGS="$(HOSTLDFLAGS)" python $(srctree)/lib/libfdt/setup.py \
12155be9b36STom Rini		"$(_hostc_flags)" $^
12276bce10dSSimon Glass	mv _libfdt.so $@
12376bce10dSSimon Glass
12476bce10dSSimon Glasstools/libfdt_wrap.c: $(srctree)/lib/libfdt/libfdt.swig
12576bce10dSSimon Glass	swig -python -o $@ $<
12676bce10dSSimon Glass
127940db16dSMasahiro Yamada# TODO(sjg@chromium.org): Is this correct on Mac OS?
128940db16dSMasahiro Yamada
129940db16dSMasahiro Yamadaifneq ($(CONFIG_MX23)$(CONFIG_MX28),)
130940db16dSMasahiro Yamada# Add CONFIG_MXS into host CFLAGS, so we can check whether or not register
131940db16dSMasahiro Yamada# the mxsimage support within tools/mxsimage.c .
1326825a95bSMasahiro YamadaHOSTCFLAGS_mxsimage.o += -DCONFIG_MXS
133940db16dSMasahiro Yamadaendif
134940db16dSMasahiro Yamada
135940db16dSMasahiro Yamadaifdef CONFIG_FIT_SIGNATURE
136940db16dSMasahiro Yamada# This affects include/image.h, but including the board config file
137940db16dSMasahiro Yamada# is tricky, so manually define this options here.
138940db16dSMasahiro YamadaHOST_EXTRACFLAGS	+= -DCONFIG_FIT_SIGNATURE
139940db16dSMasahiro Yamadaendif
140940db16dSMasahiro Yamada
1417ddf8cfbSStefan Roeseifdef CONFIG_SYS_U_BOOT_OFFS
1427ddf8cfbSStefan RoeseHOSTCFLAGS_kwbimage.o += -DCONFIG_SYS_U_BOOT_OFFS=$(CONFIG_SYS_U_BOOT_OFFS)
143e35c6c79STom Riniendif
144e35c6c79STom Rini
145*a1b6b0a9SMario Sixifneq ($(CONFIG_ARMADA_38X)$(CONFIG_ARMADA_39X),)
146*a1b6b0a9SMario SixHOSTCFLAGS_kwbimage.o += -DCONFIG_KWB_SECURE
147*a1b6b0a9SMario Sixendif
148*a1b6b0a9SMario Six
14997cb4e54SMasahiro Yamada# MXSImage needs LibSSL
150*a1b6b0a9SMario Sixifneq ($(CONFIG_MX23)$(CONFIG_MX28)$(CONFIG_ARMADA_38X)$(CONFIG_ARMADA_39X)$(CONFIG_FIT_SIGNATURE),)
1514839836aSThomas PetazzoniHOSTLOADLIBES_mkimage += \
1524839836aSThomas Petazzoni	$(shell pkg-config --libs libssl libcrypto 2> /dev/null || echo "-lssl -lcrypto")
153c6e3e821SAndreas Bießmann
154c6e3e821SAndreas Bießmann# OS X deprecate openssl in favour of CommonCrypto, supress deprecation
155c6e3e821SAndreas Bießmann# warnings on those systems
156c6e3e821SAndreas Bießmannifeq ($(HOSTOS),darwin)
157c6e3e821SAndreas BießmannHOSTCFLAGS_mxsimage.o += -Wno-deprecated-declarations
158c6e3e821SAndreas BießmannHOSTCFLAGS_image-sig.o += -Wno-deprecated-declarations
159c6e3e821SAndreas BießmannHOSTCFLAGS_rsa-sign.o += -Wno-deprecated-declarations
160c6e3e821SAndreas Bießmannendif
16197cb4e54SMasahiro Yamadaendif
16297cb4e54SMasahiro Yamada
16396b09a97SMasahiro YamadaHOSTLOADLIBES_dumpimage := $(HOSTLOADLIBES_mkimage)
16496b09a97SMasahiro YamadaHOSTLOADLIBES_fit_info := $(HOSTLOADLIBES_mkimage)
16596b09a97SMasahiro YamadaHOSTLOADLIBES_fit_check_sign := $(HOSTLOADLIBES_mkimage)
16697cb4e54SMasahiro Yamada
16796b09a97SMasahiro Yamadahostprogs-$(CONFIG_EXYNOS5250) += mkexynosspl
16896b09a97SMasahiro Yamadahostprogs-$(CONFIG_EXYNOS5420) += mkexynosspl
16996b09a97SMasahiro YamadaHOSTCFLAGS_mkexynosspl.o := -pedantic
170940db16dSMasahiro Yamada
17131eca697SSimon Glassifdtool-objs := $(LIBFDT_OBJS) ifdtool.o
172cd392fe8SSimon Glasshostprogs-$(CONFIG_X86) += ifdtool
173cd392fe8SSimon Glass
17496b09a97SMasahiro Yamadahostprogs-$(CONFIG_MX23) += mxsboot
17596b09a97SMasahiro Yamadahostprogs-$(CONFIG_MX28) += mxsboot
17696b09a97SMasahiro YamadaHOSTCFLAGS_mxsboot.o := -pedantic
177940db16dSMasahiro Yamada
178aec9a0f1SJagan Tekihostprogs-$(CONFIG_ARCH_SUNXI) += mksunxiboot
17950827a59SIan Campbell
18096b09a97SMasahiro Yamadahostprogs-$(CONFIG_NETCONSOLE) += ncb
18196b09a97SMasahiro Yamadahostprogs-$(CONFIG_SHA1_CHECK_UB_IMG) += ubsha1
182940db16dSMasahiro Yamada
18396b09a97SMasahiro Yamadaubsha1-objs := os_support.o ubsha1.o lib/sha1.o
184940db16dSMasahiro Yamada
185940db16dSMasahiro YamadaHOSTCFLAGS_ubsha1.o := -pedantic
186940db16dSMasahiro Yamada
18796b09a97SMasahiro Yamadahostprogs-$(CONFIG_KIRKWOOD) += kwboot
18881e33f4bSStefan Roesehostprogs-$(CONFIG_ARCH_MVEBU) += kwboot
18996b09a97SMasahiro Yamadahostprogs-y += proftool
19096b09a97SMasahiro Yamadahostprogs-$(CONFIG_STATIC_RELA) += relocate-rela
191940db16dSMasahiro Yamada
1921043d0a0SSimon Glasshostprogs-y += fdtgrep
1931043d0a0SSimon Glassfdtgrep-objs += $(LIBFDT_OBJS) fdtgrep.o
1941043d0a0SSimon Glass
195940db16dSMasahiro Yamada# We build some files with extra pedantic flags to try to minimize things
196940db16dSMasahiro Yamada# that won't build on some weird host compiler -- though there are lots of
197940db16dSMasahiro Yamada# exceptions for files that aren't complaint.
198940db16dSMasahiro YamadaHOSTCFLAGS_crc32.o := -pedantic
199940db16dSMasahiro YamadaHOSTCFLAGS_md5.o := -pedantic
200940db16dSMasahiro YamadaHOSTCFLAGS_sha1.o := -pedantic
2012842c1c2SHeiko SchocherHOSTCFLAGS_sha256.o := -pedantic
202ee3584a5SPeter Tyser
203ad80c4a3SMasahiro Yamadaquiet_cmd_wrap = WRAP    $@
204ffe29ebcSMasahiro Yamadacmd_wrap = echo "\#include <../$(patsubst $(obj)/%,%,$@)>" >$@
205ad80c4a3SMasahiro Yamada
206ad80c4a3SMasahiro Yamada$(obj)/lib/%.c $(obj)/common/%.c:
207ad80c4a3SMasahiro Yamada	$(call cmd,wrap)
208ad80c4a3SMasahiro Yamada
209ad80c4a3SMasahiro Yamadaclean-dirs := lib common
210ad80c4a3SMasahiro Yamada
211940db16dSMasahiro Yamadaalways := $(hostprogs-y)
21219c402afSSimon Glass
213335ffe7eSPeter Tyser# Generated LCD/video logo
2149e414032SMasahiro YamadaLOGO_H = $(objtree)/include/bmp_logo.h
2159e414032SMasahiro YamadaLOGO_DATA_H = $(objtree)/include/bmp_logo_data.h
216335ffe7eSPeter TyserLOGO-$(CONFIG_LCD_LOGO) += $(LOGO_H)
217c270730fSChe-Liang ChiouLOGO-$(CONFIG_LCD_LOGO) += $(LOGO_DATA_H)
218335ffe7eSPeter TyserLOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_H)
219c270730fSChe-Liang ChiouLOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_DATA_H)
220ee3584a5SPeter Tyser
22196903daeSOtavio Salvador# Generic logo
222ee3584a5SPeter Tyserifeq ($(LOGO_BMP),)
2239e414032SMasahiro YamadaLOGO_BMP= $(srctree)/$(src)/logos/denx.bmp
22496903daeSOtavio Salvador
22596903daeSOtavio Salvador# Use board logo and fallback to vendor
226603f51cbSMasahiro Yamadaifneq ($(wildcard $(srctree)/$(src)/logos/$(BOARD).bmp),)
2279e414032SMasahiro YamadaLOGO_BMP= $(srctree)/$(src)/logos/$(BOARD).bmp
22896903daeSOtavio Salvadorelse
229603f51cbSMasahiro Yamadaifneq ($(wildcard $(srctree)/$(src)/logos/$(VENDOR).bmp),)
2309e414032SMasahiro YamadaLOGO_BMP= $(srctree)/$(src)/logos/$(VENDOR).bmp
231ee3584a5SPeter Tyserendif
232ee3584a5SPeter Tyserendif
23396903daeSOtavio Salvador
23496903daeSOtavio Salvadorendif # !LOGO_BMP
235ee3584a5SPeter Tyser
2368a7367acSTom Rini# Generated gziped GPL-2.0 license text
2378a7367acSTom RiniLICENSE_H = $(objtree)/include/license.h
2388a7367acSTom RiniLICENSE-$(CONFIG_CMD_LICENSE) += $(LICENSE_H)
2398a7367acSTom Rini
240efee1709Swdenk#
241efee1709Swdenk# Use native tools and options
2422f8d396bSPeter Tyser# Define __KERNEL_STRICT_NAMES to prevent typedef overlaps
2432db1c3fcSYork Sun# Define _GNU_SOURCE to obtain the getline prototype from stdio.h
244efee1709Swdenk#
24501286329SMasahiro YamadaHOST_EXTRACFLAGS += -include $(srctree)/include/libfdt_env.h \
24651148790SMasahiro Yamada		$(patsubst -I%,-idirafter%, $(filter -I%, $(UBOOTINCLUDE))) \
24701286329SMasahiro Yamada		-I$(srctree)/lib/libfdt \
24801286329SMasahiro Yamada		-I$(srctree)/tools \
24914d0a02aSWolfgang Denk		-DCONFIG_SYS_TEXT_BASE=$(CONFIG_SYS_TEXT_BASE) \
25014d0a02aSWolfgang Denk		-DUSE_HOSTCC \
2512db1c3fcSYork Sun		-D__KERNEL_STRICT_NAMES \
2522db1c3fcSYork Sun		-D_GNU_SOURCE
2538cf30809SBartlomiej Sieka
2548a7367acSTom Rini__build:	$(LOGO-y) $(LICENSE-y)
255efee1709Swdenk
2569e414032SMasahiro Yamada$(LOGO_H):	$(obj)/bmp_logo $(LOGO_BMP)
2579e414032SMasahiro Yamada	$(obj)/bmp_logo --gen-info $(LOGO_BMP) > $@
258c270730fSChe-Liang Chiou
2599e414032SMasahiro Yamada$(LOGO_DATA_H):	$(obj)/bmp_logo $(LOGO_BMP)
2609e414032SMasahiro Yamada	$(obj)/bmp_logo --gen-data $(LOGO_BMP) > $@
2612887c473SMasahiro Yamada
2628a7367acSTom Rini$(LICENSE_H): $(obj)/bin2header $(srctree)/Licenses/gpl-2.0.txt
2638a7367acSTom Rini	cat $(srctree)/Licenses/gpl-2.0.txt | gzip -9 -c | \
2648a7367acSTom Rini		$(obj)/bin2header license_gzip > $(LICENSE_H)
2658a7367acSTom Rini
2662887c473SMasahiro Yamada# Let clean descend into subdirs
2672887c473SMasahiro Yamadasubdir- += env
268db5b339cSMasahiro Yamada
269db5b339cSMasahiro Yamadaifneq ($(CROSS_BUILD_TOOLS),)
270db5b339cSMasahiro YamadaHOSTCC = $(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