]>
Commit | Line | Data |
---|---|---|
efee1709 | 1 | # |
f9328639 | 2 | # (C) Copyright 2000-2006 |
efee1709 WD |
3 | # Wolfgang Denk, DENX Software Engineering, [email protected]. |
4 | # | |
1a459660 | 5 | # SPDX-License-Identifier: GPL-2.0+ |
efee1709 WD |
6 | # |
7 | ||
efee1709 | 8 | # |
2f8d396b | 9 | # toolchains targeting win32 generate .exe files |
efee1709 | 10 | # |
2f8d396b | 11 | ifneq (,$(findstring WIN32 ,$(shell $(HOSTCC) -E -dM -xc /dev/null))) |
efee1709 WD |
12 | SFX = .exe |
13 | else | |
14 | SFX = | |
15 | endif | |
16 | ||
c7c0d542 MF |
17 | # Enable all the config-independent tools |
18 | ifneq ($(HOST_TOOLS_ALL),) | |
19 | CONFIG_LCD_LOGO = y | |
570d7d50 | 20 | CONFIG_CMD_LOADS = y |
c7c0d542 | 21 | CONFIG_CMD_NET = y |
60b74bde | 22 | CONFIG_XWAY_SWAP_BYTES = y |
c7c0d542 MF |
23 | CONFIG_NETCONSOLE = y |
24 | CONFIG_SHA1_CHECK_UB_IMG = y | |
25 | endif | |
26 | ||
2ad6e27d MF |
27 | # Merge all the different vars for envcrc into one |
28 | ENVCRC-$(CONFIG_ENV_IS_EMBEDDED) = y | |
29 | ENVCRC-$(CONFIG_ENV_IS_IN_DATAFLASH) = y | |
30 | ENVCRC-$(CONFIG_ENV_IS_IN_EEPROM) = y | |
31 | ENVCRC-$(CONFIG_ENV_IS_IN_FLASH) = y | |
32 | ENVCRC-$(CONFIG_ENV_IS_IN_ONENAND) = y | |
33 | ENVCRC-$(CONFIG_ENV_IS_IN_NAND) = y | |
34 | ENVCRC-$(CONFIG_ENV_IS_IN_NVRAM) = y | |
35 | ENVCRC-$(CONFIG_ENV_IS_IN_SPI_FLASH) = y | |
36 | CONFIG_BUILD_ENVCRC ?= $(ENVCRC-y) | |
37 | ||
940db16d MY |
38 | # TODO: CONFIG_CMD_LICENSE does not work |
39 | hostprogs-$(CONFIG_CMD_LICENSE) += bin2header$(SFX) | |
ee3584a5 | 40 | |
940db16d MY |
41 | hostprogs-$(CONFIG_LCD_LOGO) += bmp_logo$(SFX) |
42 | hostprogs-$(CONFIG_VIDEO_LOGO) += bmp_logo$(SFX) | |
6825a95b | 43 | HOSTCFLAGS_bmp_logo$(SFX).o := -pedantic |
940db16d MY |
44 | |
45 | hostprogs-$(CONFIG_BUILD_ENVCRC) += envcrc$(SFX) | |
46 | envcrc$(SFX)-objs := crc32.o env_embedded.o envcrc.o sha1.o | |
47 | ||
48 | hostprogs-$(CONFIG_CMD_NET) += gen_eth_addr$(SFX) | |
6825a95b | 49 | HOSTCFLAGS_gen_eth_addr$(SFX).o := -pedantic |
ee3584a5 | 50 | |
940db16d | 51 | hostprogs-$(CONFIG_CMD_LOADS) += img2srec$(SFX) |
6825a95b | 52 | HOSTCFLAGS_img2srec$(SFX).o := -pedantic |
940db16d MY |
53 | |
54 | hostprogs-$(CONFIG_XWAY_SWAP_BYTES) += xway-swap-bytes$(SFX) | |
6825a95b | 55 | HOSTCFLAGS_xway-swap-bytes$(SFX).o := -pedantic |
940db16d MY |
56 | |
57 | hostprogs-y += mkenvimage$(SFX) | |
58 | mkenvimage$(SFX)-objs := crc32.o mkenvimage.o os_support.o | |
59 | ||
60 | hostprogs-y += dumpimage$(SFX) mkimage$(SFX) | |
61 | ||
62 | FIT_SIG_OBJS-$(CONFIG_FIT_SIGNATURE) := image-sig.o | |
ee3584a5 | 63 | # Flattened device tree objects |
940db16d MY |
64 | LIBFDT_OBJS := fdt.o fdt_ro.o fdt_rw.o fdt_strerror.o fdt_wip.o |
65 | RSA_OBJS-$(CONFIG_FIT_SIGNATURE) := rsa-sign.o | |
66 | ||
67 | # common objs for dumpimage and mkimage | |
68 | dumpimage-mkimage-objs := aisimage.o \ | |
69 | $(FIT_SIG_OBJS-y) \ | |
70 | crc32.o \ | |
71 | default_image.o \ | |
72 | fit_image.o \ | |
73 | image-fit.o \ | |
74 | image-host.o \ | |
75 | image.o \ | |
76 | imagetool.o \ | |
77 | imximage.o \ | |
78 | kwbimage.o \ | |
79 | md5.o \ | |
80 | mxsimage.o \ | |
81 | omapimage.o \ | |
82 | os_support.o \ | |
83 | pblimage.o \ | |
84 | sha1.o \ | |
85 | ublimage.o \ | |
86 | $(LIBFDT_OBJS) \ | |
87 | $(RSA_OBJS-y) | |
88 | ||
89 | dumpimage$(SFX)-objs := $(dumpimage-mkimage-objs) dumpimage.o | |
90 | mkimage$(SFX)-objs := $(dumpimage-mkimage-objs) mkimage.o | |
91 | ||
92 | # TODO([email protected]): Is this correct on Mac OS? | |
93 | ||
94 | # MXSImage needs LibSSL | |
95 | ifneq ($(CONFIG_MX23)$(CONFIG_MX28),) | |
96 | HOSTLOADLIBES_dumpimage$(SFX) := -lssl -lcrypto | |
97 | HOSTLOADLIBES_mkimage$(SFX) := -lssl -lcrypto | |
98 | # Add CONFIG_MXS into host CFLAGS, so we can check whether or not register | |
99 | # the mxsimage support within tools/mxsimage.c . | |
6825a95b | 100 | HOSTCFLAGS_mxsimage.o += -DCONFIG_MXS |
940db16d MY |
101 | endif |
102 | ||
103 | ifdef CONFIG_FIT_SIGNATURE | |
104 | HOSTLOADLIBES_dumpimage$(SFX) := -lssl -lcrypto | |
105 | HOSTLOADLIBES_mkimage$(SFX) := -lssl -lcrypto | |
106 | ||
107 | # This affects include/image.h, but including the board config file | |
108 | # is tricky, so manually define this options here. | |
109 | HOST_EXTRACFLAGS += -DCONFIG_FIT_SIGNATURE | |
110 | endif | |
111 | ||
112 | hostprogs-$(CONFIG_EXYNOS5250) += mkexynosspl$(SFX) | |
113 | hostprogs-$(CONFIG_EXYNOS5420) += mkexynosspl$(SFX) | |
6825a95b | 114 | HOSTCFLAGS_mkexynosspl$(SFX).o := -pedantic |
940db16d MY |
115 | |
116 | hostprogs-$(CONFIG_MX23) += mxsboot$(SFX) | |
117 | hostprogs-$(CONFIG_MX28) += mxsboot$(SFX) | |
6825a95b | 118 | HOSTCFLAGS_mxsboot$(SFX).o := -pedantic |
940db16d MY |
119 | |
120 | hostprogs-$(CONFIG_NETCONSOLE) += ncb$(SFX) | |
121 | hostprogs-$(CONFIG_SHA1_CHECK_UB_IMG) += ubsha1$(SFX) | |
122 | ||
123 | ubsha1$(SFX)-objs := os_support.o sha1.o ubsha1.o | |
124 | ||
125 | HOSTCFLAGS_ubsha1.o := -pedantic | |
126 | ||
127 | hostprogs-$(CONFIG_KIRKWOOD) += kwboot$(SFX) | |
128 | hostprogs-y += proftool$(SFX) | |
129 | hostprogs-$(CONFIG_STATIC_RELA) += relocate-rela$(SFX) | |
ee3584a5 | 130 | |
940db16d MY |
131 | # We build some files with extra pedantic flags to try to minimize things |
132 | # that won't build on some weird host compiler -- though there are lots of | |
133 | # exceptions for files that aren't complaint. | |
134 | HOSTCFLAGS_crc32.o := -pedantic | |
135 | HOSTCFLAGS_md5.o := -pedantic | |
136 | HOSTCFLAGS_sha1.o := -pedantic | |
137 | ||
138 | # Don't build by default | |
139 | #hostprogs-$(CONFIG_PPC) += mpc86x_clk$(SFX) | |
6825a95b | 140 | #HOSTCFLAGS_mpc86x_clk$(SFX).o := -pedantic |
940db16d MY |
141 | |
142 | always := $(hostprogs-y) | |
19c402af | 143 | |
335ffe7e | 144 | # Generated LCD/video logo |
9e414032 MY |
145 | LOGO_H = $(objtree)/include/bmp_logo.h |
146 | LOGO_DATA_H = $(objtree)/include/bmp_logo_data.h | |
335ffe7e | 147 | LOGO-$(CONFIG_LCD_LOGO) += $(LOGO_H) |
c270730f | 148 | LOGO-$(CONFIG_LCD_LOGO) += $(LOGO_DATA_H) |
335ffe7e | 149 | LOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_H) |
c270730f | 150 | LOGO-$(CONFIG_VIDEO_LOGO) += $(LOGO_DATA_H) |
ee3584a5 | 151 | |
96903dae | 152 | # Generic logo |
ee3584a5 | 153 | ifeq ($(LOGO_BMP),) |
9e414032 | 154 | LOGO_BMP= $(srctree)/$(src)/logos/denx.bmp |
96903dae OS |
155 | |
156 | # Use board logo and fallback to vendor | |
157 | ifneq ($(wildcard logos/$(BOARD).bmp),) | |
9e414032 | 158 | LOGO_BMP= $(srctree)/$(src)/logos/$(BOARD).bmp |
96903dae OS |
159 | else |
160 | ifneq ($(wildcard logos/$(VENDOR).bmp),) | |
9e414032 | 161 | LOGO_BMP= $(srctree)/$(src)/logos/$(VENDOR).bmp |
ee3584a5 | 162 | endif |
348de314 | 163 | endif |
ee3584a5 | 164 | |
96903dae OS |
165 | endif # !LOGO_BMP |
166 | ||
efee1709 WD |
167 | # |
168 | # Use native tools and options | |
2f8d396b | 169 | # Define __KERNEL_STRICT_NAMES to prevent typedef overlaps |
2db1c3fc | 170 | # Define _GNU_SOURCE to obtain the getline prototype from stdio.h |
efee1709 | 171 | # |
940db16d | 172 | HOST_EXTRACFLAGS += -include $(SRCTREE)/include/libfdt_env.h \ |
fea1ca8e MY |
173 | $(patsubst -I%,-idirafter%, $(UBOOTINCLUDE)) \ |
174 | -I$(SRCTREE)/lib/libfdt \ | |
175 | -I$(SRCTREE)/tools \ | |
14d0a02a WD |
176 | -DCONFIG_SYS_TEXT_BASE=$(CONFIG_SYS_TEXT_BASE) \ |
177 | -DUSE_HOSTCC \ | |
2db1c3fc YS |
178 | -D__KERNEL_STRICT_NAMES \ |
179 | -D_GNU_SOURCE | |
8cf30809 | 180 | |
6825a95b | 181 | __build: $(LOGO-y) |
efee1709 | 182 | |
940db16d | 183 | subdir-y := kernel-doc |
e0ac62d7 | 184 | |
9e414032 MY |
185 | $(LOGO_H): $(obj)/bmp_logo $(LOGO_BMP) |
186 | $(obj)/bmp_logo --gen-info $(LOGO_BMP) > $@ | |
c270730f | 187 | |
9e414032 MY |
188 | $(LOGO_DATA_H): $(obj)/bmp_logo $(LOGO_BMP) |
189 | $(obj)/bmp_logo --gen-data $(LOGO_BMP) > $@ |