xref: /rk3399_rockchip-uboot/tools/Makefile (revision cd392fe8a0b2d37f11c9224b1c979603d7abca48)
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
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_DATAFLASH) = 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
34940db16dSMasahiro Yamada# TODO: CONFIG_CMD_LICENSE does not work
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/, \
61ad80c4a3SMasahiro Yamada			fdt.o fdt_ro.o fdt_rw.o fdt_strerror.o fdt_wip.o)
62ad80c4a3SMasahiro YamadaRSA_OBJS-$(CONFIG_FIT_SIGNATURE) := $(addprefix lib/rsa/, \
63ad80c4a3SMasahiro Yamada					rsa-sign.o rsa-verify.o rsa-checksum.o)
64940db16dSMasahiro Yamada
65940db16dSMasahiro Yamada# common objs for dumpimage and mkimage
66940db16dSMasahiro Yamadadumpimage-mkimage-objs := aisimage.o \
677b1a4117SAndreas Bießmann			atmelimage.o \
68940db16dSMasahiro Yamada			$(FIT_SIG_OBJS-y) \
69ea51a628SSimon Glass			common/bootm.o \
70ad80c4a3SMasahiro Yamada			lib/crc32.o \
71940db16dSMasahiro Yamada			default_image.o \
72b047d671SHeiko Schocher			lib/fdtdec_common.o \
73ad80c4a3SMasahiro Yamada			lib/fdtdec.o \
746bf4ca07SHeiko Schocher			fit_common.o \
75940db16dSMasahiro Yamada			fit_image.o \
76bf411ea9SKaricheri, Muralidharan			gpimage.o \
77bf411ea9SKaricheri, Muralidharan			gpimage-common.o \
78ad80c4a3SMasahiro Yamada			common/image-fit.o \
79940db16dSMasahiro Yamada			image-host.o \
80ad80c4a3SMasahiro Yamada			common/image.o \
81940db16dSMasahiro Yamada			imagetool.o \
82940db16dSMasahiro Yamada			imximage.o \
83940db16dSMasahiro Yamada			kwbimage.o \
84ad80c4a3SMasahiro Yamada			lib/md5.o \
85940db16dSMasahiro Yamada			mxsimage.o \
86940db16dSMasahiro Yamada			omapimage.o \
87940db16dSMasahiro Yamada			os_support.o \
88940db16dSMasahiro Yamada			pblimage.o \
89abbc67eeSCharles Manning			pbl_crc32.o \
90832472a9SCharles Manning			socfpgaimage.o \
91ad80c4a3SMasahiro Yamada			lib/sha1.o \
92ad80c4a3SMasahiro Yamada			lib/sha256.o \
93940db16dSMasahiro Yamada			ublimage.o \
94940db16dSMasahiro Yamada			$(LIBFDT_OBJS) \
95940db16dSMasahiro Yamada			$(RSA_OBJS-y)
96940db16dSMasahiro Yamada
9796b09a97SMasahiro Yamadadumpimage-objs := $(dumpimage-mkimage-objs) dumpimage.o
9896b09a97SMasahiro Yamadamkimage-objs   := $(dumpimage-mkimage-objs) mkimage.o
9996b09a97SMasahiro Yamadafit_info-objs   := $(dumpimage-mkimage-objs) fit_info.o
10096b09a97SMasahiro Yamadafit_check_sign-objs   := $(dumpimage-mkimage-objs) fit_check_sign.o
101940db16dSMasahiro Yamada
102940db16dSMasahiro Yamada# TODO(sjg@chromium.org): Is this correct on Mac OS?
103940db16dSMasahiro Yamada
104940db16dSMasahiro Yamadaifneq ($(CONFIG_MX23)$(CONFIG_MX28),)
105940db16dSMasahiro Yamada# Add CONFIG_MXS into host CFLAGS, so we can check whether or not register
106940db16dSMasahiro Yamada# the mxsimage support within tools/mxsimage.c .
1076825a95bSMasahiro YamadaHOSTCFLAGS_mxsimage.o += -DCONFIG_MXS
108940db16dSMasahiro Yamadaendif
109940db16dSMasahiro Yamada
110940db16dSMasahiro Yamadaifdef CONFIG_FIT_SIGNATURE
111940db16dSMasahiro Yamada# This affects include/image.h, but including the board config file
112940db16dSMasahiro Yamada# is tricky, so manually define this options here.
113940db16dSMasahiro YamadaHOST_EXTRACFLAGS	+= -DCONFIG_FIT_SIGNATURE
114940db16dSMasahiro Yamadaendif
115940db16dSMasahiro Yamada
11697cb4e54SMasahiro Yamada# MXSImage needs LibSSL
11797cb4e54SMasahiro Yamadaifneq ($(CONFIG_MX23)$(CONFIG_MX28)$(CONFIG_FIT_SIGNATURE),)
11896b09a97SMasahiro YamadaHOSTLOADLIBES_mkimage += -lssl -lcrypto
11997cb4e54SMasahiro Yamadaendif
12097cb4e54SMasahiro Yamada
12196b09a97SMasahiro YamadaHOSTLOADLIBES_dumpimage := $(HOSTLOADLIBES_mkimage)
12296b09a97SMasahiro YamadaHOSTLOADLIBES_fit_info := $(HOSTLOADLIBES_mkimage)
12396b09a97SMasahiro YamadaHOSTLOADLIBES_fit_check_sign := $(HOSTLOADLIBES_mkimage)
12497cb4e54SMasahiro Yamada
12596b09a97SMasahiro Yamadahostprogs-$(CONFIG_EXYNOS5250) += mkexynosspl
12696b09a97SMasahiro Yamadahostprogs-$(CONFIG_EXYNOS5420) += mkexynosspl
12796b09a97SMasahiro YamadaHOSTCFLAGS_mkexynosspl.o := -pedantic
128940db16dSMasahiro Yamada
129*cd392fe8SSimon Glasshostprogs-$(CONFIG_X86) += ifdtool
130*cd392fe8SSimon Glass
13196b09a97SMasahiro Yamadahostprogs-$(CONFIG_MX23) += mxsboot
13296b09a97SMasahiro Yamadahostprogs-$(CONFIG_MX28) += mxsboot
13396b09a97SMasahiro YamadaHOSTCFLAGS_mxsboot.o := -pedantic
134940db16dSMasahiro Yamada
13596b09a97SMasahiro Yamadahostprogs-$(CONFIG_SUNXI) += mksunxiboot
13650827a59SIan Campbell
13796b09a97SMasahiro Yamadahostprogs-$(CONFIG_NETCONSOLE) += ncb
13896b09a97SMasahiro Yamadahostprogs-$(CONFIG_SHA1_CHECK_UB_IMG) += ubsha1
139940db16dSMasahiro Yamada
14096b09a97SMasahiro Yamadaubsha1-objs := os_support.o ubsha1.o lib/sha1.o
141940db16dSMasahiro Yamada
142940db16dSMasahiro YamadaHOSTCFLAGS_ubsha1.o := -pedantic
143940db16dSMasahiro Yamada
14496b09a97SMasahiro Yamadahostprogs-$(CONFIG_KIRKWOOD) += kwboot
1452afa3312SStefan Roesehostprogs-$(CONFIG_ARMADA_XP) += kwboot
14696b09a97SMasahiro Yamadahostprogs-y += proftool
14796b09a97SMasahiro Yamadahostprogs-$(CONFIG_STATIC_RELA) += relocate-rela
148940db16dSMasahiro Yamada
149940db16dSMasahiro Yamada# We build some files with extra pedantic flags to try to minimize things
150940db16dSMasahiro Yamada# that won't build on some weird host compiler -- though there are lots of
151940db16dSMasahiro Yamada# exceptions for files that aren't complaint.
152940db16dSMasahiro YamadaHOSTCFLAGS_crc32.o := -pedantic
153940db16dSMasahiro YamadaHOSTCFLAGS_md5.o := -pedantic
154940db16dSMasahiro YamadaHOSTCFLAGS_sha1.o := -pedantic
1552842c1c2SHeiko SchocherHOSTCFLAGS_sha256.o := -pedantic
156ee3584a5SPeter Tyser
157ee3584a5SPeter Tyser# Don't build by default
15896b09a97SMasahiro Yamada#hostprogs-$(CONFIG_PPC) += mpc86x_clk
15996b09a97SMasahiro Yamada#HOSTCFLAGS_mpc86x_clk.o := -pedantic
160ee3584a5SPeter Tyser
161ad80c4a3SMasahiro Yamadaquiet_cmd_wrap = WRAP    $@
162ffe29ebcSMasahiro Yamadacmd_wrap = echo "\#include <../$(patsubst $(obj)/%,%,$@)>" >$@
163ad80c4a3SMasahiro Yamada
164ad80c4a3SMasahiro Yamada$(obj)/lib/%.c $(obj)/common/%.c:
165ad80c4a3SMasahiro Yamada	$(call cmd,wrap)
166ad80c4a3SMasahiro Yamada
167ad80c4a3SMasahiro Yamadaclean-dirs := lib common
168ad80c4a3SMasahiro Yamada
169940db16dSMasahiro Yamadaalways := $(hostprogs-y)
17019c402afSSimon Glass
171335ffe7eSPeter Tyser# Generated LCD/video logo
1729e414032SMasahiro YamadaLOGO_H = $(objtree)/include/bmp_logo.h
1739e414032SMasahiro YamadaLOGO_DATA_H = $(objtree)/include/bmp_logo_data.h
174335ffe7eSPeter TyserLOGO-$(CONFIG_LCD_LOGO) += $(LOGO_H)
175c270730fSChe-Liang ChiouLOGO-$(CONFIG_LCD_LOGO) += $(LOGO_DATA_H)
176335ffe7eSPeter TyserLOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_H)
177c270730fSChe-Liang ChiouLOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_DATA_H)
178ee3584a5SPeter Tyser
17996903daeSOtavio Salvador# Generic logo
180ee3584a5SPeter Tyserifeq ($(LOGO_BMP),)
1819e414032SMasahiro YamadaLOGO_BMP= $(srctree)/$(src)/logos/denx.bmp
18296903daeSOtavio Salvador
18396903daeSOtavio Salvador# Use board logo and fallback to vendor
184603f51cbSMasahiro Yamadaifneq ($(wildcard $(srctree)/$(src)/logos/$(BOARD).bmp),)
1859e414032SMasahiro YamadaLOGO_BMP= $(srctree)/$(src)/logos/$(BOARD).bmp
18696903daeSOtavio Salvadorelse
187603f51cbSMasahiro Yamadaifneq ($(wildcard $(srctree)/$(src)/logos/$(VENDOR).bmp),)
1889e414032SMasahiro YamadaLOGO_BMP= $(srctree)/$(src)/logos/$(VENDOR).bmp
189ee3584a5SPeter Tyserendif
190ee3584a5SPeter Tyserendif
19196903daeSOtavio Salvador
19296903daeSOtavio Salvadorendif # !LOGO_BMP
193ee3584a5SPeter Tyser
194efee1709Swdenk#
195efee1709Swdenk# Use native tools and options
1962f8d396bSPeter Tyser# Define __KERNEL_STRICT_NAMES to prevent typedef overlaps
1972db1c3fcSYork Sun# Define _GNU_SOURCE to obtain the getline prototype from stdio.h
198efee1709Swdenk#
19901286329SMasahiro YamadaHOST_EXTRACFLAGS += -include $(srctree)/include/libfdt_env.h \
20051148790SMasahiro Yamada		$(patsubst -I%,-idirafter%, $(filter -I%, $(UBOOTINCLUDE))) \
20101286329SMasahiro Yamada		-I$(srctree)/lib/libfdt \
20201286329SMasahiro Yamada		-I$(srctree)/tools \
20314d0a02aSWolfgang Denk		-DCONFIG_SYS_TEXT_BASE=$(CONFIG_SYS_TEXT_BASE) \
20414d0a02aSWolfgang Denk		-DUSE_HOSTCC \
2052db1c3fcSYork Sun		-D__KERNEL_STRICT_NAMES \
2062db1c3fcSYork Sun		-D_GNU_SOURCE
2078cf30809SBartlomiej Sieka
2086825a95bSMasahiro Yamada__build:	$(LOGO-y)
209efee1709Swdenk
2109e414032SMasahiro Yamada$(LOGO_H):	$(obj)/bmp_logo $(LOGO_BMP)
2119e414032SMasahiro Yamada	$(obj)/bmp_logo --gen-info $(LOGO_BMP) > $@
212c270730fSChe-Liang Chiou
2139e414032SMasahiro Yamada$(LOGO_DATA_H):	$(obj)/bmp_logo $(LOGO_BMP)
2149e414032SMasahiro Yamada	$(obj)/bmp_logo --gen-data $(LOGO_BMP) > $@
2152887c473SMasahiro Yamada
2162887c473SMasahiro Yamada# Let clean descend into subdirs
2172887c473SMasahiro Yamadasubdir- += env
218db5b339cSMasahiro Yamada
219db5b339cSMasahiro Yamadaifneq ($(CROSS_BUILD_TOOLS),)
220db5b339cSMasahiro YamadaHOSTCC = $(CC)
221db5b339cSMasahiro Yamada
222db5b339cSMasahiro Yamadaquiet_cmd_crosstools_strip = STRIP   $^
223db5b339cSMasahiro Yamada      cmd_crosstools_strip = $(STRIP) $^; touch $@
224db5b339cSMasahiro Yamada$(obj)/.strip: $(call objectify,$(filter $(always),$(hostprogs-y)))
225db5b339cSMasahiro Yamada	$(call cmd,crosstools_strip)
226db5b339cSMasahiro Yamada
227db5b339cSMasahiro Yamadaalways += .strip
228db5b339cSMasahiro Yamadaendif
229db5b339cSMasahiro Yamadaclean-files += .strip
230