]> git.ipfire.org Git - people/ms/u-boot.git/blame - tools/Makefile
binman: Add add test for using an Intel MRC binary
[people/ms/u-boot.git] / tools / Makefile
CommitLineData
efee1709 1#
f9328639 2# (C) Copyright 2000-2006
efee1709
WD
3# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
4#
1a459660 5# SPDX-License-Identifier: GPL-2.0+
efee1709
WD
6#
7
c7c0d542
MF
8# Enable all the config-independent tools
9ifneq ($(HOST_TOOLS_ALL),)
10CONFIG_LCD_LOGO = y
570d7d50 11CONFIG_CMD_LOADS = y
c7c0d542 12CONFIG_CMD_NET = y
60b74bde 13CONFIG_XWAY_SWAP_BYTES = y
c7c0d542
MF
14CONFIG_NETCONSOLE = y
15CONFIG_SHA1_CHECK_UB_IMG = y
d8c0d99e 16CONFIG_ARCH_SUNXI = y
c7c0d542
MF
17endif
18
2887c473
MY
19subdir-$(HOST_TOOLS_ALL) += easylogo
20subdir-$(HOST_TOOLS_ALL) += gdb
21
2ad6e27d
MF
22# Merge all the different vars for envcrc into one
23ENVCRC-$(CONFIG_ENV_IS_EMBEDDED) = y
2ad6e27d
MF
24ENVCRC-$(CONFIG_ENV_IS_IN_EEPROM) = y
25ENVCRC-$(CONFIG_ENV_IS_IN_FLASH) = y
26ENVCRC-$(CONFIG_ENV_IS_IN_ONENAND) = y
27ENVCRC-$(CONFIG_ENV_IS_IN_NAND) = y
28ENVCRC-$(CONFIG_ENV_IS_IN_NVRAM) = y
29ENVCRC-$(CONFIG_ENV_IS_IN_SPI_FLASH) = y
30CONFIG_BUILD_ENVCRC ?= $(ENVCRC-y)
31
96b09a97 32hostprogs-$(CONFIG_SPL_GENERATE_ATMEL_PMECC_HEADER) += atmel_pmecc_params
5c390a5b 33
96b09a97
MY
34hostprogs-$(CONFIG_LCD_LOGO) += bmp_logo
35hostprogs-$(CONFIG_VIDEO_LOGO) += bmp_logo
36HOSTCFLAGS_bmp_logo.o := -pedantic
940db16d 37
96b09a97 38hostprogs-$(CONFIG_BUILD_ENVCRC) += envcrc
0649cd0d 39envcrc-objs := envcrc.o lib/crc32.o env/embedded.o lib/sha1.o
940db16d 40
96b09a97
MY
41hostprogs-$(CONFIG_CMD_NET) += gen_eth_addr
42HOSTCFLAGS_gen_eth_addr.o := -pedantic
ee3584a5 43
c25f01a6 44hostprogs-$(CONFIG_CMD_NET) += gen_ethaddr_crc
45gen_ethaddr_crc-objs := gen_ethaddr_crc.o lib/crc8.o
46HOSTCFLAGS_gen_ethaddr_crc.o := -pedantic
47
96b09a97
MY
48hostprogs-$(CONFIG_CMD_LOADS) += img2srec
49HOSTCFLAGS_img2srec.o := -pedantic
940db16d 50
96b09a97
MY
51hostprogs-$(CONFIG_XWAY_SWAP_BYTES) += xway-swap-bytes
52HOSTCFLAGS_xway-swap-bytes.o := -pedantic
940db16d 53
96b09a97
MY
54hostprogs-y += mkenvimage
55mkenvimage-objs := mkenvimage.o os_support.o lib/crc32.o
940db16d 56
96b09a97
MY
57hostprogs-y += dumpimage mkimage
58hostprogs-$(CONFIG_FIT_SIGNATURE) += fit_info fit_check_sign
940db16d 59
ad80c4a3 60FIT_SIG_OBJS-$(CONFIG_FIT_SIGNATURE) := common/image-sig.o
ee95d10b 61
b38ad663
MY
62# The following files are synced with upstream DTC.
63# Use synced versions from scripts/dtc/libfdt/.
64LIBFDT_SRCS_SYNCED := fdt.c fdt_sw.c fdt_strerror.c fdt_empty_tree.c \
65 fdt_addresses.c fdt_overlay.c
66# The following files are locally modified for U-Boot (unfotunately).
67# Use U-Boot own versions from lib/libfdt/.
68LIBFDT_SRCS_UNSYNCED := fdt_ro.c fdt_wip.c fdt_rw.c fdt_region.c
69
70LIBFDT_OBJS := $(addprefix libfdt/, $(patsubst %.c, %.o, $(LIBFDT_SRCS_SYNCED))) \
71 $(addprefix lib/libfdt/, $(patsubst %.c, %.o, $(LIBFDT_SRCS_UNSYNCED)))
330274f1 72
ad80c4a3 73RSA_OBJS-$(CONFIG_FIT_SIGNATURE) := $(addprefix lib/rsa/, \
fc2f4246
RG
74 rsa-sign.o rsa-verify.o rsa-checksum.o \
75 rsa-mod-exp.o)
940db16d 76
9b03701a 77ROCKCHIP_OBS = lib/rc4.o rkcommon.o rkimage.o rksd.o rkspi.o
a131c1f4 78
940db16d
MY
79# common objs for dumpimage and mkimage
80dumpimage-mkimage-objs := aisimage.o \
7b1a4117 81 atmelimage.o \
940db16d 82 $(FIT_SIG_OBJS-y) \
ea51a628 83 common/bootm.o \
ad80c4a3 84 lib/crc32.o \
940db16d 85 default_image.o \
b047d671 86 lib/fdtdec_common.o \
ad80c4a3 87 lib/fdtdec.o \
6bf4ca07 88 fit_common.o \
940db16d 89 fit_image.o \
ad80c4a3 90 common/image-fit.o \
940db16d 91 image-host.o \
ad80c4a3 92 common/image.o \
940db16d
MY
93 imagetool.o \
94 imximage.o \
95 kwbimage.o \
ad80c4a3 96 lib/md5.o \
39f520bb 97 lpc32xximage.o \
940db16d
MY
98 mxsimage.o \
99 omapimage.o \
100 os_support.o \
101 pblimage.o \
abbc67ee 102 pbl_crc32.o \
ed0c2c0a 103 vybridimage.o \
a131c1f4 104 $(ROCKCHIP_OBS) \
832472a9 105 socfpgaimage.o \
ad80c4a3
MY
106 lib/sha1.o \
107 lib/sha256.o \
2dd90027 108 common/hash.o \
940db16d 109 ublimage.o \
66eef1e7 110 zynqimage.o \
d9b58b30 111 zynqmpimage.o \
940db16d 112 $(LIBFDT_OBJS) \
969cd1fa
SB
113 gpimage.o \
114 gpimage-common.o \
940db16d
MY
115 $(RSA_OBJS-y)
116
96b09a97
MY
117dumpimage-objs := $(dumpimage-mkimage-objs) dumpimage.o
118mkimage-objs := $(dumpimage-mkimage-objs) mkimage.o
119fit_info-objs := $(dumpimage-mkimage-objs) fit_info.o
120fit_check_sign-objs := $(dumpimage-mkimage-objs) fit_check_sign.o
940db16d 121
940db16d 122ifneq ($(CONFIG_MX23)$(CONFIG_MX28),)
940db16d
MY
123# Add CONFIG_MXS into host CFLAGS, so we can check whether or not register
124# the mxsimage support within tools/mxsimage.c .
6825a95b 125HOSTCFLAGS_mxsimage.o += -DCONFIG_MXS
940db16d
MY
126endif
127
128ifdef CONFIG_FIT_SIGNATURE
940db16d
MY
129# This affects include/image.h, but including the board config file
130# is tricky, so manually define this options here.
131HOST_EXTRACFLAGS += -DCONFIG_FIT_SIGNATURE
132endif
133
7ddf8cfb
SR
134ifdef CONFIG_SYS_U_BOOT_OFFS
135HOSTCFLAGS_kwbimage.o += -DCONFIG_SYS_U_BOOT_OFFS=$(CONFIG_SYS_U_BOOT_OFFS)
e35c6c79
TR
136endif
137
a1b6b0a9
MS
138ifneq ($(CONFIG_ARMADA_38X)$(CONFIG_ARMADA_39X),)
139HOSTCFLAGS_kwbimage.o += -DCONFIG_KWB_SECURE
140endif
141
97cb4e54 142# MXSImage needs LibSSL
a1b6b0a9 143ifneq ($(CONFIG_MX23)$(CONFIG_MX28)$(CONFIG_ARMADA_38X)$(CONFIG_ARMADA_39X)$(CONFIG_FIT_SIGNATURE),)
4839836a
TP
144HOSTLOADLIBES_mkimage += \
145 $(shell pkg-config --libs libssl libcrypto 2> /dev/null || echo "-lssl -lcrypto")
c6e3e821
AB
146
147# OS X deprecate openssl in favour of CommonCrypto, supress deprecation
148# warnings on those systems
149ifeq ($(HOSTOS),darwin)
150HOSTCFLAGS_mxsimage.o += -Wno-deprecated-declarations
151HOSTCFLAGS_image-sig.o += -Wno-deprecated-declarations
152HOSTCFLAGS_rsa-sign.o += -Wno-deprecated-declarations
153endif
97cb4e54
MY
154endif
155
1f6049e2 156HOSTCFLAGS_fit_image.o += -DMKIMAGE_DTC=\"$(CONFIG_MKIMAGE_DTC_PATH)\"
47a52cd1 157
96b09a97
MY
158HOSTLOADLIBES_dumpimage := $(HOSTLOADLIBES_mkimage)
159HOSTLOADLIBES_fit_info := $(HOSTLOADLIBES_mkimage)
160HOSTLOADLIBES_fit_check_sign := $(HOSTLOADLIBES_mkimage)
97cb4e54 161
96b09a97
MY
162hostprogs-$(CONFIG_EXYNOS5250) += mkexynosspl
163hostprogs-$(CONFIG_EXYNOS5420) += mkexynosspl
164HOSTCFLAGS_mkexynosspl.o := -pedantic
940db16d 165
31eca697 166ifdtool-objs := $(LIBFDT_OBJS) ifdtool.o
cd392fe8
SG
167hostprogs-$(CONFIG_X86) += ifdtool
168
96b09a97
MY
169hostprogs-$(CONFIG_MX23) += mxsboot
170hostprogs-$(CONFIG_MX28) += mxsboot
171HOSTCFLAGS_mxsboot.o := -pedantic
940db16d 172
aec9a0f1 173hostprogs-$(CONFIG_ARCH_SUNXI) += mksunxiboot
594b4cc7
MR
174hostprogs-$(CONFIG_ARCH_SUNXI) += sunxi-spl-image-builder
175sunxi-spl-image-builder-objs := sunxi-spl-image-builder.o lib/bch.o
50827a59 176
96b09a97
MY
177hostprogs-$(CONFIG_NETCONSOLE) += ncb
178hostprogs-$(CONFIG_SHA1_CHECK_UB_IMG) += ubsha1
940db16d 179
96b09a97 180ubsha1-objs := os_support.o ubsha1.o lib/sha1.o
940db16d
MY
181
182HOSTCFLAGS_ubsha1.o := -pedantic
183
96b09a97 184hostprogs-$(CONFIG_KIRKWOOD) += kwboot
81e33f4b 185hostprogs-$(CONFIG_ARCH_MVEBU) += kwboot
96b09a97
MY
186hostprogs-y += proftool
187hostprogs-$(CONFIG_STATIC_RELA) += relocate-rela
ee3584a5 188
1043d0a0
SG
189hostprogs-y += fdtgrep
190fdtgrep-objs += $(LIBFDT_OBJS) fdtgrep.o
191
703ec9dd
PB
192hostprogs-$(CONFIG_MIPS) += mips-relocs
193
940db16d
MY
194# We build some files with extra pedantic flags to try to minimize things
195# that won't build on some weird host compiler -- though there are lots of
196# exceptions for files that aren't complaint.
197HOSTCFLAGS_crc32.o := -pedantic
1d3c5392 198HOSTCFLAGS_crc8.o := -pedantic
940db16d
MY
199HOSTCFLAGS_md5.o := -pedantic
200HOSTCFLAGS_sha1.o := -pedantic
2842c1c2 201HOSTCFLAGS_sha256.o := -pedantic
940db16d 202
ad80c4a3 203quiet_cmd_wrap = WRAP $@
ffe29ebc 204cmd_wrap = echo "\#include <../$(patsubst $(obj)/%,%,$@)>" >$@
ad80c4a3 205
0649cd0d 206$(obj)/lib/%.c $(obj)/common/%.c $(obj)/env/%.c:
ad80c4a3
MY
207 $(call cmd,wrap)
208
209clean-dirs := lib common
210
940db16d 211always := $(hostprogs-y)
19c402af 212
335ffe7e 213# Generated LCD/video logo
9e414032
MY
214LOGO_H = $(objtree)/include/bmp_logo.h
215LOGO_DATA_H = $(objtree)/include/bmp_logo_data.h
335ffe7e 216LOGO-$(CONFIG_LCD_LOGO) += $(LOGO_H)
c270730f 217LOGO-$(CONFIG_LCD_LOGO) += $(LOGO_DATA_H)
335ffe7e 218LOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_H)
c270730f 219LOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_DATA_H)
ee3584a5 220
96903dae 221# Generic logo
ee3584a5 222ifeq ($(LOGO_BMP),)
9e414032 223LOGO_BMP= $(srctree)/$(src)/logos/denx.bmp
96903dae
OS
224
225# Use board logo and fallback to vendor
603f51cb 226ifneq ($(wildcard $(srctree)/$(src)/logos/$(BOARD).bmp),)
9e414032 227LOGO_BMP= $(srctree)/$(src)/logos/$(BOARD).bmp
96903dae 228else
603f51cb 229ifneq ($(wildcard $(srctree)/$(src)/logos/$(VENDOR).bmp),)
9e414032 230LOGO_BMP= $(srctree)/$(src)/logos/$(VENDOR).bmp
ee3584a5 231endif
348de314 232endif
ee3584a5 233
96903dae
OS
234endif # !LOGO_BMP
235
efee1709
WD
236#
237# Use native tools and options
2f8d396b 238# Define __KERNEL_STRICT_NAMES to prevent typedef overlaps
2db1c3fc 239# Define _GNU_SOURCE to obtain the getline prototype from stdio.h
efee1709 240#
01286329 241HOST_EXTRACFLAGS += -include $(srctree)/include/libfdt_env.h \
51148790 242 $(patsubst -I%,-idirafter%, $(filter -I%, $(UBOOTINCLUDE))) \
01286329
MY
243 -I$(srctree)/lib/libfdt \
244 -I$(srctree)/tools \
14d0a02a 245 -DUSE_HOSTCC \
2db1c3fc
YS
246 -D__KERNEL_STRICT_NAMES \
247 -D_GNU_SOURCE
8cf30809 248
d726f225 249__build: $(LOGO-y)
efee1709 250
9e414032
MY
251$(LOGO_H): $(obj)/bmp_logo $(LOGO_BMP)
252 $(obj)/bmp_logo --gen-info $(LOGO_BMP) > $@
c270730f 253
9e414032
MY
254$(LOGO_DATA_H): $(obj)/bmp_logo $(LOGO_BMP)
255 $(obj)/bmp_logo --gen-data $(LOGO_BMP) > $@
2887c473
MY
256
257# Let clean descend into subdirs
258subdir- += env
db5b339c
MY
259
260ifneq ($(CROSS_BUILD_TOOLS),)
3b082529 261override HOSTCC = $(CC)
db5b339c
MY
262
263quiet_cmd_crosstools_strip = STRIP $^
264 cmd_crosstools_strip = $(STRIP) $^; touch $@
265$(obj)/.strip: $(call objectify,$(filter $(always),$(hostprogs-y)))
266 $(call cmd,crosstools_strip)
267
268always += .strip
269endif
270clean-files += .strip