blob: 5dd33ed4d5611b9740bad90fcd25516b18f01dfe [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001# SPDX-License-Identifier: GPL-2.0+
wdenkefee1702002-07-20 20:14:13 +00002#
Marian Balakowiczf9328632006-09-01 19:49:50 +02003# (C) Copyright 2000-2006
wdenkefee1702002-07-20 20:14:13 +00004# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
wdenkefee1702002-07-20 20:14:13 +00005
Mike Frysingerc7c0d542010-01-21 04:03:22 -05006# Enable all the config-independent tools
7ifneq ($(HOST_TOOLS_ALL),)
Tuomas Tynkkynen5473eb62018-03-13 15:23:04 +02008CONFIG_KIRKWOOD = y
Mike Frysingerc7c0d542010-01-21 04:03:22 -05009CONFIG_LCD_LOGO = y
Mike Frysinger570d7d52010-08-15 00:03:19 -040010CONFIG_CMD_LOADS = y
Mike Frysingerc7c0d542010-01-21 04:03:22 -050011CONFIG_CMD_NET = y
Daniel Schwierzeck60b74bd2011-07-27 13:22:36 +020012CONFIG_XWAY_SWAP_BYTES = y
Mike Frysingerc7c0d542010-01-21 04:03:22 -050013CONFIG_NETCONSOLE = y
14CONFIG_SHA1_CHECK_UB_IMG = y
Andre Przywarad8c0d992016-11-10 12:13:23 +000015CONFIG_ARCH_SUNXI = y
Mike Frysingerc7c0d542010-01-21 04:03:22 -050016endif
17
Masahiro Yamada2887c472014-02-04 17:24:39 +090018subdir-$(HOST_TOOLS_ALL) += easylogo
19subdir-$(HOST_TOOLS_ALL) += gdb
20
Mike Frysinger2ad6e272011-06-19 08:27:39 +000021# Merge all the different vars for envcrc into one
22ENVCRC-$(CONFIG_ENV_IS_EMBEDDED) = y
Mike Frysinger2ad6e272011-06-19 08:27:39 +000023ENVCRC-$(CONFIG_ENV_IS_IN_EEPROM) = y
24ENVCRC-$(CONFIG_ENV_IS_IN_FLASH) = y
25ENVCRC-$(CONFIG_ENV_IS_IN_ONENAND) = y
26ENVCRC-$(CONFIG_ENV_IS_IN_NAND) = y
27ENVCRC-$(CONFIG_ENV_IS_IN_NVRAM) = y
28ENVCRC-$(CONFIG_ENV_IS_IN_SPI_FLASH) = y
29CONFIG_BUILD_ENVCRC ?= $(ENVCRC-y)
30
Masahiro Yamada96b09a92014-06-06 20:46:44 +090031hostprogs-$(CONFIG_SPL_GENERATE_ATMEL_PMECC_HEADER) += atmel_pmecc_params
Andreas Bießmann5c390a52014-05-19 14:23:40 +020032
Masahiro Yamada96b09a92014-06-06 20:46:44 +090033hostprogs-$(CONFIG_LCD_LOGO) += bmp_logo
34hostprogs-$(CONFIG_VIDEO_LOGO) += bmp_logo
35HOSTCFLAGS_bmp_logo.o := -pedantic
Peter Tyseree3584a2009-03-13 18:54:34 -050036
Masahiro Yamada96b09a92014-06-06 20:46:44 +090037hostprogs-$(CONFIG_BUILD_ENVCRC) += envcrc
Simon Glass0649cd02017-08-03 12:21:49 -060038envcrc-objs := envcrc.o lib/crc32.o env/embedded.o lib/sha1.o
Masahiro Yamada940db162014-02-04 17:24:10 +090039
Masahiro Yamada96b09a92014-06-06 20:46:44 +090040hostprogs-$(CONFIG_CMD_NET) += gen_eth_addr
41HOSTCFLAGS_gen_eth_addr.o := -pedantic
Masahiro Yamada940db162014-02-04 17:24:10 +090042
oliver@schinagl.nlc25f01a2016-11-25 16:30:32 +010043hostprogs-$(CONFIG_CMD_NET) += gen_ethaddr_crc
44gen_ethaddr_crc-objs := gen_ethaddr_crc.o lib/crc8.o
45HOSTCFLAGS_gen_ethaddr_crc.o := -pedantic
46
Masahiro Yamada96b09a92014-06-06 20:46:44 +090047hostprogs-$(CONFIG_CMD_LOADS) += img2srec
48HOSTCFLAGS_img2srec.o := -pedantic
Masahiro Yamada940db162014-02-04 17:24:10 +090049
Masahiro Yamada96b09a92014-06-06 20:46:44 +090050hostprogs-$(CONFIG_XWAY_SWAP_BYTES) += xway-swap-bytes
51HOSTCFLAGS_xway-swap-bytes.o := -pedantic
Masahiro Yamada940db162014-02-04 17:24:10 +090052
Masahiro Yamada96b09a92014-06-06 20:46:44 +090053hostprogs-y += mkenvimage
54mkenvimage-objs := mkenvimage.o os_support.o lib/crc32.o
Masahiro Yamada940db162014-02-04 17:24:10 +090055
Masahiro Yamada96b09a92014-06-06 20:46:44 +090056hostprogs-y += dumpimage mkimage
57hostprogs-$(CONFIG_FIT_SIGNATURE) += fit_info fit_check_sign
Masahiro Yamada940db162014-02-04 17:24:10 +090058
Heinrich Schuchardtac020192018-01-17 20:16:09 +010059hostprogs-$(CONFIG_CMD_BOOTEFI_SELFTEST) += file2include
60
Masahiro Yamadaad80c4a2014-06-06 14:04:32 +090061FIT_SIG_OBJS-$(CONFIG_FIT_SIGNATURE) := common/image-sig.o
Simon Glassee95d102017-05-27 07:38:19 -060062
Masahiro Yamadab38ad662017-10-17 22:30:18 +090063# The following files are synced with upstream DTC.
64# Use synced versions from scripts/dtc/libfdt/.
Masahiro Yamadaae9ace72018-01-21 19:19:13 +090065LIBFDT_SRCS_SYNCED := fdt.c fdt_wip.c fdt_sw.c fdt_rw.c \
66 fdt_strerror.c fdt_empty_tree.c fdt_addresses.c fdt_overlay.c
Masahiro Yamadab38ad662017-10-17 22:30:18 +090067# The following files are locally modified for U-Boot (unfotunately).
68# Use U-Boot own versions from lib/libfdt/.
Masahiro Yamadaae9ace72018-01-21 19:19:13 +090069LIBFDT_SRCS_UNSYNCED := fdt_ro.c fdt_region.c
Masahiro Yamadab38ad662017-10-17 22:30:18 +090070
71LIBFDT_OBJS := $(addprefix libfdt/, $(patsubst %.c, %.o, $(LIBFDT_SRCS_SYNCED))) \
72 $(addprefix lib/libfdt/, $(patsubst %.c, %.o, $(LIBFDT_SRCS_UNSYNCED)))
Simon Glass330274f2017-05-27 07:38:17 -060073
Masahiro Yamadaad80c4a2014-06-06 14:04:32 +090074RSA_OBJS-$(CONFIG_FIT_SIGNATURE) := $(addprefix lib/rsa/, \
Ruchika Guptafc2f4242015-01-23 16:01:50 +053075 rsa-sign.o rsa-verify.o rsa-checksum.o \
76 rsa-mod-exp.o)
Masahiro Yamada940db162014-02-04 17:24:10 +090077
Simon Glass9b037012015-12-29 05:22:43 -070078ROCKCHIP_OBS = lib/rc4.o rkcommon.o rkimage.o rksd.o rkspi.o
Simon Glassa131c1f2015-08-30 16:55:24 -060079
Masahiro Yamada940db162014-02-04 17:24:10 +090080# common objs for dumpimage and mkimage
81dumpimage-mkimage-objs := aisimage.o \
Andreas Bießmann7b1a4112014-05-19 14:23:39 +020082 atmelimage.o \
Masahiro Yamada940db162014-02-04 17:24:10 +090083 $(FIT_SIG_OBJS-y) \
Simon Glassea51a622014-06-12 07:24:51 -060084 common/bootm.o \
Masahiro Yamadaad80c4a2014-06-06 14:04:32 +090085 lib/crc32.o \
Masahiro Yamada940db162014-02-04 17:24:10 +090086 default_image.o \
Heiko Schocherb047d672014-06-22 06:33:29 +020087 lib/fdtdec_common.o \
Masahiro Yamadaad80c4a2014-06-06 14:04:32 +090088 lib/fdtdec.o \
Heiko Schocher6bf4ca02014-03-03 12:19:29 +010089 fit_common.o \
Masahiro Yamada940db162014-02-04 17:24:10 +090090 fit_image.o \
Masahiro Yamadaad80c4a2014-06-06 14:04:32 +090091 common/image-fit.o \
Masahiro Yamada940db162014-02-04 17:24:10 +090092 image-host.o \
Masahiro Yamadaad80c4a2014-06-06 14:04:32 +090093 common/image.o \
Masahiro Yamada940db162014-02-04 17:24:10 +090094 imagetool.o \
95 imximage.o \
96 kwbimage.o \
Masahiro Yamadaad80c4a2014-06-06 14:04:32 +090097 lib/md5.o \
Albert ARIBAUD \(3ADEV\)39f520b2015-03-31 11:40:49 +020098 lpc32xximage.o \
Masahiro Yamada940db162014-02-04 17:24:10 +090099 mxsimage.o \
100 omapimage.o \
101 os_support.o \
102 pblimage.o \
Charles Manningabbc67e2014-05-14 14:45:00 +1200103 pbl_crc32.o \
Albert ARIBAUD \(3ADEV\)ed0c2c02016-09-26 09:08:06 +0200104 vybridimage.o \
Patrick Delaunay81260e32018-03-12 10:46:04 +0100105 stm32image.o \
Simon Glassa131c1f2015-08-30 16:55:24 -0600106 $(ROCKCHIP_OBS) \
Charles Manning832472a2014-03-06 15:40:50 +1300107 socfpgaimage.o \
Masahiro Yamadaad80c4a2014-06-06 14:04:32 +0900108 lib/sha1.o \
109 lib/sha256.o \
Ruchika Gupta2dd90022015-01-23 16:01:58 +0530110 common/hash.o \
Masahiro Yamada940db162014-02-04 17:24:10 +0900111 ublimage.o \
Nathan Rossi66eef1e2015-11-17 22:56:56 +1000112 zynqimage.o \
Michal Simekd9b58b32016-04-27 14:03:29 +0200113 zynqmpimage.o \
Alexander Graf6915dcf2018-04-13 14:18:52 +0200114 zynqmpbif.o \
Masahiro Yamada940db162014-02-04 17:24:10 +0900115 $(LIBFDT_OBJS) \
Stefano Babic969cd1f2016-07-11 16:09:48 +0200116 gpimage.o \
117 gpimage-common.o \
Masahiro Yamada940db162014-02-04 17:24:10 +0900118 $(RSA_OBJS-y)
119
Masahiro Yamada96b09a92014-06-06 20:46:44 +0900120dumpimage-objs := $(dumpimage-mkimage-objs) dumpimage.o
121mkimage-objs := $(dumpimage-mkimage-objs) mkimage.o
122fit_info-objs := $(dumpimage-mkimage-objs) fit_info.o
123fit_check_sign-objs := $(dumpimage-mkimage-objs) fit_check_sign.o
Heinrich Schuchardtac020192018-01-17 20:16:09 +0100124file2include-objs := file2include.o
Masahiro Yamada940db162014-02-04 17:24:10 +0900125
Masahiro Yamada940db162014-02-04 17:24:10 +0900126ifneq ($(CONFIG_MX23)$(CONFIG_MX28),)
Masahiro Yamada940db162014-02-04 17:24:10 +0900127# Add CONFIG_MXS into host CFLAGS, so we can check whether or not register
128# the mxsimage support within tools/mxsimage.c .
Masahiro Yamada6825a952014-02-04 17:24:28 +0900129HOSTCFLAGS_mxsimage.o += -DCONFIG_MXS
Masahiro Yamada940db162014-02-04 17:24:10 +0900130endif
131
132ifdef CONFIG_FIT_SIGNATURE
Masahiro Yamada940db162014-02-04 17:24:10 +0900133# This affects include/image.h, but including the board config file
134# is tricky, so manually define this options here.
135HOST_EXTRACFLAGS += -DCONFIG_FIT_SIGNATURE
136endif
137
Stefan Roese7ddf8cf2015-07-20 11:20:38 +0200138ifdef CONFIG_SYS_U_BOOT_OFFS
139HOSTCFLAGS_kwbimage.o += -DCONFIG_SYS_U_BOOT_OFFS=$(CONFIG_SYS_U_BOOT_OFFS)
Tom Rinie35c6c72015-02-07 07:03:00 -0500140endif
141
Mario Sixa1b6b0a2017-01-11 16:01:00 +0100142ifneq ($(CONFIG_ARMADA_38X)$(CONFIG_ARMADA_39X),)
143HOSTCFLAGS_kwbimage.o += -DCONFIG_KWB_SECURE
144endif
145
Masahiro Yamada97cb4e52014-06-05 16:41:49 +0900146# MXSImage needs LibSSL
Mario Sixa1b6b0a2017-01-11 16:01:00 +0100147ifneq ($(CONFIG_MX23)$(CONFIG_MX28)$(CONFIG_ARMADA_38X)$(CONFIG_ARMADA_39X)$(CONFIG_FIT_SIGNATURE),)
Thomas Petazzoni48398362015-05-16 18:36:15 +0200148HOSTLOADLIBES_mkimage += \
149 $(shell pkg-config --libs libssl libcrypto 2> /dev/null || echo "-lssl -lcrypto")
Andreas Bießmannc6e3e822016-02-16 23:29:28 +0100150
151# OS X deprecate openssl in favour of CommonCrypto, supress deprecation
152# warnings on those systems
153ifeq ($(HOSTOS),darwin)
154HOSTCFLAGS_mxsimage.o += -Wno-deprecated-declarations
155HOSTCFLAGS_image-sig.o += -Wno-deprecated-declarations
156HOSTCFLAGS_rsa-sign.o += -Wno-deprecated-declarations
157endif
Masahiro Yamada97cb4e52014-06-05 16:41:49 +0900158endif
159
Tom Rini1f6049e2017-09-23 23:14:33 -0400160HOSTCFLAGS_fit_image.o += -DMKIMAGE_DTC=\"$(CONFIG_MKIMAGE_DTC_PATH)\"
Emmanuel Vadot47a52cd2017-06-25 09:43:33 +0200161
Masahiro Yamada96b09a92014-06-06 20:46:44 +0900162HOSTLOADLIBES_dumpimage := $(HOSTLOADLIBES_mkimage)
163HOSTLOADLIBES_fit_info := $(HOSTLOADLIBES_mkimage)
164HOSTLOADLIBES_fit_check_sign := $(HOSTLOADLIBES_mkimage)
Masahiro Yamada97cb4e52014-06-05 16:41:49 +0900165
Masahiro Yamada96b09a92014-06-06 20:46:44 +0900166hostprogs-$(CONFIG_EXYNOS5250) += mkexynosspl
167hostprogs-$(CONFIG_EXYNOS5420) += mkexynosspl
168HOSTCFLAGS_mkexynosspl.o := -pedantic
Masahiro Yamada940db162014-02-04 17:24:10 +0900169
Simon Glass31eca692014-12-15 22:02:38 -0700170ifdtool-objs := $(LIBFDT_OBJS) ifdtool.o
Simon Glasscd392fe2014-11-10 18:00:22 -0700171hostprogs-$(CONFIG_X86) += ifdtool
172
Masahiro Yamada96b09a92014-06-06 20:46:44 +0900173hostprogs-$(CONFIG_MX23) += mxsboot
174hostprogs-$(CONFIG_MX28) += mxsboot
175HOSTCFLAGS_mxsboot.o := -pedantic
Masahiro Yamada940db162014-02-04 17:24:10 +0900176
Jagan Tekiaec9a0f2016-10-13 14:19:35 +0530177hostprogs-$(CONFIG_ARCH_SUNXI) += mksunxiboot
Maxime Ripard594b4cc2017-02-27 18:22:02 +0100178hostprogs-$(CONFIG_ARCH_SUNXI) += sunxi-spl-image-builder
179sunxi-spl-image-builder-objs := sunxi-spl-image-builder.o lib/bch.o
Ian Campbell50827a52014-05-05 11:52:30 +0100180
Masahiro Yamada96b09a92014-06-06 20:46:44 +0900181hostprogs-$(CONFIG_NETCONSOLE) += ncb
182hostprogs-$(CONFIG_SHA1_CHECK_UB_IMG) += ubsha1
Masahiro Yamada940db162014-02-04 17:24:10 +0900183
Masahiro Yamada96b09a92014-06-06 20:46:44 +0900184ubsha1-objs := os_support.o ubsha1.o lib/sha1.o
Masahiro Yamada940db162014-02-04 17:24:10 +0900185
186HOSTCFLAGS_ubsha1.o := -pedantic
187
Masahiro Yamada96b09a92014-06-06 20:46:44 +0900188hostprogs-$(CONFIG_KIRKWOOD) += kwboot
Stefan Roese81e33f42015-12-21 13:56:33 +0100189hostprogs-$(CONFIG_ARCH_MVEBU) += kwboot
Masahiro Yamada96b09a92014-06-06 20:46:44 +0900190hostprogs-y += proftool
191hostprogs-$(CONFIG_STATIC_RELA) += relocate-rela
Rick Chen42ac26f2017-12-26 13:55:56 +0800192hostprogs-$(CONFIG_RISCV) += prelink-riscv
Masahiro Yamada940db162014-02-04 17:24:10 +0900193
Simon Glass1043d0a2015-06-23 15:38:28 -0600194hostprogs-y += fdtgrep
195fdtgrep-objs += $(LIBFDT_OBJS) fdtgrep.o
196
Paul Burton703ec9d2017-06-19 11:53:47 -0700197hostprogs-$(CONFIG_MIPS) += mips-relocs
198
Masahiro Yamada940db162014-02-04 17:24:10 +0900199# We build some files with extra pedantic flags to try to minimize things
200# that won't build on some weird host compiler -- though there are lots of
201# exceptions for files that aren't complaint.
202HOSTCFLAGS_crc32.o := -pedantic
oliver@schinagl.nl1d3c5392016-11-25 16:30:31 +0100203HOSTCFLAGS_crc8.o := -pedantic
Masahiro Yamada940db162014-02-04 17:24:10 +0900204HOSTCFLAGS_md5.o := -pedantic
205HOSTCFLAGS_sha1.o := -pedantic
Heiko Schocher2842c1c2014-03-03 12:19:25 +0100206HOSTCFLAGS_sha256.o := -pedantic
Peter Tyseree3584a2009-03-13 18:54:34 -0500207
Masahiro Yamadaad80c4a2014-06-06 14:04:32 +0900208quiet_cmd_wrap = WRAP $@
Masahiro Yamadaffe29eb2014-10-30 11:06:11 +0900209cmd_wrap = echo "\#include <../$(patsubst $(obj)/%,%,$@)>" >$@
Masahiro Yamadaad80c4a2014-06-06 14:04:32 +0900210
Simon Glass0649cd02017-08-03 12:21:49 -0600211$(obj)/lib/%.c $(obj)/common/%.c $(obj)/env/%.c:
Masahiro Yamadaad80c4a2014-06-06 14:04:32 +0900212 $(call cmd,wrap)
213
214clean-dirs := lib common
215
Masahiro Yamada940db162014-02-04 17:24:10 +0900216always := $(hostprogs-y)
Simon Glass19c402a2013-06-13 15:10:02 -0700217
Peter Tyser335ffe72009-03-13 18:54:35 -0500218# Generated LCD/video logo
Masahiro Yamada9e414032014-02-04 17:24:24 +0900219LOGO_H = $(objtree)/include/bmp_logo.h
220LOGO_DATA_H = $(objtree)/include/bmp_logo_data.h
Peter Tyser335ffe72009-03-13 18:54:35 -0500221LOGO-$(CONFIG_LCD_LOGO) += $(LOGO_H)
Che-Liang Chiouc2707302011-10-20 23:04:20 +0000222LOGO-$(CONFIG_LCD_LOGO) += $(LOGO_DATA_H)
Peter Tyser335ffe72009-03-13 18:54:35 -0500223LOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_H)
Che-Liang Chiouc2707302011-10-20 23:04:20 +0000224LOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_DATA_H)
Peter Tyseree3584a2009-03-13 18:54:34 -0500225
Otavio Salvador96903da2013-05-27 12:18:43 +0000226# Generic logo
Peter Tyseree3584a2009-03-13 18:54:34 -0500227ifeq ($(LOGO_BMP),)
Masahiro Yamada9e414032014-02-04 17:24:24 +0900228LOGO_BMP= $(srctree)/$(src)/logos/denx.bmp
Otavio Salvador96903da2013-05-27 12:18:43 +0000229
230# Use board logo and fallback to vendor
Masahiro Yamada603f51c2014-03-03 18:40:56 +0900231ifneq ($(wildcard $(srctree)/$(src)/logos/$(BOARD).bmp),)
Masahiro Yamada9e414032014-02-04 17:24:24 +0900232LOGO_BMP= $(srctree)/$(src)/logos/$(BOARD).bmp
Otavio Salvador96903da2013-05-27 12:18:43 +0000233else
Masahiro Yamada603f51c2014-03-03 18:40:56 +0900234ifneq ($(wildcard $(srctree)/$(src)/logos/$(VENDOR).bmp),)
Masahiro Yamada9e414032014-02-04 17:24:24 +0900235LOGO_BMP= $(srctree)/$(src)/logos/$(VENDOR).bmp
Peter Tyseree3584a2009-03-13 18:54:34 -0500236endif
Peter Tyseree3584a2009-03-13 18:54:34 -0500237endif
Otavio Salvador96903da2013-05-27 12:18:43 +0000238
239endif # !LOGO_BMP
Peter Tyseree3584a2009-03-13 18:54:34 -0500240
wdenkefee1702002-07-20 20:14:13 +0000241#
242# Use native tools and options
Peter Tyser2f8d3962009-03-13 18:54:51 -0500243# Define __KERNEL_STRICT_NAMES to prevent typedef overlaps
York Sun2db1c3f2013-07-30 15:26:11 -0700244# Define _GNU_SOURCE to obtain the getline prototype from stdio.h
wdenkefee1702002-07-20 20:14:13 +0000245#
Masahiro Yamada66228222018-01-21 19:19:18 +0900246HOST_EXTRACFLAGS += -include $(srctree)/include/compiler.h \
Masahiro Yamada51148792014-07-30 14:08:17 +0900247 $(patsubst -I%,-idirafter%, $(filter -I%, $(UBOOTINCLUDE))) \
Paul Kocialkowskie0d20dc2018-03-02 23:13:42 +0100248 -I$(srctree)/scripts/dtc/libfdt \
Masahiro Yamada01286322014-03-11 11:05:20 +0900249 -I$(srctree)/tools \
Wolfgang Denk14d0a022010-10-07 21:51:12 +0200250 -DUSE_HOSTCC \
York Sun2db1c3f2013-07-30 15:26:11 -0700251 -D__KERNEL_STRICT_NAMES \
252 -D_GNU_SOURCE
Bartlomiej Sieka8cf30802008-02-29 16:00:24 +0100253
Masahiro Yamadad726f222017-01-30 11:12:08 +0900254__build: $(LOGO-y)
wdenkefee1702002-07-20 20:14:13 +0000255
Masahiro Yamada9e414032014-02-04 17:24:24 +0900256$(LOGO_H): $(obj)/bmp_logo $(LOGO_BMP)
257 $(obj)/bmp_logo --gen-info $(LOGO_BMP) > $@
Che-Liang Chiouc2707302011-10-20 23:04:20 +0000258
Masahiro Yamada9e414032014-02-04 17:24:24 +0900259$(LOGO_DATA_H): $(obj)/bmp_logo $(LOGO_BMP)
260 $(obj)/bmp_logo --gen-data $(LOGO_BMP) > $@
Masahiro Yamada2887c472014-02-04 17:24:39 +0900261
262# Let clean descend into subdirs
263subdir- += env
Masahiro Yamadadb5b3392014-03-03 11:06:19 +0900264
265ifneq ($(CROSS_BUILD_TOOLS),)
Masahiro Yamada3b082522017-03-13 17:43:16 +0900266override HOSTCC = $(CC)
Masahiro Yamadadb5b3392014-03-03 11:06:19 +0900267
268quiet_cmd_crosstools_strip = STRIP $^
269 cmd_crosstools_strip = $(STRIP) $^; touch $@
270$(obj)/.strip: $(call objectify,$(filter $(always),$(hostprogs-y)))
271 $(call cmd,crosstools_strip)
272
273always += .strip
274endif
275clean-files += .strip