u-boot: fit: add support to decrypt fit with aes
[platform/kernel/u-boot.git] / tools / Makefile
1 # SPDX-License-Identifier: GPL-2.0+
2 #
3 # (C) Copyright 2000-2006
4 # Wolfgang Denk, DENX Software Engineering, wd@denx.de.
5
6 # Enable all the config-independent tools
7 ifneq ($(HOST_TOOLS_ALL),)
8 CONFIG_KIRKWOOD = y
9 CONFIG_LCD_LOGO = y
10 CONFIG_CMD_LOADS = y
11 CONFIG_CMD_NET = y
12 CONFIG_XWAY_SWAP_BYTES = y
13 CONFIG_NETCONSOLE = y
14 CONFIG_SHA1_CHECK_UB_IMG = y
15 CONFIG_ARCH_SUNXI = y
16 endif
17
18 subdir-$(HOST_TOOLS_ALL) += gdb
19
20 # Merge all the different vars for envcrc into one
21 ENVCRC-$(CONFIG_ENV_IS_EMBEDDED) = y
22 ENVCRC-$(CONFIG_ENV_IS_IN_EEPROM) = y
23 ENVCRC-$(CONFIG_ENV_IS_IN_FLASH) = y
24 ENVCRC-$(CONFIG_ENV_IS_IN_ONENAND) = y
25 ENVCRC-$(CONFIG_ENV_IS_IN_NAND) = y
26 ENVCRC-$(CONFIG_ENV_IS_IN_NVRAM) = y
27 ENVCRC-$(CONFIG_ENV_IS_IN_SPI_FLASH) = y
28 CONFIG_BUILD_ENVCRC ?= $(ENVCRC-y)
29
30 hostprogs-$(CONFIG_SPL_GENERATE_ATMEL_PMECC_HEADER) += atmel_pmecc_params
31
32 hostprogs-$(CONFIG_LCD_LOGO) += bmp_logo
33 hostprogs-$(CONFIG_VIDEO_LOGO) += bmp_logo
34 HOSTCFLAGS_bmp_logo.o := -pedantic
35
36 hostprogs-$(CONFIG_BUILD_ENVCRC) += envcrc
37 envcrc-objs := envcrc.o lib/crc32.o env/embedded.o lib/sha1.o
38
39 hostprogs-$(CONFIG_CMD_NET) += gen_eth_addr
40 HOSTCFLAGS_gen_eth_addr.o := -pedantic
41
42 hostprogs-$(CONFIG_CMD_NET) += gen_ethaddr_crc
43 gen_ethaddr_crc-objs := gen_ethaddr_crc.o lib/crc8.o
44 HOSTCFLAGS_gen_ethaddr_crc.o := -pedantic
45
46 hostprogs-$(CONFIG_CMD_LOADS) += img2srec
47 HOSTCFLAGS_img2srec.o := -pedantic
48
49 hostprogs-$(CONFIG_XWAY_SWAP_BYTES) += xway-swap-bytes
50 HOSTCFLAGS_xway-swap-bytes.o := -pedantic
51
52 hostprogs-y += mkenvimage
53 mkenvimage-objs := mkenvimage.o os_support.o lib/crc32.o
54
55 hostprogs-y += dumpimage mkimage
56 hostprogs-$(CONFIG_FIT_SIGNATURE) += fit_info fit_check_sign
57
58 hostprogs-$(CONFIG_CMD_BOOTEFI_SELFTEST) += file2include
59
60 FIT_OBJS-$(CONFIG_FIT) := fit_common.o fit_image.o image-host.o common/image-fit.o
61 FIT_SIG_OBJS-$(CONFIG_FIT_SIGNATURE) := common/image-sig.o
62 FIT_CIPHER_OBJS-$(CONFIG_FIT_CIPHER) := common/image-cipher.o
63
64 # The following files are synced with upstream DTC.
65 # Use synced versions from scripts/dtc/libfdt/.
66 LIBFDT_SRCS_SYNCED := fdt.c fdt_wip.c fdt_sw.c fdt_rw.c \
67                 fdt_strerror.c fdt_empty_tree.c fdt_addresses.c fdt_overlay.c
68 # The following files are locally modified for U-Boot (unfotunately).
69 # Use U-Boot own versions from lib/libfdt/.
70 LIBFDT_SRCS_UNSYNCED := fdt_ro.c fdt_region.c
71
72 LIBFDT_OBJS := $(addprefix libfdt/, $(patsubst %.c, %.o, $(LIBFDT_SRCS_SYNCED))) \
73                $(addprefix lib/libfdt/, $(patsubst %.c, %.o, $(LIBFDT_SRCS_UNSYNCED)))
74
75 RSA_OBJS-$(CONFIG_FIT_SIGNATURE) := $(addprefix lib/rsa/, \
76                                         rsa-sign.o rsa-verify.o rsa-checksum.o \
77                                         rsa-mod-exp.o)
78
79 AES_OBJS-$(CONFIG_FIT_CIPHER) := $(addprefix lib/aes/, \
80                                         aes-encrypt.o aes-decrypt.o)
81
82 ROCKCHIP_OBS = lib/rc4.o rkcommon.o rkimage.o rksd.o rkspi.o
83
84 # common objs for dumpimage and mkimage
85 dumpimage-mkimage-objs := aisimage.o \
86                         atmelimage.o \
87                         $(FIT_OBJS-y) \
88                         $(FIT_SIG_OBJS-y) \
89                         $(FIT_CIPHER_OBJS-y) \
90                         common/bootm.o \
91                         lib/crc32.o \
92                         default_image.o \
93                         lib/fdtdec_common.o \
94                         lib/fdtdec.o \
95                         common/image.o \
96                         imagetool.o \
97                         imximage.o \
98                         imx8image.o \
99                         imx8mimage.o \
100                         kwbimage.o \
101                         lib/md5.o \
102                         lpc32xximage.o \
103                         mxsimage.o \
104                         omapimage.o \
105                         os_support.o \
106                         pblimage.o \
107                         pbl_crc32.o \
108                         vybridimage.o \
109                         stm32image.o \
110                         $(ROCKCHIP_OBS) \
111                         socfpgaimage.o \
112                         lib/crc16.o \
113                         lib/sha1.o \
114                         lib/sha256.o \
115                         common/hash.o \
116                         ublimage.o \
117                         zynqimage.o \
118                         zynqmpimage.o \
119                         zynqmpbif.o \
120                         $(LIBFDT_OBJS) \
121                         gpimage.o \
122                         gpimage-common.o \
123                         mtk_image.o \
124                         $(RSA_OBJS-y) \
125                         $(AES_OBJS-y)
126
127 dumpimage-objs := $(dumpimage-mkimage-objs) dumpimage.o
128 mkimage-objs   := $(dumpimage-mkimage-objs) mkimage.o
129 fit_info-objs   := $(dumpimage-mkimage-objs) fit_info.o
130 fit_check_sign-objs   := $(dumpimage-mkimage-objs) fit_check_sign.o
131 file2include-objs := file2include.o
132
133 ifneq ($(CONFIG_MX23)$(CONFIG_MX28)$(CONFIG_FIT_SIGNATURE),)
134 # Add CONFIG_MXS into host CFLAGS, so we can check whether or not register
135 # the mxsimage support within tools/mxsimage.c .
136 HOSTCFLAGS_mxsimage.o += -DCONFIG_MXS
137 endif
138
139 ifdef CONFIG_FIT_SIGNATURE
140 # This affects include/image.h, but including the board config file
141 # is tricky, so manually define this options here.
142 HOST_EXTRACFLAGS        += -DCONFIG_FIT_SIGNATURE
143 HOST_EXTRACFLAGS        += -DCONFIG_FIT_SIGNATURE_MAX_SIZE=$(CONFIG_FIT_SIGNATURE_MAX_SIZE)
144 endif
145
146 ifdef CONFIG_FIT_CIPHER
147 # This affects include/image.h, but including the board config file
148 # is tricky, so manually define this options here.
149 HOST_EXTRACFLAGS        += -DCONFIG_FIT_CIPHER
150 endif
151
152 ifdef CONFIG_SYS_U_BOOT_OFFS
153 HOSTCFLAGS_kwbimage.o += -DCONFIG_SYS_U_BOOT_OFFS=$(CONFIG_SYS_U_BOOT_OFFS)
154 endif
155
156 ifneq ($(CONFIG_ARMADA_38X)$(CONFIG_ARMADA_39X),)
157 HOSTCFLAGS_kwbimage.o += -DCONFIG_KWB_SECURE
158 endif
159
160 # MXSImage needs LibSSL
161 ifneq ($(CONFIG_MX23)$(CONFIG_MX28)$(CONFIG_ARMADA_38X)$(CONFIG_ARMADA_39X)$(CONFIG_FIT_SIGNATURE),)
162 HOSTCFLAGS_kwbimage.o += \
163         $(shell pkg-config --cflags libssl libcrypto 2> /dev/null || echo "")
164 HOSTLOADLIBES_mkimage += \
165         $(shell pkg-config --libs libssl libcrypto 2> /dev/null || echo "-lssl -lcrypto")
166
167 # OS X deprecate openssl in favour of CommonCrypto, supress deprecation
168 # warnings on those systems
169 ifeq ($(HOSTOS),darwin)
170 HOSTCFLAGS_mxsimage.o += -Wno-deprecated-declarations
171 HOSTCFLAGS_image-sig.o += -Wno-deprecated-declarations
172 HOSTCFLAGS_rsa-sign.o += -Wno-deprecated-declarations
173 endif
174 endif
175
176 HOSTCFLAGS_fit_image.o += -DMKIMAGE_DTC=\"$(CONFIG_MKIMAGE_DTC_PATH)\"
177
178 HOSTLOADLIBES_dumpimage := $(HOSTLOADLIBES_mkimage)
179 HOSTLOADLIBES_fit_info := $(HOSTLOADLIBES_mkimage)
180 HOSTLOADLIBES_fit_check_sign := $(HOSTLOADLIBES_mkimage)
181
182 hostprogs-$(CONFIG_EXYNOS5250) += mkexynosspl
183 hostprogs-$(CONFIG_EXYNOS5420) += mkexynosspl
184 HOSTCFLAGS_mkexynosspl.o := -pedantic
185
186 ifdtool-objs := $(LIBFDT_OBJS) ifdtool.o
187 hostprogs-$(CONFIG_X86) += ifdtool
188
189 ifwitool-objs := ifwitool.o
190 hostprogs-$(CONFIG_X86)$(CONFIG_SANDBOX) += ifwitool
191
192 hostprogs-$(CONFIG_MX23) += mxsboot
193 hostprogs-$(CONFIG_MX28) += mxsboot
194 HOSTCFLAGS_mxsboot.o := -pedantic
195
196 hostprogs-$(CONFIG_ARCH_SUNXI) += mksunxiboot
197 hostprogs-$(CONFIG_ARCH_SUNXI) += sunxi-spl-image-builder
198 sunxi-spl-image-builder-objs := sunxi-spl-image-builder.o lib/bch.o
199
200 hostprogs-$(CONFIG_NETCONSOLE) += ncb
201 hostprogs-$(CONFIG_SHA1_CHECK_UB_IMG) += ubsha1
202
203 ubsha1-objs := os_support.o ubsha1.o lib/sha1.o
204
205 HOSTCFLAGS_ubsha1.o := -pedantic
206
207 hostprogs-$(CONFIG_KIRKWOOD) += kwboot
208 hostprogs-$(CONFIG_ARCH_MVEBU) += kwboot
209 hostprogs-y += proftool
210 hostprogs-$(CONFIG_STATIC_RELA) += relocate-rela
211 hostprogs-$(CONFIG_RISCV) += prelink-riscv
212
213 hostprogs-y += fdtgrep
214 fdtgrep-objs += $(LIBFDT_OBJS) fdtgrep.o
215
216 ifneq ($(TOOLS_ONLY),y)
217 hostprogs-y += spl_size_limit
218 endif
219
220 hostprogs-$(CONFIG_MIPS) += mips-relocs
221
222 hostprogs-$(CONFIG_ASN1_COMPILER)       += asn1_compiler
223 HOSTCFLAGS_asn1_compiler.o = -idirafter $(srctree)/include
224
225 # We build some files with extra pedantic flags to try to minimize things
226 # that won't build on some weird host compiler -- though there are lots of
227 # exceptions for files that aren't complaint.
228 HOSTCFLAGS_crc32.o := -pedantic
229 HOSTCFLAGS_crc8.o := -pedantic
230 HOSTCFLAGS_md5.o := -pedantic
231 HOSTCFLAGS_sha1.o := -pedantic
232 HOSTCFLAGS_sha256.o := -pedantic
233
234 quiet_cmd_wrap = WRAP    $@
235 cmd_wrap = echo "\#include <../$(patsubst $(obj)/%,%,$@)>" >$@
236
237 $(obj)/lib/%.c $(obj)/common/%.c $(obj)/env/%.c:
238         $(call cmd,wrap)
239
240 clean-dirs := lib common
241
242 always := $(hostprogs-y)
243
244 # Generated LCD/video logo
245 LOGO_H = $(objtree)/include/bmp_logo.h
246 LOGO_DATA_H = $(objtree)/include/bmp_logo_data.h
247 LOGO-$(CONFIG_LCD_LOGO) += $(LOGO_H)
248 LOGO-$(CONFIG_LCD_LOGO) += $(LOGO_DATA_H)
249 LOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_H)
250 LOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_DATA_H)
251
252 # Generic logo
253 ifeq ($(LOGO_BMP),)
254 LOGO_BMP= $(srctree)/$(src)/logos/denx.bmp
255
256 # Use board logo and fallback to vendor
257 ifneq ($(wildcard $(srctree)/$(src)/logos/$(BOARD).bmp),)
258 LOGO_BMP= $(srctree)/$(src)/logos/$(BOARD).bmp
259 else
260 ifneq ($(wildcard $(srctree)/$(src)/logos/$(VENDOR).bmp),)
261 LOGO_BMP= $(srctree)/$(src)/logos/$(VENDOR).bmp
262 endif
263 endif
264
265 endif # !LOGO_BMP
266
267 #
268 # Use native tools and options
269 # Define __KERNEL_STRICT_NAMES to prevent typedef overlaps
270 # Define _GNU_SOURCE to obtain the getline prototype from stdio.h
271 #
272 HOST_EXTRACFLAGS += -include $(srctree)/include/compiler.h \
273                 $(patsubst -I%,-idirafter%, $(filter -I%, $(UBOOTINCLUDE))) \
274                 -I$(srctree)/scripts/dtc/libfdt \
275                 -I$(srctree)/tools \
276                 -DUSE_HOSTCC \
277                 -D__KERNEL_STRICT_NAMES \
278                 -D_GNU_SOURCE \
279                 -std=gnu99
280
281 __build:        $(LOGO-y)
282
283 $(LOGO_H):      $(obj)/bmp_logo $(LOGO_BMP)
284         $(obj)/bmp_logo --gen-info $(LOGO_BMP) > $@
285
286 ifeq ($(CONFIG_DM_VIDEO),y)
287 $(LOGO_DATA_H): $(obj)/bmp_logo $(LOGO_BMP)
288         $(obj)/bmp_logo --gen-bmp $(LOGO_BMP) > $@
289 else
290 $(LOGO_DATA_H): $(obj)/bmp_logo $(LOGO_BMP)
291         $(obj)/bmp_logo --gen-data $(LOGO_BMP) > $@
292 #endif
293 endif
294
295 # Let clean descend into subdirs
296 subdir- += env
297
298 ifneq ($(CROSS_BUILD_TOOLS),)
299 override HOSTCC = $(CC)
300 override HOSTCFLAGS = $(CFLAGS)
301
302 quiet_cmd_crosstools_strip = STRIP   $^
303       cmd_crosstools_strip = $(STRIP) $^; touch $@
304 $(obj)/.strip: $(call objectify,$(filter $(always),$(hostprogs-y)))
305         $(call cmd,crosstools_strip)
306
307 always += .strip
308 endif
309 clean-files += .strip