]> git.ipfire.org Git - people/ms/u-boot.git/blame - tools/Makefile
Merge branch 'for-tom' of git://git.denx.de/u-boot-dm
[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
16endif
17
2887c473
MY
18subdir-$(HOST_TOOLS_ALL) += easylogo
19subdir-$(HOST_TOOLS_ALL) += gdb
20
2ad6e27d
MF
21# Merge all the different vars for envcrc into one
22ENVCRC-$(CONFIG_ENV_IS_EMBEDDED) = y
23ENVCRC-$(CONFIG_ENV_IS_IN_DATAFLASH) = y
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
940db16d 34# TODO: CONFIG_CMD_LICENSE does not work
96b09a97
MY
35hostprogs-$(CONFIG_CMD_LICENSE) += bin2header
36hostprogs-$(CONFIG_LCD_LOGO) += bmp_logo
37hostprogs-$(CONFIG_VIDEO_LOGO) += bmp_logo
38HOSTCFLAGS_bmp_logo.o := -pedantic
940db16d 39
96b09a97
MY
40hostprogs-$(CONFIG_BUILD_ENVCRC) += envcrc
41envcrc-objs := envcrc.o lib/crc32.o common/env_embedded.o lib/sha1.o
940db16d 42
96b09a97
MY
43hostprogs-$(CONFIG_CMD_NET) += gen_eth_addr
44HOSTCFLAGS_gen_eth_addr.o := -pedantic
ee3584a5 45
96b09a97
MY
46hostprogs-$(CONFIG_CMD_LOADS) += img2srec
47HOSTCFLAGS_img2srec.o := -pedantic
940db16d 48
96b09a97
MY
49hostprogs-$(CONFIG_XWAY_SWAP_BYTES) += xway-swap-bytes
50HOSTCFLAGS_xway-swap-bytes.o := -pedantic
940db16d 51
96b09a97
MY
52hostprogs-y += mkenvimage
53mkenvimage-objs := mkenvimage.o os_support.o lib/crc32.o
940db16d 54
96b09a97
MY
55hostprogs-y += dumpimage mkimage
56hostprogs-$(CONFIG_FIT_SIGNATURE) += fit_info fit_check_sign
940db16d 57
ad80c4a3 58FIT_SIG_OBJS-$(CONFIG_FIT_SIGNATURE) := common/image-sig.o
ee3584a5 59# Flattened device tree objects
ad80c4a3
MY
60LIBFDT_OBJS := $(addprefix lib/libfdt/, \
61 fdt.o fdt_ro.o fdt_rw.o fdt_strerror.o fdt_wip.o)
62RSA_OBJS-$(CONFIG_FIT_SIGNATURE) := $(addprefix lib/rsa/, \
63 rsa-sign.o rsa-verify.o rsa-checksum.o)
940db16d
MY
64
65# common objs for dumpimage and mkimage
66dumpimage-mkimage-objs := aisimage.o \
7b1a4117 67 atmelimage.o \
940db16d 68 $(FIT_SIG_OBJS-y) \
ea51a628 69 common/bootm.o \
ad80c4a3 70 lib/crc32.o \
940db16d 71 default_image.o \
b047d671 72 lib/fdtdec_common.o \
ad80c4a3 73 lib/fdtdec.o \
6bf4ca07 74 fit_common.o \
940db16d 75 fit_image.o \
bf411ea9
KM
76 gpimage.o \
77 gpimage-common.o \
ad80c4a3 78 common/image-fit.o \
940db16d 79 image-host.o \
ad80c4a3 80 common/image.o \
940db16d
MY
81 imagetool.o \
82 imximage.o \
83 kwbimage.o \
ad80c4a3 84 lib/md5.o \
940db16d
MY
85 mxsimage.o \
86 omapimage.o \
87 os_support.o \
88 pblimage.o \
abbc67ee 89 pbl_crc32.o \
ad80c4a3
MY
90 lib/sha1.o \
91 lib/sha256.o \
940db16d
MY
92 ublimage.o \
93 $(LIBFDT_OBJS) \
94 $(RSA_OBJS-y)
95
96b09a97
MY
96dumpimage-objs := $(dumpimage-mkimage-objs) dumpimage.o
97mkimage-objs := $(dumpimage-mkimage-objs) mkimage.o
98fit_info-objs := $(dumpimage-mkimage-objs) fit_info.o
99fit_check_sign-objs := $(dumpimage-mkimage-objs) fit_check_sign.o
940db16d
MY
100
101# TODO(sjg@chromium.org): Is this correct on Mac OS?
102
940db16d 103ifneq ($(CONFIG_MX23)$(CONFIG_MX28),)
940db16d
MY
104# Add CONFIG_MXS into host CFLAGS, so we can check whether or not register
105# the mxsimage support within tools/mxsimage.c .
6825a95b 106HOSTCFLAGS_mxsimage.o += -DCONFIG_MXS
940db16d
MY
107endif
108
109ifdef CONFIG_FIT_SIGNATURE
940db16d
MY
110# This affects include/image.h, but including the board config file
111# is tricky, so manually define this options here.
112HOST_EXTRACFLAGS += -DCONFIG_FIT_SIGNATURE
113endif
114
97cb4e54
MY
115# MXSImage needs LibSSL
116ifneq ($(CONFIG_MX23)$(CONFIG_MX28)$(CONFIG_FIT_SIGNATURE),)
96b09a97 117HOSTLOADLIBES_mkimage += -lssl -lcrypto
97cb4e54
MY
118endif
119
96b09a97
MY
120HOSTLOADLIBES_dumpimage := $(HOSTLOADLIBES_mkimage)
121HOSTLOADLIBES_fit_info := $(HOSTLOADLIBES_mkimage)
122HOSTLOADLIBES_fit_check_sign := $(HOSTLOADLIBES_mkimage)
97cb4e54 123
96b09a97
MY
124hostprogs-$(CONFIG_EXYNOS5250) += mkexynosspl
125hostprogs-$(CONFIG_EXYNOS5420) += mkexynosspl
126HOSTCFLAGS_mkexynosspl.o := -pedantic
940db16d 127
96b09a97
MY
128hostprogs-$(CONFIG_MX23) += mxsboot
129hostprogs-$(CONFIG_MX28) += mxsboot
130HOSTCFLAGS_mxsboot.o := -pedantic
940db16d 131
96b09a97 132hostprogs-$(CONFIG_SUNXI) += mksunxiboot
50827a59 133
96b09a97
MY
134hostprogs-$(CONFIG_NETCONSOLE) += ncb
135hostprogs-$(CONFIG_SHA1_CHECK_UB_IMG) += ubsha1
940db16d 136
96b09a97 137ubsha1-objs := os_support.o ubsha1.o lib/sha1.o
940db16d
MY
138
139HOSTCFLAGS_ubsha1.o := -pedantic
140
96b09a97
MY
141hostprogs-$(CONFIG_KIRKWOOD) += kwboot
142hostprogs-y += proftool
143hostprogs-$(CONFIG_STATIC_RELA) += relocate-rela
ee3584a5 144
940db16d
MY
145# We build some files with extra pedantic flags to try to minimize things
146# that won't build on some weird host compiler -- though there are lots of
147# exceptions for files that aren't complaint.
148HOSTCFLAGS_crc32.o := -pedantic
149HOSTCFLAGS_md5.o := -pedantic
150HOSTCFLAGS_sha1.o := -pedantic
2842c1c2 151HOSTCFLAGS_sha256.o := -pedantic
940db16d
MY
152
153# Don't build by default
96b09a97
MY
154#hostprogs-$(CONFIG_PPC) += mpc86x_clk
155#HOSTCFLAGS_mpc86x_clk.o := -pedantic
940db16d 156
ad80c4a3
MY
157quiet_cmd_wrap = WRAP $@
158cmd_wrap = echo "\#include <$(srctree)/$(patsubst $(obj)/%,%,$@)>" >$@
159
160$(obj)/lib/%.c $(obj)/common/%.c:
161 $(call cmd,wrap)
162
163clean-dirs := lib common
164
940db16d 165always := $(hostprogs-y)
19c402af 166
335ffe7e 167# Generated LCD/video logo
9e414032
MY
168LOGO_H = $(objtree)/include/bmp_logo.h
169LOGO_DATA_H = $(objtree)/include/bmp_logo_data.h
335ffe7e 170LOGO-$(CONFIG_LCD_LOGO) += $(LOGO_H)
c270730f 171LOGO-$(CONFIG_LCD_LOGO) += $(LOGO_DATA_H)
335ffe7e 172LOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_H)
c270730f 173LOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_DATA_H)
ee3584a5 174
96903dae 175# Generic logo
ee3584a5 176ifeq ($(LOGO_BMP),)
9e414032 177LOGO_BMP= $(srctree)/$(src)/logos/denx.bmp
96903dae
OS
178
179# Use board logo and fallback to vendor
603f51cb 180ifneq ($(wildcard $(srctree)/$(src)/logos/$(BOARD).bmp),)
9e414032 181LOGO_BMP= $(srctree)/$(src)/logos/$(BOARD).bmp
96903dae 182else
603f51cb 183ifneq ($(wildcard $(srctree)/$(src)/logos/$(VENDOR).bmp),)
9e414032 184LOGO_BMP= $(srctree)/$(src)/logos/$(VENDOR).bmp
ee3584a5 185endif
348de314 186endif
ee3584a5 187
96903dae
OS
188endif # !LOGO_BMP
189
efee1709
WD
190#
191# Use native tools and options
2f8d396b 192# Define __KERNEL_STRICT_NAMES to prevent typedef overlaps
2db1c3fc 193# Define _GNU_SOURCE to obtain the getline prototype from stdio.h
efee1709 194#
01286329 195HOST_EXTRACFLAGS += -include $(srctree)/include/libfdt_env.h \
51148790 196 $(patsubst -I%,-idirafter%, $(filter -I%, $(UBOOTINCLUDE))) \
01286329
MY
197 -I$(srctree)/lib/libfdt \
198 -I$(srctree)/tools \
14d0a02a
WD
199 -DCONFIG_SYS_TEXT_BASE=$(CONFIG_SYS_TEXT_BASE) \
200 -DUSE_HOSTCC \
2db1c3fc
YS
201 -D__KERNEL_STRICT_NAMES \
202 -D_GNU_SOURCE
8cf30809 203
6825a95b 204__build: $(LOGO-y)
efee1709 205
9e414032
MY
206$(LOGO_H): $(obj)/bmp_logo $(LOGO_BMP)
207 $(obj)/bmp_logo --gen-info $(LOGO_BMP) > $@
c270730f 208
9e414032
MY
209$(LOGO_DATA_H): $(obj)/bmp_logo $(LOGO_BMP)
210 $(obj)/bmp_logo --gen-data $(LOGO_BMP) > $@
2887c473
MY
211
212# Let clean descend into subdirs
213subdir- += env
db5b339c
MY
214
215ifneq ($(CROSS_BUILD_TOOLS),)
216HOSTCC = $(CC)
217
218quiet_cmd_crosstools_strip = STRIP $^
219 cmd_crosstools_strip = $(STRIP) $^; touch $@
220$(obj)/.strip: $(call objectify,$(filter $(always),$(hostprogs-y)))
221 $(call cmd,crosstools_strip)
222
223always += .strip
224endif
225clean-files += .strip