Commit ce28d7ac6d64c8a730334c8584742cf7255ad318
Committed by
Tom Rini
1 parent
9d33fb4a5c
Exists in
master
and in
50 other branches
Makefile: prepare for using Kbuild-style Makefile
Every makefile in sub directories has common lines at the top and the bottom. This commit pushes the common parts into script/Makefile.build. Going forward sub-makefiles only need to describe this part: COBJS := ... COBJS += ... SOBJS := ... But using obj-y is preferable to prepare for switching to Kbuild. The conventional (non-Kbuild) Makefile style is still supported. This is achieved by greping the Makefile before entering into it. U-Boot conventional sub makefiles always include some other makefiles. So the build system searches a line beginning with "include" keyword in the makefile in order to distinguish which style it is. If the Makefile include a "include" line, we assume it is a conventional U-Boot style. Otherwise, it is treated as a Kbuild-style makefile. With this tweak, we can switch sub-makefiles from U-Boot style to Kbuild style little by little. obj-y := foo/ syntax (descending into the sub directory) is not supportd yet. It will be implemented in the upcomming commit. Signed-off-by: Masahiro Yamada <yamada.m@jp.panasonic.com> Cc: Simon Glass <sjg@chromium.org> Cc: Tom Rini <trini@ti.com>
Showing 3 changed files with 99 additions and 7 deletions Inline Diff
Makefile
1 | # | 1 | # |
2 | # (C) Copyright 2000-2013 | 2 | # (C) Copyright 2000-2013 |
3 | # Wolfgang Denk, DENX Software Engineering, wd@denx.de. | 3 | # Wolfgang Denk, DENX Software Engineering, wd@denx.de. |
4 | # | 4 | # |
5 | # SPDX-License-Identifier: GPL-2.0+ | 5 | # SPDX-License-Identifier: GPL-2.0+ |
6 | # | 6 | # |
7 | 7 | ||
8 | VERSION = 2013 | 8 | VERSION = 2013 |
9 | PATCHLEVEL = 10 | 9 | PATCHLEVEL = 10 |
10 | SUBLEVEL = | 10 | SUBLEVEL = |
11 | EXTRAVERSION = | 11 | EXTRAVERSION = |
12 | ifneq "$(SUBLEVEL)" "" | 12 | ifneq "$(SUBLEVEL)" "" |
13 | U_BOOT_VERSION = $(VERSION).$(PATCHLEVEL).$(SUBLEVEL)$(EXTRAVERSION) | 13 | U_BOOT_VERSION = $(VERSION).$(PATCHLEVEL).$(SUBLEVEL)$(EXTRAVERSION) |
14 | else | 14 | else |
15 | U_BOOT_VERSION = $(VERSION).$(PATCHLEVEL)$(EXTRAVERSION) | 15 | U_BOOT_VERSION = $(VERSION).$(PATCHLEVEL)$(EXTRAVERSION) |
16 | endif | 16 | endif |
17 | TIMESTAMP_FILE = $(obj)include/generated/timestamp_autogenerated.h | 17 | TIMESTAMP_FILE = $(obj)include/generated/timestamp_autogenerated.h |
18 | VERSION_FILE = $(obj)include/generated/version_autogenerated.h | 18 | VERSION_FILE = $(obj)include/generated/version_autogenerated.h |
19 | 19 | ||
20 | HOSTARCH := $(shell uname -m | \ | 20 | HOSTARCH := $(shell uname -m | \ |
21 | sed -e s/i.86/x86/ \ | 21 | sed -e s/i.86/x86/ \ |
22 | -e s/sun4u/sparc64/ \ | 22 | -e s/sun4u/sparc64/ \ |
23 | -e s/arm.*/arm/ \ | 23 | -e s/arm.*/arm/ \ |
24 | -e s/sa110/arm/ \ | 24 | -e s/sa110/arm/ \ |
25 | -e s/ppc64/powerpc/ \ | 25 | -e s/ppc64/powerpc/ \ |
26 | -e s/ppc/powerpc/ \ | 26 | -e s/ppc/powerpc/ \ |
27 | -e s/macppc/powerpc/\ | 27 | -e s/macppc/powerpc/\ |
28 | -e s/sh.*/sh/) | 28 | -e s/sh.*/sh/) |
29 | 29 | ||
30 | HOSTOS := $(shell uname -s | tr '[:upper:]' '[:lower:]' | \ | 30 | HOSTOS := $(shell uname -s | tr '[:upper:]' '[:lower:]' | \ |
31 | sed -e 's/\(cygwin\).*/cygwin/') | 31 | sed -e 's/\(cygwin\).*/cygwin/') |
32 | 32 | ||
33 | export HOSTARCH HOSTOS | 33 | export HOSTARCH HOSTOS |
34 | 34 | ||
35 | # Deal with colliding definitions from tcsh etc. | 35 | # Deal with colliding definitions from tcsh etc. |
36 | VENDOR= | 36 | VENDOR= |
37 | 37 | ||
38 | ######################################################################### | 38 | ######################################################################### |
39 | # Allow for silent builds | 39 | # Allow for silent builds |
40 | ifeq (,$(findstring s,$(MAKEFLAGS))) | 40 | ifeq (,$(findstring s,$(MAKEFLAGS))) |
41 | XECHO = echo | 41 | XECHO = echo |
42 | else | 42 | else |
43 | XECHO = : | 43 | XECHO = : |
44 | endif | 44 | endif |
45 | 45 | ||
46 | ######################################################################### | 46 | ######################################################################### |
47 | # | 47 | # |
48 | # U-boot build supports generating object files in a separate external | 48 | # U-boot build supports generating object files in a separate external |
49 | # directory. Two use cases are supported: | 49 | # directory. Two use cases are supported: |
50 | # | 50 | # |
51 | # 1) Add O= to the make command line | 51 | # 1) Add O= to the make command line |
52 | # 'make O=/tmp/build all' | 52 | # 'make O=/tmp/build all' |
53 | # | 53 | # |
54 | # 2) Set environment variable BUILD_DIR to point to the desired location | 54 | # 2) Set environment variable BUILD_DIR to point to the desired location |
55 | # 'export BUILD_DIR=/tmp/build' | 55 | # 'export BUILD_DIR=/tmp/build' |
56 | # 'make' | 56 | # 'make' |
57 | # | 57 | # |
58 | # The second approach can also be used with a MAKEALL script | 58 | # The second approach can also be used with a MAKEALL script |
59 | # 'export BUILD_DIR=/tmp/build' | 59 | # 'export BUILD_DIR=/tmp/build' |
60 | # './MAKEALL' | 60 | # './MAKEALL' |
61 | # | 61 | # |
62 | # Command line 'O=' setting overrides BUILD_DIR environment variable. | 62 | # Command line 'O=' setting overrides BUILD_DIR environment variable. |
63 | # | 63 | # |
64 | # When none of the above methods is used the local build is performed and | 64 | # When none of the above methods is used the local build is performed and |
65 | # the object files are placed in the source directory. | 65 | # the object files are placed in the source directory. |
66 | # | 66 | # |
67 | 67 | ||
68 | ifdef O | 68 | ifdef O |
69 | ifeq ("$(origin O)", "command line") | 69 | ifeq ("$(origin O)", "command line") |
70 | BUILD_DIR := $(O) | 70 | BUILD_DIR := $(O) |
71 | endif | 71 | endif |
72 | endif | 72 | endif |
73 | 73 | ||
74 | # Call a source code checker (by default, "sparse") as part of the | 74 | # Call a source code checker (by default, "sparse") as part of the |
75 | # C compilation. | 75 | # C compilation. |
76 | # | 76 | # |
77 | # Use 'make C=1' to enable checking of re-compiled files. | 77 | # Use 'make C=1' to enable checking of re-compiled files. |
78 | # | 78 | # |
79 | # See the linux kernel file "Documentation/sparse.txt" for more details, | 79 | # See the linux kernel file "Documentation/sparse.txt" for more details, |
80 | # including where to get the "sparse" utility. | 80 | # including where to get the "sparse" utility. |
81 | 81 | ||
82 | ifdef C | 82 | ifdef C |
83 | ifeq ("$(origin C)", "command line") | 83 | ifeq ("$(origin C)", "command line") |
84 | CHECKSRC := $(C) | 84 | CHECKSRC := $(C) |
85 | endif | 85 | endif |
86 | endif | 86 | endif |
87 | ifndef CHECKSRC | 87 | ifndef CHECKSRC |
88 | CHECKSRC = 0 | 88 | CHECKSRC = 0 |
89 | endif | 89 | endif |
90 | export CHECKSRC | 90 | export CHECKSRC |
91 | 91 | ||
92 | ifneq ($(BUILD_DIR),) | 92 | ifneq ($(BUILD_DIR),) |
93 | saved-output := $(BUILD_DIR) | 93 | saved-output := $(BUILD_DIR) |
94 | 94 | ||
95 | # Attempt to create a output directory. | 95 | # Attempt to create a output directory. |
96 | $(shell [ -d ${BUILD_DIR} ] || mkdir -p ${BUILD_DIR}) | 96 | $(shell [ -d ${BUILD_DIR} ] || mkdir -p ${BUILD_DIR}) |
97 | 97 | ||
98 | # Verify if it was successful. | 98 | # Verify if it was successful. |
99 | BUILD_DIR := $(shell cd $(BUILD_DIR) && /bin/pwd) | 99 | BUILD_DIR := $(shell cd $(BUILD_DIR) && /bin/pwd) |
100 | $(if $(BUILD_DIR),,$(error output directory "$(saved-output)" does not exist)) | 100 | $(if $(BUILD_DIR),,$(error output directory "$(saved-output)" does not exist)) |
101 | endif # ifneq ($(BUILD_DIR),) | 101 | endif # ifneq ($(BUILD_DIR),) |
102 | 102 | ||
103 | OBJTREE := $(if $(BUILD_DIR),$(BUILD_DIR),$(CURDIR)) | 103 | OBJTREE := $(if $(BUILD_DIR),$(BUILD_DIR),$(CURDIR)) |
104 | SPLTREE := $(OBJTREE)/spl | 104 | SPLTREE := $(OBJTREE)/spl |
105 | TPLTREE := $(OBJTREE)/tpl | 105 | TPLTREE := $(OBJTREE)/tpl |
106 | SRCTREE := $(CURDIR) | 106 | SRCTREE := $(CURDIR) |
107 | TOPDIR := $(SRCTREE) | 107 | TOPDIR := $(SRCTREE) |
108 | LNDIR := $(OBJTREE) | 108 | LNDIR := $(OBJTREE) |
109 | export TOPDIR SRCTREE OBJTREE SPLTREE TPLTREE | 109 | export TOPDIR SRCTREE OBJTREE SPLTREE TPLTREE |
110 | 110 | ||
111 | MKCONFIG := $(SRCTREE)/mkconfig | 111 | MKCONFIG := $(SRCTREE)/mkconfig |
112 | export MKCONFIG | 112 | export MKCONFIG |
113 | 113 | ||
114 | ifneq ($(OBJTREE),$(SRCTREE)) | 114 | ifneq ($(OBJTREE),$(SRCTREE)) |
115 | REMOTE_BUILD := 1 | 115 | REMOTE_BUILD := 1 |
116 | export REMOTE_BUILD | 116 | export REMOTE_BUILD |
117 | endif | 117 | endif |
118 | 118 | ||
119 | # $(obj) and (src) are defined in config.mk but here in main Makefile | 119 | # $(obj) and (src) are defined in config.mk but here in main Makefile |
120 | # we also need them before config.mk is included which is the case for | 120 | # we also need them before config.mk is included which is the case for |
121 | # some targets like unconfig, clean, clobber, distclean, etc. | 121 | # some targets like unconfig, clean, clobber, distclean, etc. |
122 | ifneq ($(OBJTREE),$(SRCTREE)) | 122 | ifneq ($(OBJTREE),$(SRCTREE)) |
123 | obj := $(OBJTREE)/ | 123 | obj := $(OBJTREE)/ |
124 | src := $(SRCTREE)/ | 124 | src := $(SRCTREE)/ |
125 | else | 125 | else |
126 | obj := | 126 | obj := |
127 | src := | 127 | src := |
128 | endif | 128 | endif |
129 | export obj src | 129 | export obj src |
130 | 130 | ||
131 | # Make sure CDPATH settings don't interfere | 131 | # Make sure CDPATH settings don't interfere |
132 | unexport CDPATH | 132 | unexport CDPATH |
133 | 133 | ||
134 | ######################################################################### | 134 | ######################################################################### |
135 | 135 | ||
136 | # The "tools" are needed early, so put this first | 136 | # The "tools" are needed early, so put this first |
137 | # Don't include stuff already done in $(LIBS) | 137 | # Don't include stuff already done in $(LIBS) |
138 | # The "examples" conditionally depend on U-Boot (say, when USE_PRIVATE_LIBGCC | 138 | # The "examples" conditionally depend on U-Boot (say, when USE_PRIVATE_LIBGCC |
139 | # is "yes"), so compile examples after U-Boot is compiled. | 139 | # is "yes"), so compile examples after U-Boot is compiled. |
140 | SUBDIR_TOOLS = tools | 140 | SUBDIR_TOOLS = tools |
141 | SUBDIR_EXAMPLES = examples/standalone examples/api | 141 | SUBDIR_EXAMPLES = examples/standalone examples/api |
142 | SUBDIRS = $(SUBDIR_TOOLS) | 142 | SUBDIRS = $(SUBDIR_TOOLS) |
143 | 143 | ||
144 | .PHONY : $(SUBDIRS) $(VERSION_FILE) $(TIMESTAMP_FILE) | 144 | .PHONY : $(SUBDIRS) $(VERSION_FILE) $(TIMESTAMP_FILE) |
145 | 145 | ||
146 | ifeq ($(obj)include/config.mk,$(wildcard $(obj)include/config.mk)) | 146 | ifeq ($(obj)include/config.mk,$(wildcard $(obj)include/config.mk)) |
147 | 147 | ||
148 | # Include autoconf.mk before config.mk so that the config options are available | 148 | # Include autoconf.mk before config.mk so that the config options are available |
149 | # to all top level build files. We need the dummy all: target to prevent the | 149 | # to all top level build files. We need the dummy all: target to prevent the |
150 | # dependency target in autoconf.mk.dep from being the default. | 150 | # dependency target in autoconf.mk.dep from being the default. |
151 | all: | 151 | all: |
152 | sinclude $(obj)include/autoconf.mk.dep | 152 | sinclude $(obj)include/autoconf.mk.dep |
153 | sinclude $(obj)include/autoconf.mk | 153 | sinclude $(obj)include/autoconf.mk |
154 | 154 | ||
155 | ifndef CONFIG_SANDBOX | 155 | ifndef CONFIG_SANDBOX |
156 | SUBDIRS += $(SUBDIR_EXAMPLES) | 156 | SUBDIRS += $(SUBDIR_EXAMPLES) |
157 | endif | 157 | endif |
158 | 158 | ||
159 | # load ARCH, BOARD, and CPU configuration | 159 | # load ARCH, BOARD, and CPU configuration |
160 | include $(obj)include/config.mk | 160 | include $(obj)include/config.mk |
161 | export ARCH CPU BOARD VENDOR SOC | 161 | export ARCH CPU BOARD VENDOR SOC |
162 | 162 | ||
163 | # set default to nothing for native builds | 163 | # set default to nothing for native builds |
164 | ifeq ($(HOSTARCH),$(ARCH)) | 164 | ifeq ($(HOSTARCH),$(ARCH)) |
165 | CROSS_COMPILE ?= | 165 | CROSS_COMPILE ?= |
166 | endif | 166 | endif |
167 | 167 | ||
168 | # load other configuration | 168 | # load other configuration |
169 | include $(TOPDIR)/config.mk | 169 | include $(TOPDIR)/config.mk |
170 | 170 | ||
171 | # Targets which don't build the source code | 171 | # Targets which don't build the source code |
172 | NON_BUILD_TARGETS = backup clean clobber distclean mkproper tidy unconfig | 172 | NON_BUILD_TARGETS = backup clean clobber distclean mkproper tidy unconfig |
173 | 173 | ||
174 | # Only do the generic board check when actually building, not configuring | 174 | # Only do the generic board check when actually building, not configuring |
175 | ifeq ($(filter $(NON_BUILD_TARGETS),$(MAKECMDGOALS)),) | 175 | ifeq ($(filter $(NON_BUILD_TARGETS),$(MAKECMDGOALS)),) |
176 | ifeq ($(findstring _config,$(MAKECMDGOALS)),) | 176 | ifeq ($(findstring _config,$(MAKECMDGOALS)),) |
177 | $(CHECK_GENERIC_BOARD) | 177 | $(CHECK_GENERIC_BOARD) |
178 | endif | 178 | endif |
179 | endif | 179 | endif |
180 | 180 | ||
181 | # If board code explicitly specified LDSCRIPT or CONFIG_SYS_LDSCRIPT, use | 181 | # If board code explicitly specified LDSCRIPT or CONFIG_SYS_LDSCRIPT, use |
182 | # that (or fail if absent). Otherwise, search for a linker script in a | 182 | # that (or fail if absent). Otherwise, search for a linker script in a |
183 | # standard location. | 183 | # standard location. |
184 | 184 | ||
185 | LDSCRIPT_MAKEFILE_DIR = $(dir $(LDSCRIPT)) | 185 | LDSCRIPT_MAKEFILE_DIR = $(dir $(LDSCRIPT)) |
186 | 186 | ||
187 | ifndef LDSCRIPT | 187 | ifndef LDSCRIPT |
188 | #LDSCRIPT := $(TOPDIR)/board/$(BOARDDIR)/u-boot.lds.debug | 188 | #LDSCRIPT := $(TOPDIR)/board/$(BOARDDIR)/u-boot.lds.debug |
189 | ifdef CONFIG_SYS_LDSCRIPT | 189 | ifdef CONFIG_SYS_LDSCRIPT |
190 | # need to strip off double quotes | 190 | # need to strip off double quotes |
191 | LDSCRIPT := $(subst ",,$(CONFIG_SYS_LDSCRIPT)) | 191 | LDSCRIPT := $(subst ",,$(CONFIG_SYS_LDSCRIPT)) |
192 | endif | 192 | endif |
193 | endif | 193 | endif |
194 | 194 | ||
195 | # If there is no specified link script, we look in a number of places for it | 195 | # If there is no specified link script, we look in a number of places for it |
196 | ifndef LDSCRIPT | 196 | ifndef LDSCRIPT |
197 | ifeq ($(CONFIG_NAND_U_BOOT),y) | 197 | ifeq ($(CONFIG_NAND_U_BOOT),y) |
198 | LDSCRIPT := $(TOPDIR)/board/$(BOARDDIR)/u-boot-nand.lds | 198 | LDSCRIPT := $(TOPDIR)/board/$(BOARDDIR)/u-boot-nand.lds |
199 | ifeq ($(wildcard $(LDSCRIPT)),) | 199 | ifeq ($(wildcard $(LDSCRIPT)),) |
200 | LDSCRIPT := $(TOPDIR)/$(CPUDIR)/u-boot-nand.lds | 200 | LDSCRIPT := $(TOPDIR)/$(CPUDIR)/u-boot-nand.lds |
201 | endif | 201 | endif |
202 | endif | 202 | endif |
203 | ifeq ($(wildcard $(LDSCRIPT)),) | 203 | ifeq ($(wildcard $(LDSCRIPT)),) |
204 | LDSCRIPT := $(TOPDIR)/board/$(BOARDDIR)/u-boot.lds | 204 | LDSCRIPT := $(TOPDIR)/board/$(BOARDDIR)/u-boot.lds |
205 | endif | 205 | endif |
206 | ifeq ($(wildcard $(LDSCRIPT)),) | 206 | ifeq ($(wildcard $(LDSCRIPT)),) |
207 | LDSCRIPT := $(TOPDIR)/$(CPUDIR)/u-boot.lds | 207 | LDSCRIPT := $(TOPDIR)/$(CPUDIR)/u-boot.lds |
208 | endif | 208 | endif |
209 | ifeq ($(wildcard $(LDSCRIPT)),) | 209 | ifeq ($(wildcard $(LDSCRIPT)),) |
210 | LDSCRIPT := $(TOPDIR)/arch/$(ARCH)/cpu/u-boot.lds | 210 | LDSCRIPT := $(TOPDIR)/arch/$(ARCH)/cpu/u-boot.lds |
211 | # We don't expect a Makefile here | 211 | # We don't expect a Makefile here |
212 | LDSCRIPT_MAKEFILE_DIR = | 212 | LDSCRIPT_MAKEFILE_DIR = |
213 | endif | 213 | endif |
214 | ifeq ($(wildcard $(LDSCRIPT)),) | 214 | ifeq ($(wildcard $(LDSCRIPT)),) |
215 | $(error could not find linker script) | 215 | $(error could not find linker script) |
216 | endif | 216 | endif |
217 | endif | 217 | endif |
218 | 218 | ||
219 | ######################################################################### | 219 | ######################################################################### |
220 | # U-Boot objects....order is important (i.e. start must be first) | 220 | # U-Boot objects....order is important (i.e. start must be first) |
221 | 221 | ||
222 | OBJS = $(CPUDIR)/start.o | 222 | OBJS = $(CPUDIR)/start.o |
223 | ifeq ($(CPU),ppc4xx) | 223 | ifeq ($(CPU),ppc4xx) |
224 | OBJS += $(CPUDIR)/resetvec.o | 224 | OBJS += $(CPUDIR)/resetvec.o |
225 | endif | 225 | endif |
226 | ifeq ($(CPU),mpc85xx) | 226 | ifeq ($(CPU),mpc85xx) |
227 | OBJS += $(CPUDIR)/resetvec.o | 227 | OBJS += $(CPUDIR)/resetvec.o |
228 | endif | 228 | endif |
229 | 229 | ||
230 | OBJS := $(addprefix $(obj),$(OBJS)) | 230 | OBJS := $(addprefix $(obj),$(OBJS)) |
231 | 231 | ||
232 | HAVE_VENDOR_COMMON_LIB = $(if $(wildcard board/$(VENDOR)/common/Makefile),y,n) | 232 | HAVE_VENDOR_COMMON_LIB = $(if $(wildcard board/$(VENDOR)/common/Makefile),y,n) |
233 | 233 | ||
234 | LIBS-y += lib/libgeneric.o | 234 | LIBS-y += lib/libgeneric.o |
235 | LIBS-y += lib/rsa/librsa.o | 235 | LIBS-y += lib/rsa/librsa.o |
236 | LIBS-y += lib/lzma/liblzma.o | 236 | LIBS-y += lib/lzma/liblzma.o |
237 | LIBS-y += lib/lzo/liblzo.o | 237 | LIBS-y += lib/lzo/liblzo.o |
238 | LIBS-y += lib/zlib/libz.o | 238 | LIBS-y += lib/zlib/libz.o |
239 | LIBS-$(CONFIG_TIZEN) += lib/tizen/libtizen.o | 239 | LIBS-$(CONFIG_TIZEN) += lib/tizen/libtizen.o |
240 | LIBS-$(HAVE_VENDOR_COMMON_LIB) += board/$(VENDOR)/common/lib$(VENDOR).o | 240 | LIBS-$(HAVE_VENDOR_COMMON_LIB) += board/$(VENDOR)/common/lib$(VENDOR).o |
241 | LIBS-y += $(CPUDIR)/lib$(CPU).o | 241 | LIBS-y += $(CPUDIR)/lib$(CPU).o |
242 | ifdef SOC | 242 | ifdef SOC |
243 | LIBS-y += $(CPUDIR)/$(SOC)/lib$(SOC).o | 243 | LIBS-y += $(CPUDIR)/$(SOC)/lib$(SOC).o |
244 | endif | 244 | endif |
245 | ifeq ($(CPU),ixp) | 245 | ifeq ($(CPU),ixp) |
246 | LIBS-y += drivers/net/npe/libnpe.o | 246 | LIBS-y += drivers/net/npe/libnpe.o |
247 | endif | 247 | endif |
248 | LIBS-$(CONFIG_OF_EMBED) += dts/libdts.o | 248 | LIBS-$(CONFIG_OF_EMBED) += dts/libdts.o |
249 | LIBS-y += arch/$(ARCH)/lib/lib$(ARCH).o | 249 | LIBS-y += arch/$(ARCH)/lib/lib$(ARCH).o |
250 | LIBS-y += fs/libfs.o \ | 250 | LIBS-y += fs/libfs.o \ |
251 | fs/cbfs/libcbfs.o \ | 251 | fs/cbfs/libcbfs.o \ |
252 | fs/cramfs/libcramfs.o \ | 252 | fs/cramfs/libcramfs.o \ |
253 | fs/ext4/libext4fs.o \ | 253 | fs/ext4/libext4fs.o \ |
254 | fs/fat/libfat.o \ | 254 | fs/fat/libfat.o \ |
255 | fs/fdos/libfdos.o \ | 255 | fs/fdos/libfdos.o \ |
256 | fs/jffs2/libjffs2.o \ | 256 | fs/jffs2/libjffs2.o \ |
257 | fs/reiserfs/libreiserfs.o \ | 257 | fs/reiserfs/libreiserfs.o \ |
258 | fs/sandbox/libsandboxfs.o \ | 258 | fs/sandbox/libsandboxfs.o \ |
259 | fs/ubifs/libubifs.o \ | 259 | fs/ubifs/libubifs.o \ |
260 | fs/yaffs2/libyaffs2.o \ | 260 | fs/yaffs2/libyaffs2.o \ |
261 | fs/zfs/libzfs.o | 261 | fs/zfs/libzfs.o |
262 | LIBS-y += net/libnet.o | 262 | LIBS-y += net/libnet.o |
263 | LIBS-y += disk/libdisk.o | 263 | LIBS-y += disk/libdisk.o |
264 | LIBS-y += drivers/bios_emulator/libatibiosemu.o | 264 | LIBS-y += drivers/bios_emulator/libatibiosemu.o |
265 | LIBS-y += drivers/block/libblock.o | 265 | LIBS-y += drivers/block/libblock.o |
266 | LIBS-$(CONFIG_BOOTCOUNT_LIMIT) += drivers/bootcount/libbootcount.o | 266 | LIBS-$(CONFIG_BOOTCOUNT_LIMIT) += drivers/bootcount/libbootcount.o |
267 | LIBS-y += drivers/crypto/libcrypto.o | 267 | LIBS-y += drivers/crypto/libcrypto.o |
268 | LIBS-y += drivers/dma/libdma.o | 268 | LIBS-y += drivers/dma/libdma.o |
269 | LIBS-y += drivers/fpga/libfpga.o | 269 | LIBS-y += drivers/fpga/libfpga.o |
270 | LIBS-y += drivers/gpio/libgpio.o | 270 | LIBS-y += drivers/gpio/libgpio.o |
271 | LIBS-y += drivers/hwmon/libhwmon.o | 271 | LIBS-y += drivers/hwmon/libhwmon.o |
272 | LIBS-y += drivers/i2c/libi2c.o | 272 | LIBS-y += drivers/i2c/libi2c.o |
273 | LIBS-y += drivers/input/libinput.o | 273 | LIBS-y += drivers/input/libinput.o |
274 | LIBS-y += drivers/misc/libmisc.o | 274 | LIBS-y += drivers/misc/libmisc.o |
275 | LIBS-y += drivers/mmc/libmmc.o | 275 | LIBS-y += drivers/mmc/libmmc.o |
276 | LIBS-y += drivers/mtd/libmtd.o | 276 | LIBS-y += drivers/mtd/libmtd.o |
277 | LIBS-y += drivers/mtd/nand/libnand.o | 277 | LIBS-y += drivers/mtd/nand/libnand.o |
278 | LIBS-y += drivers/mtd/onenand/libonenand.o | 278 | LIBS-y += drivers/mtd/onenand/libonenand.o |
279 | LIBS-y += drivers/mtd/ubi/libubi.o | 279 | LIBS-y += drivers/mtd/ubi/libubi.o |
280 | LIBS-y += drivers/mtd/spi/libspi_flash.o | 280 | LIBS-y += drivers/mtd/spi/libspi_flash.o |
281 | LIBS-y += drivers/net/libnet.o | 281 | LIBS-y += drivers/net/libnet.o |
282 | LIBS-y += drivers/net/phy/libphy.o | 282 | LIBS-y += drivers/net/phy/libphy.o |
283 | LIBS-y += drivers/pci/libpci.o | 283 | LIBS-y += drivers/pci/libpci.o |
284 | LIBS-y += drivers/pcmcia/libpcmcia.o | 284 | LIBS-y += drivers/pcmcia/libpcmcia.o |
285 | LIBS-y += drivers/power/libpower.o \ | 285 | LIBS-y += drivers/power/libpower.o \ |
286 | drivers/power/fuel_gauge/libfuel_gauge.o \ | 286 | drivers/power/fuel_gauge/libfuel_gauge.o \ |
287 | drivers/power/mfd/libmfd.o \ | 287 | drivers/power/mfd/libmfd.o \ |
288 | drivers/power/pmic/libpmic.o \ | 288 | drivers/power/pmic/libpmic.o \ |
289 | drivers/power/battery/libbattery.o | 289 | drivers/power/battery/libbattery.o |
290 | LIBS-y += drivers/spi/libspi.o | 290 | LIBS-y += drivers/spi/libspi.o |
291 | LIBS-y += drivers/dfu/libdfu.o | 291 | LIBS-y += drivers/dfu/libdfu.o |
292 | ifeq ($(CPU),mpc83xx) | 292 | ifeq ($(CPU),mpc83xx) |
293 | LIBS-y += drivers/qe/libqe.o | 293 | LIBS-y += drivers/qe/libqe.o |
294 | LIBS-y += arch/powerpc/cpu/mpc8xxx/ddr/libddr.o | 294 | LIBS-y += arch/powerpc/cpu/mpc8xxx/ddr/libddr.o |
295 | LIBS-y += arch/powerpc/cpu/mpc8xxx/lib8xxx.o | 295 | LIBS-y += arch/powerpc/cpu/mpc8xxx/lib8xxx.o |
296 | endif | 296 | endif |
297 | ifeq ($(CPU),mpc85xx) | 297 | ifeq ($(CPU),mpc85xx) |
298 | LIBS-y += drivers/qe/libqe.o | 298 | LIBS-y += drivers/qe/libqe.o |
299 | LIBS-y += drivers/net/fm/libfm.o | 299 | LIBS-y += drivers/net/fm/libfm.o |
300 | LIBS-y += arch/powerpc/cpu/mpc8xxx/ddr/libddr.o | 300 | LIBS-y += arch/powerpc/cpu/mpc8xxx/ddr/libddr.o |
301 | LIBS-y += arch/powerpc/cpu/mpc8xxx/lib8xxx.o | 301 | LIBS-y += arch/powerpc/cpu/mpc8xxx/lib8xxx.o |
302 | endif | 302 | endif |
303 | ifeq ($(CPU),mpc86xx) | 303 | ifeq ($(CPU),mpc86xx) |
304 | LIBS-y += arch/powerpc/cpu/mpc8xxx/ddr/libddr.o | 304 | LIBS-y += arch/powerpc/cpu/mpc8xxx/ddr/libddr.o |
305 | LIBS-y += arch/powerpc/cpu/mpc8xxx/lib8xxx.o | 305 | LIBS-y += arch/powerpc/cpu/mpc8xxx/lib8xxx.o |
306 | endif | 306 | endif |
307 | LIBS-y += drivers/rtc/librtc.o | 307 | LIBS-y += drivers/rtc/librtc.o |
308 | LIBS-y += drivers/serial/libserial.o | 308 | LIBS-y += drivers/serial/libserial.o |
309 | LIBS-y += drivers/sound/libsound.o | 309 | LIBS-y += drivers/sound/libsound.o |
310 | LIBS-y += drivers/tpm/libtpm.o | 310 | LIBS-y += drivers/tpm/libtpm.o |
311 | LIBS-y += drivers/twserial/libtws.o | 311 | LIBS-y += drivers/twserial/libtws.o |
312 | LIBS-y += drivers/usb/eth/libusb_eth.o | 312 | LIBS-y += drivers/usb/eth/libusb_eth.o |
313 | LIBS-y += drivers/usb/gadget/libusb_gadget.o | 313 | LIBS-y += drivers/usb/gadget/libusb_gadget.o |
314 | LIBS-y += drivers/usb/host/libusb_host.o | 314 | LIBS-y += drivers/usb/host/libusb_host.o |
315 | LIBS-y += drivers/usb/musb/libusb_musb.o | 315 | LIBS-y += drivers/usb/musb/libusb_musb.o |
316 | LIBS-y += drivers/usb/musb-new/libusb_musb-new.o | 316 | LIBS-y += drivers/usb/musb-new/libusb_musb-new.o |
317 | LIBS-y += drivers/usb/phy/libusb_phy.o | 317 | LIBS-y += drivers/usb/phy/libusb_phy.o |
318 | LIBS-y += drivers/usb/ulpi/libusb_ulpi.o | 318 | LIBS-y += drivers/usb/ulpi/libusb_ulpi.o |
319 | LIBS-y += drivers/video/libvideo.o | 319 | LIBS-y += drivers/video/libvideo.o |
320 | LIBS-y += drivers/watchdog/libwatchdog.o | 320 | LIBS-y += drivers/watchdog/libwatchdog.o |
321 | LIBS-y += common/libcommon.o | 321 | LIBS-y += common/libcommon.o |
322 | LIBS-y += lib/libfdt/libfdt.o | 322 | LIBS-y += lib/libfdt/libfdt.o |
323 | LIBS-y += api/libapi.o | 323 | LIBS-y += api/libapi.o |
324 | LIBS-y += post/libpost.o | 324 | LIBS-y += post/libpost.o |
325 | LIBS-y += test/libtest.o | 325 | LIBS-y += test/libtest.o |
326 | 326 | ||
327 | ifneq ($(CONFIG_OMAP_COMMON),) | 327 | ifneq ($(CONFIG_OMAP_COMMON),) |
328 | LIBS-y += $(CPUDIR)/omap-common/libomap-common.o | 328 | LIBS-y += $(CPUDIR)/omap-common/libomap-common.o |
329 | endif | 329 | endif |
330 | 330 | ||
331 | ifneq (,$(filter $(SOC), mx25 mx27 mx5 mx6 mx31 mx35 mxs vf610)) | 331 | ifneq (,$(filter $(SOC), mx25 mx27 mx5 mx6 mx31 mx35 mxs vf610)) |
332 | LIBS-y += arch/$(ARCH)/imx-common/libimx-common.o | 332 | LIBS-y += arch/$(ARCH)/imx-common/libimx-common.o |
333 | endif | 333 | endif |
334 | 334 | ||
335 | ifeq ($(SOC),s5pc1xx) | 335 | ifeq ($(SOC),s5pc1xx) |
336 | LIBS-y += $(CPUDIR)/s5p-common/libs5p-common.o | 336 | LIBS-y += $(CPUDIR)/s5p-common/libs5p-common.o |
337 | endif | 337 | endif |
338 | ifeq ($(SOC),exynos) | 338 | ifeq ($(SOC),exynos) |
339 | LIBS-y += $(CPUDIR)/s5p-common/libs5p-common.o | 339 | LIBS-y += $(CPUDIR)/s5p-common/libs5p-common.o |
340 | endif | 340 | endif |
341 | ifneq ($(CONFIG_TEGRA),) | 341 | ifneq ($(CONFIG_TEGRA),) |
342 | LIBS-y += arch/$(ARCH)/cpu/$(SOC)-common/lib$(SOC)-common.o | 342 | LIBS-y += arch/$(ARCH)/cpu/$(SOC)-common/lib$(SOC)-common.o |
343 | LIBS-y += arch/$(ARCH)/cpu/tegra-common/libcputegra-common.o | 343 | LIBS-y += arch/$(ARCH)/cpu/tegra-common/libcputegra-common.o |
344 | LIBS-y += $(CPUDIR)/tegra-common/libtegra-common.o | 344 | LIBS-y += $(CPUDIR)/tegra-common/libtegra-common.o |
345 | endif | 345 | endif |
346 | 346 | ||
347 | LIBS := $(addprefix $(obj),$(sort $(LIBS-y))) | 347 | LIBS := $(addprefix $(obj),$(sort $(LIBS-y))) |
348 | .PHONY : $(LIBS) | 348 | .PHONY : $(LIBS) |
349 | 349 | ||
350 | LIBBOARD = board/$(BOARDDIR)/lib$(BOARD).o | 350 | LIBBOARD = board/$(BOARDDIR)/lib$(BOARD).o |
351 | LIBBOARD := $(addprefix $(obj),$(LIBBOARD)) | 351 | LIBBOARD := $(addprefix $(obj),$(LIBBOARD)) |
352 | 352 | ||
353 | # Add GCC lib | 353 | # Add GCC lib |
354 | ifdef USE_PRIVATE_LIBGCC | 354 | ifdef USE_PRIVATE_LIBGCC |
355 | ifeq ("$(USE_PRIVATE_LIBGCC)", "yes") | 355 | ifeq ("$(USE_PRIVATE_LIBGCC)", "yes") |
356 | PLATFORM_LIBGCC = $(OBJTREE)/arch/$(ARCH)/lib/libgcc.o | 356 | PLATFORM_LIBGCC = $(OBJTREE)/arch/$(ARCH)/lib/libgcc.o |
357 | else | 357 | else |
358 | PLATFORM_LIBGCC = -L $(USE_PRIVATE_LIBGCC) -lgcc | 358 | PLATFORM_LIBGCC = -L $(USE_PRIVATE_LIBGCC) -lgcc |
359 | endif | 359 | endif |
360 | else | 360 | else |
361 | PLATFORM_LIBGCC := -L $(shell dirname `$(CC) $(CFLAGS) -print-libgcc-file-name`) -lgcc | 361 | PLATFORM_LIBGCC := -L $(shell dirname `$(CC) $(CFLAGS) -print-libgcc-file-name`) -lgcc |
362 | endif | 362 | endif |
363 | PLATFORM_LIBS += $(PLATFORM_LIBGCC) | 363 | PLATFORM_LIBS += $(PLATFORM_LIBGCC) |
364 | export PLATFORM_LIBS | 364 | export PLATFORM_LIBS |
365 | 365 | ||
366 | # Special flags for CPP when processing the linker script. | 366 | # Special flags for CPP when processing the linker script. |
367 | # Pass the version down so we can handle backwards compatibility | 367 | # Pass the version down so we can handle backwards compatibility |
368 | # on the fly. | 368 | # on the fly. |
369 | LDPPFLAGS += \ | 369 | LDPPFLAGS += \ |
370 | -include $(TOPDIR)/include/u-boot/u-boot.lds.h \ | 370 | -include $(TOPDIR)/include/u-boot/u-boot.lds.h \ |
371 | -DCPUDIR=$(CPUDIR) \ | 371 | -DCPUDIR=$(CPUDIR) \ |
372 | $(shell $(LD) --version | \ | 372 | $(shell $(LD) --version | \ |
373 | sed -ne 's/GNU ld version \([0-9][0-9]*\)\.\([0-9][0-9]*\).*/-DLD_MAJOR=\1 -DLD_MINOR=\2/p') | 373 | sed -ne 's/GNU ld version \([0-9][0-9]*\)\.\([0-9][0-9]*\).*/-DLD_MAJOR=\1 -DLD_MINOR=\2/p') |
374 | 374 | ||
375 | __OBJS := $(subst $(obj),,$(OBJS)) | 375 | __OBJS := $(subst $(obj),,$(OBJS)) |
376 | __LIBS := $(subst $(obj),,$(LIBS)) $(subst $(obj),,$(LIBBOARD)) | 376 | __LIBS := $(subst $(obj),,$(LIBS)) $(subst $(obj),,$(LIBBOARD)) |
377 | 377 | ||
378 | ######################################################################### | 378 | ######################################################################### |
379 | ######################################################################### | 379 | ######################################################################### |
380 | 380 | ||
381 | ifneq ($(CONFIG_BOARD_SIZE_LIMIT),) | 381 | ifneq ($(CONFIG_BOARD_SIZE_LIMIT),) |
382 | BOARD_SIZE_CHECK = \ | 382 | BOARD_SIZE_CHECK = \ |
383 | @actual=`wc -c $@ | awk '{print $$1}'`; \ | 383 | @actual=`wc -c $@ | awk '{print $$1}'`; \ |
384 | limit=`printf "%d" $(CONFIG_BOARD_SIZE_LIMIT)`; \ | 384 | limit=`printf "%d" $(CONFIG_BOARD_SIZE_LIMIT)`; \ |
385 | if test $$actual -gt $$limit; then \ | 385 | if test $$actual -gt $$limit; then \ |
386 | echo "$@ exceeds file size limit:" >&2 ; \ | 386 | echo "$@ exceeds file size limit:" >&2 ; \ |
387 | echo " limit: $$limit bytes" >&2 ; \ | 387 | echo " limit: $$limit bytes" >&2 ; \ |
388 | echo " actual: $$actual bytes" >&2 ; \ | 388 | echo " actual: $$actual bytes" >&2 ; \ |
389 | echo " excess: $$((actual - limit)) bytes" >&2; \ | 389 | echo " excess: $$((actual - limit)) bytes" >&2; \ |
390 | exit 1; \ | 390 | exit 1; \ |
391 | fi | 391 | fi |
392 | else | 392 | else |
393 | BOARD_SIZE_CHECK = | 393 | BOARD_SIZE_CHECK = |
394 | endif | 394 | endif |
395 | 395 | ||
396 | # Always append ALL so that arch config.mk's can add custom ones | 396 | # Always append ALL so that arch config.mk's can add custom ones |
397 | ALL-y += $(obj)u-boot.srec $(obj)u-boot.bin $(obj)System.map | 397 | ALL-y += $(obj)u-boot.srec $(obj)u-boot.bin $(obj)System.map |
398 | 398 | ||
399 | ALL-$(CONFIG_NAND_U_BOOT) += $(obj)u-boot-nand.bin | 399 | ALL-$(CONFIG_NAND_U_BOOT) += $(obj)u-boot-nand.bin |
400 | ALL-$(CONFIG_ONENAND_U_BOOT) += $(obj)u-boot-onenand.bin | 400 | ALL-$(CONFIG_ONENAND_U_BOOT) += $(obj)u-boot-onenand.bin |
401 | ALL-$(CONFIG_RAMBOOT_PBL) += $(obj)u-boot.pbl | 401 | ALL-$(CONFIG_RAMBOOT_PBL) += $(obj)u-boot.pbl |
402 | ALL-$(CONFIG_SPL) += $(obj)spl/u-boot-spl.bin | 402 | ALL-$(CONFIG_SPL) += $(obj)spl/u-boot-spl.bin |
403 | ALL-$(CONFIG_SPL_FRAMEWORK) += $(obj)u-boot.img | 403 | ALL-$(CONFIG_SPL_FRAMEWORK) += $(obj)u-boot.img |
404 | ALL-$(CONFIG_TPL) += $(obj)tpl/u-boot-tpl.bin | 404 | ALL-$(CONFIG_TPL) += $(obj)tpl/u-boot-tpl.bin |
405 | ALL-$(CONFIG_OF_SEPARATE) += $(obj)u-boot.dtb $(obj)u-boot-dtb.bin | 405 | ALL-$(CONFIG_OF_SEPARATE) += $(obj)u-boot.dtb $(obj)u-boot-dtb.bin |
406 | ifneq ($(CONFIG_SPL_TARGET),) | 406 | ifneq ($(CONFIG_SPL_TARGET),) |
407 | ALL-$(CONFIG_SPL) += $(obj)$(subst ",,$(CONFIG_SPL_TARGET)) | 407 | ALL-$(CONFIG_SPL) += $(obj)$(subst ",,$(CONFIG_SPL_TARGET)) |
408 | endif | 408 | endif |
409 | 409 | ||
410 | # enable combined SPL/u-boot/dtb rules for tegra | 410 | # enable combined SPL/u-boot/dtb rules for tegra |
411 | ifneq ($(CONFIG_TEGRA),) | 411 | ifneq ($(CONFIG_TEGRA),) |
412 | ifeq ($(CONFIG_OF_SEPARATE),y) | 412 | ifeq ($(CONFIG_OF_SEPARATE),y) |
413 | ALL-y += $(obj)u-boot-dtb-tegra.bin | 413 | ALL-y += $(obj)u-boot-dtb-tegra.bin |
414 | else | 414 | else |
415 | ALL-y += $(obj)u-boot-nodtb-tegra.bin | 415 | ALL-y += $(obj)u-boot-nodtb-tegra.bin |
416 | endif | 416 | endif |
417 | endif | 417 | endif |
418 | 418 | ||
419 | all: $(ALL-y) $(SUBDIR_EXAMPLES) | 419 | all: $(ALL-y) $(SUBDIR_EXAMPLES) |
420 | 420 | ||
421 | $(obj)u-boot.dtb: checkdtc $(obj)u-boot | 421 | $(obj)u-boot.dtb: checkdtc $(obj)u-boot |
422 | $(MAKE) -C dts binary | 422 | $(MAKE) -C dts binary |
423 | mv $(obj)dts/dt.dtb $@ | 423 | mv $(obj)dts/dt.dtb $@ |
424 | 424 | ||
425 | $(obj)u-boot-dtb.bin: $(obj)u-boot.bin $(obj)u-boot.dtb | 425 | $(obj)u-boot-dtb.bin: $(obj)u-boot.bin $(obj)u-boot.dtb |
426 | cat $^ >$@ | 426 | cat $^ >$@ |
427 | 427 | ||
428 | $(obj)u-boot.hex: $(obj)u-boot | 428 | $(obj)u-boot.hex: $(obj)u-boot |
429 | $(OBJCOPY) ${OBJCFLAGS} -O ihex $< $@ | 429 | $(OBJCOPY) ${OBJCFLAGS} -O ihex $< $@ |
430 | 430 | ||
431 | $(obj)u-boot.srec: $(obj)u-boot | 431 | $(obj)u-boot.srec: $(obj)u-boot |
432 | $(OBJCOPY) -O srec $< $@ | 432 | $(OBJCOPY) -O srec $< $@ |
433 | 433 | ||
434 | $(obj)u-boot.bin: $(obj)u-boot | 434 | $(obj)u-boot.bin: $(obj)u-boot |
435 | $(OBJCOPY) ${OBJCFLAGS} -O binary $< $@ | 435 | $(OBJCOPY) ${OBJCFLAGS} -O binary $< $@ |
436 | $(BOARD_SIZE_CHECK) | 436 | $(BOARD_SIZE_CHECK) |
437 | 437 | ||
438 | $(obj)u-boot.ldr: $(obj)u-boot | 438 | $(obj)u-boot.ldr: $(obj)u-boot |
439 | $(CREATE_LDR_ENV) | 439 | $(CREATE_LDR_ENV) |
440 | $(LDR) -T $(CONFIG_BFIN_CPU) -c $@ $< $(LDR_FLAGS) | 440 | $(LDR) -T $(CONFIG_BFIN_CPU) -c $@ $< $(LDR_FLAGS) |
441 | $(BOARD_SIZE_CHECK) | 441 | $(BOARD_SIZE_CHECK) |
442 | 442 | ||
443 | $(obj)u-boot.ldr.hex: $(obj)u-boot.ldr | 443 | $(obj)u-boot.ldr.hex: $(obj)u-boot.ldr |
444 | $(OBJCOPY) ${OBJCFLAGS} -O ihex $< $@ -I binary | 444 | $(OBJCOPY) ${OBJCFLAGS} -O ihex $< $@ -I binary |
445 | 445 | ||
446 | $(obj)u-boot.ldr.srec: $(obj)u-boot.ldr | 446 | $(obj)u-boot.ldr.srec: $(obj)u-boot.ldr |
447 | $(OBJCOPY) ${OBJCFLAGS} -O srec $< $@ -I binary | 447 | $(OBJCOPY) ${OBJCFLAGS} -O srec $< $@ -I binary |
448 | 448 | ||
449 | # | 449 | # |
450 | # U-Boot entry point, needed for booting of full-blown U-Boot | 450 | # U-Boot entry point, needed for booting of full-blown U-Boot |
451 | # from the SPL U-Boot version. | 451 | # from the SPL U-Boot version. |
452 | # | 452 | # |
453 | ifndef CONFIG_SYS_UBOOT_START | 453 | ifndef CONFIG_SYS_UBOOT_START |
454 | CONFIG_SYS_UBOOT_START := 0 | 454 | CONFIG_SYS_UBOOT_START := 0 |
455 | endif | 455 | endif |
456 | 456 | ||
457 | $(obj)u-boot.img: $(obj)u-boot.bin | 457 | $(obj)u-boot.img: $(obj)u-boot.bin |
458 | $(obj)tools/mkimage -A $(ARCH) -T firmware -C none \ | 458 | $(obj)tools/mkimage -A $(ARCH) -T firmware -C none \ |
459 | -O u-boot -a $(CONFIG_SYS_TEXT_BASE) \ | 459 | -O u-boot -a $(CONFIG_SYS_TEXT_BASE) \ |
460 | -e $(CONFIG_SYS_UBOOT_START) \ | 460 | -e $(CONFIG_SYS_UBOOT_START) \ |
461 | -n $(shell sed -n -e 's/.*U_BOOT_VERSION//p' $(VERSION_FILE) | \ | 461 | -n $(shell sed -n -e 's/.*U_BOOT_VERSION//p' $(VERSION_FILE) | \ |
462 | sed -e 's/"[ ]*$$/ for $(BOARD) board"/') \ | 462 | sed -e 's/"[ ]*$$/ for $(BOARD) board"/') \ |
463 | -d $< $@ | 463 | -d $< $@ |
464 | 464 | ||
465 | $(obj)u-boot.imx: $(obj)u-boot.bin depend | 465 | $(obj)u-boot.imx: $(obj)u-boot.bin depend |
466 | $(MAKE) -C $(SRCTREE)/arch/arm/imx-common $(OBJTREE)/u-boot.imx | 466 | $(MAKE) -C $(SRCTREE)/arch/arm/imx-common $(OBJTREE)/u-boot.imx |
467 | 467 | ||
468 | $(obj)u-boot.kwb: $(obj)u-boot.bin | 468 | $(obj)u-boot.kwb: $(obj)u-boot.bin |
469 | $(obj)tools/mkimage -n $(CONFIG_SYS_KWD_CONFIG) -T kwbimage \ | 469 | $(obj)tools/mkimage -n $(CONFIG_SYS_KWD_CONFIG) -T kwbimage \ |
470 | -a $(CONFIG_SYS_TEXT_BASE) -e $(CONFIG_SYS_TEXT_BASE) -d $< $@ | 470 | -a $(CONFIG_SYS_TEXT_BASE) -e $(CONFIG_SYS_TEXT_BASE) -d $< $@ |
471 | 471 | ||
472 | $(obj)u-boot.pbl: $(obj)u-boot.bin | 472 | $(obj)u-boot.pbl: $(obj)u-boot.bin |
473 | $(obj)tools/mkimage -n $(CONFIG_PBLRCW_CONFIG) \ | 473 | $(obj)tools/mkimage -n $(CONFIG_PBLRCW_CONFIG) \ |
474 | -R $(CONFIG_PBLPBI_CONFIG) -T pblimage \ | 474 | -R $(CONFIG_PBLPBI_CONFIG) -T pblimage \ |
475 | -d $< $@ | 475 | -d $< $@ |
476 | 476 | ||
477 | $(obj)u-boot.sha1: $(obj)u-boot.bin | 477 | $(obj)u-boot.sha1: $(obj)u-boot.bin |
478 | $(obj)tools/ubsha1 $(obj)u-boot.bin | 478 | $(obj)tools/ubsha1 $(obj)u-boot.bin |
479 | 479 | ||
480 | $(obj)u-boot.dis: $(obj)u-boot | 480 | $(obj)u-boot.dis: $(obj)u-boot |
481 | $(OBJDUMP) -d $< > $@ | 481 | $(OBJDUMP) -d $< > $@ |
482 | 482 | ||
483 | # $@ is output, $(1) and $(2) are inputs, $(3) is padded intermediate, | 483 | # $@ is output, $(1) and $(2) are inputs, $(3) is padded intermediate, |
484 | # $(4) is pad-to | 484 | # $(4) is pad-to |
485 | SPL_PAD_APPEND = \ | 485 | SPL_PAD_APPEND = \ |
486 | $(OBJCOPY) ${OBJCFLAGS} --pad-to=$(4) -I binary -O binary \ | 486 | $(OBJCOPY) ${OBJCFLAGS} --pad-to=$(4) -I binary -O binary \ |
487 | $(1) $(obj)$(3); \ | 487 | $(1) $(obj)$(3); \ |
488 | cat $(obj)$(3) $(2) > $@; \ | 488 | cat $(obj)$(3) $(2) > $@; \ |
489 | rm $(obj)$(3) | 489 | rm $(obj)$(3) |
490 | 490 | ||
491 | ifdef CONFIG_TPL | 491 | ifdef CONFIG_TPL |
492 | SPL_PAYLOAD := $(obj)tpl/u-boot-with-tpl.bin | 492 | SPL_PAYLOAD := $(obj)tpl/u-boot-with-tpl.bin |
493 | else | 493 | else |
494 | SPL_PAYLOAD := $(obj)u-boot.bin | 494 | SPL_PAYLOAD := $(obj)u-boot.bin |
495 | endif | 495 | endif |
496 | 496 | ||
497 | $(obj)u-boot-with-spl.bin: $(obj)spl/u-boot-spl.bin $(SPL_PAYLOAD) | 497 | $(obj)u-boot-with-spl.bin: $(obj)spl/u-boot-spl.bin $(SPL_PAYLOAD) |
498 | $(call SPL_PAD_APPEND,$<,$(SPL_PAYLOAD),spl/u-boot-spl-pad.bin,$(CONFIG_SPL_PAD_TO)) | 498 | $(call SPL_PAD_APPEND,$<,$(SPL_PAYLOAD),spl/u-boot-spl-pad.bin,$(CONFIG_SPL_PAD_TO)) |
499 | 499 | ||
500 | $(obj)tpl/u-boot-with-tpl.bin: $(obj)tpl/u-boot-tpl.bin $(obj)u-boot.bin | 500 | $(obj)tpl/u-boot-with-tpl.bin: $(obj)tpl/u-boot-tpl.bin $(obj)u-boot.bin |
501 | $(call SPL_PAD_APPEND,$<,$(obj)u-boot.bin,tpl/u-boot-tpl-pad.bin,$(CONFIG_TPL_PAD_TO)) | 501 | $(call SPL_PAD_APPEND,$<,$(obj)u-boot.bin,tpl/u-boot-tpl-pad.bin,$(CONFIG_TPL_PAD_TO)) |
502 | 502 | ||
503 | $(obj)u-boot-with-spl.imx: $(obj)spl/u-boot-spl.bin $(obj)u-boot.bin | 503 | $(obj)u-boot-with-spl.imx: $(obj)spl/u-boot-spl.bin $(obj)u-boot.bin |
504 | $(MAKE) -C $(SRCTREE)/arch/arm/imx-common \ | 504 | $(MAKE) -C $(SRCTREE)/arch/arm/imx-common \ |
505 | $(OBJTREE)/u-boot-with-spl.imx | 505 | $(OBJTREE)/u-boot-with-spl.imx |
506 | 506 | ||
507 | $(obj)u-boot-with-nand-spl.imx: $(obj)spl/u-boot-spl.bin $(obj)u-boot.bin | 507 | $(obj)u-boot-with-nand-spl.imx: $(obj)spl/u-boot-spl.bin $(obj)u-boot.bin |
508 | $(MAKE) -C $(SRCTREE)/arch/arm/imx-common \ | 508 | $(MAKE) -C $(SRCTREE)/arch/arm/imx-common \ |
509 | $(OBJTREE)/u-boot-with-nand-spl.imx | 509 | $(OBJTREE)/u-boot-with-nand-spl.imx |
510 | 510 | ||
511 | $(obj)u-boot.ubl: $(obj)u-boot-with-spl.bin | 511 | $(obj)u-boot.ubl: $(obj)u-boot-with-spl.bin |
512 | $(obj)tools/mkimage -n $(UBL_CONFIG) -T ublimage \ | 512 | $(obj)tools/mkimage -n $(UBL_CONFIG) -T ublimage \ |
513 | -e $(CONFIG_SYS_TEXT_BASE) -d $< $(obj)u-boot.ubl | 513 | -e $(CONFIG_SYS_TEXT_BASE) -d $< $(obj)u-boot.ubl |
514 | 514 | ||
515 | $(obj)u-boot.ais: $(obj)spl/u-boot-spl.bin $(obj)u-boot.img | 515 | $(obj)u-boot.ais: $(obj)spl/u-boot-spl.bin $(obj)u-boot.img |
516 | $(obj)tools/mkimage -s -n $(if $(CONFIG_AIS_CONFIG_FILE),$(CONFIG_AIS_CONFIG_FILE),"/dev/null") \ | 516 | $(obj)tools/mkimage -s -n $(if $(CONFIG_AIS_CONFIG_FILE),$(CONFIG_AIS_CONFIG_FILE),"/dev/null") \ |
517 | -T aisimage \ | 517 | -T aisimage \ |
518 | -e $(CONFIG_SPL_TEXT_BASE) \ | 518 | -e $(CONFIG_SPL_TEXT_BASE) \ |
519 | -d $(obj)spl/u-boot-spl.bin \ | 519 | -d $(obj)spl/u-boot-spl.bin \ |
520 | $(obj)spl/u-boot-spl.ais | 520 | $(obj)spl/u-boot-spl.ais |
521 | $(OBJCOPY) ${OBJCFLAGS} -I binary \ | 521 | $(OBJCOPY) ${OBJCFLAGS} -I binary \ |
522 | --pad-to=$(CONFIG_SPL_MAX_SIZE) -O binary \ | 522 | --pad-to=$(CONFIG_SPL_MAX_SIZE) -O binary \ |
523 | $(obj)spl/u-boot-spl.ais $(obj)spl/u-boot-spl-pad.ais | 523 | $(obj)spl/u-boot-spl.ais $(obj)spl/u-boot-spl-pad.ais |
524 | cat $(obj)spl/u-boot-spl-pad.ais $(obj)u-boot.img > \ | 524 | cat $(obj)spl/u-boot-spl-pad.ais $(obj)u-boot.img > \ |
525 | $(obj)u-boot.ais | 525 | $(obj)u-boot.ais |
526 | 526 | ||
527 | 527 | ||
528 | $(obj)u-boot.sb: $(obj)u-boot.bin $(obj)spl/u-boot-spl.bin | 528 | $(obj)u-boot.sb: $(obj)u-boot.bin $(obj)spl/u-boot-spl.bin |
529 | $(MAKE) -C $(SRCTREE)/$(CPUDIR)/$(SOC)/ $(OBJTREE)/u-boot.sb | 529 | $(MAKE) -C $(SRCTREE)/$(CPUDIR)/$(SOC)/ $(OBJTREE)/u-boot.sb |
530 | 530 | ||
531 | # On x600 (SPEAr600) U-Boot is appended to U-Boot SPL. | 531 | # On x600 (SPEAr600) U-Boot is appended to U-Boot SPL. |
532 | # Both images are created using mkimage (crc etc), so that the ROM | 532 | # Both images are created using mkimage (crc etc), so that the ROM |
533 | # bootloader can check its integrity. Padding needs to be done to the | 533 | # bootloader can check its integrity. Padding needs to be done to the |
534 | # SPL image (with mkimage header) and not the binary. Otherwise the resulting image | 534 | # SPL image (with mkimage header) and not the binary. Otherwise the resulting image |
535 | # which is loaded/copied by the ROM bootloader to SRAM doesn't fit. | 535 | # which is loaded/copied by the ROM bootloader to SRAM doesn't fit. |
536 | # The resulting image containing both U-Boot images is called u-boot.spr | 536 | # The resulting image containing both U-Boot images is called u-boot.spr |
537 | $(obj)u-boot.spr: $(obj)u-boot.img $(obj)spl/u-boot-spl.bin | 537 | $(obj)u-boot.spr: $(obj)u-boot.img $(obj)spl/u-boot-spl.bin |
538 | $(obj)tools/mkimage -A $(ARCH) -T firmware -C none \ | 538 | $(obj)tools/mkimage -A $(ARCH) -T firmware -C none \ |
539 | -a $(CONFIG_SPL_TEXT_BASE) -e $(CONFIG_SPL_TEXT_BASE) -n XLOADER \ | 539 | -a $(CONFIG_SPL_TEXT_BASE) -e $(CONFIG_SPL_TEXT_BASE) -n XLOADER \ |
540 | -d $(obj)spl/u-boot-spl.bin $(obj)spl/u-boot-spl.img | 540 | -d $(obj)spl/u-boot-spl.bin $(obj)spl/u-boot-spl.img |
541 | tr "\000" "\377" < /dev/zero | dd ibs=1 count=$(CONFIG_SPL_PAD_TO) \ | 541 | tr "\000" "\377" < /dev/zero | dd ibs=1 count=$(CONFIG_SPL_PAD_TO) \ |
542 | of=$(obj)spl/u-boot-spl-pad.img 2>/dev/null | 542 | of=$(obj)spl/u-boot-spl-pad.img 2>/dev/null |
543 | dd if=$(obj)spl/u-boot-spl.img of=$(obj)spl/u-boot-spl-pad.img \ | 543 | dd if=$(obj)spl/u-boot-spl.img of=$(obj)spl/u-boot-spl-pad.img \ |
544 | conv=notrunc 2>/dev/null | 544 | conv=notrunc 2>/dev/null |
545 | cat $(obj)spl/u-boot-spl-pad.img $(obj)u-boot.img > $@ | 545 | cat $(obj)spl/u-boot-spl-pad.img $(obj)u-boot.img > $@ |
546 | 546 | ||
547 | ifneq ($(CONFIG_TEGRA),) | 547 | ifneq ($(CONFIG_TEGRA),) |
548 | $(obj)u-boot-nodtb-tegra.bin: $(obj)spl/u-boot-spl.bin $(obj)u-boot.bin | 548 | $(obj)u-boot-nodtb-tegra.bin: $(obj)spl/u-boot-spl.bin $(obj)u-boot.bin |
549 | $(OBJCOPY) ${OBJCFLAGS} --pad-to=$(CONFIG_SYS_TEXT_BASE) -O binary $(obj)spl/u-boot-spl $(obj)spl/u-boot-spl-pad.bin | 549 | $(OBJCOPY) ${OBJCFLAGS} --pad-to=$(CONFIG_SYS_TEXT_BASE) -O binary $(obj)spl/u-boot-spl $(obj)spl/u-boot-spl-pad.bin |
550 | cat $(obj)spl/u-boot-spl-pad.bin $(obj)u-boot.bin > $@ | 550 | cat $(obj)spl/u-boot-spl-pad.bin $(obj)u-boot.bin > $@ |
551 | rm $(obj)spl/u-boot-spl-pad.bin | 551 | rm $(obj)spl/u-boot-spl-pad.bin |
552 | 552 | ||
553 | ifeq ($(CONFIG_OF_SEPARATE),y) | 553 | ifeq ($(CONFIG_OF_SEPARATE),y) |
554 | $(obj)u-boot-dtb-tegra.bin: $(obj)u-boot-nodtb-tegra.bin $(obj)u-boot.dtb | 554 | $(obj)u-boot-dtb-tegra.bin: $(obj)u-boot-nodtb-tegra.bin $(obj)u-boot.dtb |
555 | cat $(obj)u-boot-nodtb-tegra.bin $(obj)u-boot.dtb > $@ | 555 | cat $(obj)u-boot-nodtb-tegra.bin $(obj)u-boot.dtb > $@ |
556 | endif | 556 | endif |
557 | endif | 557 | endif |
558 | 558 | ||
559 | $(obj)u-boot-img.bin: $(obj)spl/u-boot-spl.bin $(obj)u-boot.img | 559 | $(obj)u-boot-img.bin: $(obj)spl/u-boot-spl.bin $(obj)u-boot.img |
560 | cat $(obj)spl/u-boot-spl.bin $(obj)u-boot.img > $@ | 560 | cat $(obj)spl/u-boot-spl.bin $(obj)u-boot.img > $@ |
561 | 561 | ||
562 | # PPC4xx needs the SPL at the end of the image, since the reset vector | 562 | # PPC4xx needs the SPL at the end of the image, since the reset vector |
563 | # is located at 0xfffffffc. So we can't use the "u-boot-img.bin" target | 563 | # is located at 0xfffffffc. So we can't use the "u-boot-img.bin" target |
564 | # and need to introduce a new build target with the full blown U-Boot | 564 | # and need to introduce a new build target with the full blown U-Boot |
565 | # at the start padded up to the start of the SPL image. And then concat | 565 | # at the start padded up to the start of the SPL image. And then concat |
566 | # the SPL image to the end. | 566 | # the SPL image to the end. |
567 | $(obj)u-boot-img-spl-at-end.bin: $(obj)spl/u-boot-spl.bin $(obj)u-boot.img | 567 | $(obj)u-boot-img-spl-at-end.bin: $(obj)spl/u-boot-spl.bin $(obj)u-boot.img |
568 | tr "\000" "\377" < /dev/zero | dd ibs=1 count=$(CONFIG_UBOOT_PAD_TO) \ | 568 | tr "\000" "\377" < /dev/zero | dd ibs=1 count=$(CONFIG_UBOOT_PAD_TO) \ |
569 | of=$(obj)u-boot-pad.img 2>/dev/null | 569 | of=$(obj)u-boot-pad.img 2>/dev/null |
570 | dd if=$(obj)u-boot.img of=$(obj)u-boot-pad.img \ | 570 | dd if=$(obj)u-boot.img of=$(obj)u-boot-pad.img \ |
571 | conv=notrunc 2>/dev/null | 571 | conv=notrunc 2>/dev/null |
572 | cat $(obj)u-boot-pad.img $(obj)spl/u-boot-spl.bin > $@ | 572 | cat $(obj)u-boot-pad.img $(obj)spl/u-boot-spl.bin > $@ |
573 | 573 | ||
574 | ifeq ($(CONFIG_SANDBOX),y) | 574 | ifeq ($(CONFIG_SANDBOX),y) |
575 | GEN_UBOOT = \ | 575 | GEN_UBOOT = \ |
576 | cd $(LNDIR) && $(CC) $(SYMS) -T $(obj)u-boot.lds \ | 576 | cd $(LNDIR) && $(CC) $(SYMS) -T $(obj)u-boot.lds \ |
577 | -Wl,--start-group $(__LIBS) -Wl,--end-group \ | 577 | -Wl,--start-group $(__LIBS) -Wl,--end-group \ |
578 | $(PLATFORM_LIBS) -Wl,-Map -Wl,u-boot.map -o u-boot | 578 | $(PLATFORM_LIBS) -Wl,-Map -Wl,u-boot.map -o u-boot |
579 | else | 579 | else |
580 | GEN_UBOOT = \ | 580 | GEN_UBOOT = \ |
581 | cd $(LNDIR) && $(LD) $(LDFLAGS) $(LDFLAGS_$(@F)) \ | 581 | cd $(LNDIR) && $(LD) $(LDFLAGS) $(LDFLAGS_$(@F)) \ |
582 | $(__OBJS) \ | 582 | $(__OBJS) \ |
583 | --start-group $(__LIBS) --end-group $(PLATFORM_LIBS) \ | 583 | --start-group $(__LIBS) --end-group $(PLATFORM_LIBS) \ |
584 | -Map u-boot.map -o u-boot | 584 | -Map u-boot.map -o u-boot |
585 | endif | 585 | endif |
586 | 586 | ||
587 | $(obj)u-boot: depend \ | 587 | $(obj)u-boot: depend \ |
588 | $(SUBDIR_TOOLS) $(OBJS) $(LIBBOARD) $(LIBS) $(LDSCRIPT) $(obj)u-boot.lds | 588 | $(SUBDIR_TOOLS) $(OBJS) $(LIBBOARD) $(LIBS) $(LDSCRIPT) $(obj)u-boot.lds |
589 | $(GEN_UBOOT) | 589 | $(GEN_UBOOT) |
590 | ifeq ($(CONFIG_KALLSYMS),y) | 590 | ifeq ($(CONFIG_KALLSYMS),y) |
591 | smap=`$(call SYSTEM_MAP,$(obj)u-boot) | \ | 591 | smap=`$(call SYSTEM_MAP,$(obj)u-boot) | \ |
592 | awk '$$2 ~ /[tTwW]/ {printf $$1 $$3 "\\\\000"}'` ; \ | 592 | awk '$$2 ~ /[tTwW]/ {printf $$1 $$3 "\\\\000"}'` ; \ |
593 | $(CC) $(CFLAGS) -DSYSTEM_MAP="\"$${smap}\"" \ | 593 | $(CC) $(CFLAGS) -DSYSTEM_MAP="\"$${smap}\"" \ |
594 | -c common/system_map.c -o $(obj)common/system_map.o | 594 | -c common/system_map.c -o $(obj)common/system_map.o |
595 | $(GEN_UBOOT) $(obj)common/system_map.o | 595 | $(GEN_UBOOT) $(obj)common/system_map.o |
596 | endif | 596 | endif |
597 | 597 | ||
598 | # Tentative step for Kbuild-style makefiles coexist with conventional U-Boot style makefiles | ||
599 | # U-Boot conventional sub makefiles always include some other makefiles. | ||
600 | # So, the build system searches a line beginning with "include" before entering into the sub makefile | ||
601 | # in order to distinguish which style it is. | ||
602 | # If the Makefile include a "include" line, we assume it is an U-Boot style makefile. | ||
603 | # Otherwise, it is treated as a Kbuild-style makefile. | ||
604 | select_makefile = \ | ||
605 | +if grep -q "^include" $1/Makefile; then \ | ||
606 | $(MAKE) -C $1; \ | ||
607 | else \ | ||
608 | $(MAKE) -C $1 -f $(TOPDIR)/scripts/Makefile.build; \ | ||
609 | mv $(dir $@)built-in.o $@; \ | ||
610 | fi | ||
611 | |||
612 | # We do not need to build $(OBJS) explicitly. | ||
613 | # It is built while we are at $(CPUDIR)/lib$(CPU).o build. | ||
598 | $(OBJS): depend | 614 | $(OBJS): depend |
599 | $(MAKE) -C $(CPUDIR) $(if $(REMOTE_BUILD),$@,$(notdir $@)) | 615 | if grep -q "^include" $(CPUDIR)/Makefile; then \ |
616 | $(MAKE) -C $(CPUDIR) $(if $(REMOTE_BUILD),$@,$(notdir $@)); \ | ||
617 | fi | ||
600 | 618 | ||
601 | $(LIBS): depend $(SUBDIR_TOOLS) | 619 | $(LIBS): depend $(SUBDIR_TOOLS) |
602 | $(MAKE) -C $(dir $(subst $(obj),,$@)) | 620 | +$(call select_makefile, $(dir $(subst $(obj),,$@))) |
603 | 621 | ||
604 | $(LIBBOARD): depend $(LIBS) | 622 | $(LIBBOARD): depend $(LIBS) |
605 | $(MAKE) -C $(dir $(subst $(obj),,$@)) | 623 | +$(call select_makefile, $(dir $(subst $(obj),,$@))) |
606 | 624 | ||
607 | $(SUBDIRS): depend | 625 | $(SUBDIRS): depend |
608 | $(MAKE) -C $@ all | 626 | $(MAKE) -C $@ all |
609 | 627 | ||
610 | $(SUBDIR_EXAMPLES): $(obj)u-boot | 628 | $(SUBDIR_EXAMPLES): $(obj)u-boot |
611 | 629 | ||
612 | $(LDSCRIPT): depend | 630 | $(LDSCRIPT): depend |
613 | $(MAKE) -C $(dir $@) $(notdir $@) | 631 | $(MAKE) -C $(dir $@) $(notdir $@) |
614 | 632 | ||
615 | $(obj)u-boot.lds: $(LDSCRIPT) | 633 | $(obj)u-boot.lds: $(LDSCRIPT) |
616 | $(CPP) $(CPPFLAGS) $(LDPPFLAGS) -ansi -D__ASSEMBLY__ -P - <$< >$@ | 634 | $(CPP) $(CPPFLAGS) $(LDPPFLAGS) -ansi -D__ASSEMBLY__ -P - <$< >$@ |
617 | 635 | ||
618 | nand_spl: $(TIMESTAMP_FILE) $(VERSION_FILE) depend | 636 | nand_spl: $(TIMESTAMP_FILE) $(VERSION_FILE) depend |
619 | $(MAKE) -C nand_spl/board/$(BOARDDIR) all | 637 | $(MAKE) -C nand_spl/board/$(BOARDDIR) all |
620 | 638 | ||
621 | $(obj)u-boot-nand.bin: nand_spl $(obj)u-boot.bin | 639 | $(obj)u-boot-nand.bin: nand_spl $(obj)u-boot.bin |
622 | cat $(obj)nand_spl/u-boot-spl-16k.bin $(obj)u-boot.bin > $(obj)u-boot-nand.bin | 640 | cat $(obj)nand_spl/u-boot-spl-16k.bin $(obj)u-boot.bin > $(obj)u-boot-nand.bin |
623 | 641 | ||
624 | $(obj)spl/u-boot-spl.bin: $(SUBDIR_TOOLS) depend | 642 | $(obj)spl/u-boot-spl.bin: $(SUBDIR_TOOLS) depend |
625 | $(MAKE) -C spl all | 643 | $(MAKE) -C spl all |
626 | 644 | ||
627 | $(obj)tpl/u-boot-tpl.bin: $(SUBDIR_TOOLS) depend | 645 | $(obj)tpl/u-boot-tpl.bin: $(SUBDIR_TOOLS) depend |
628 | $(MAKE) -C spl all CONFIG_TPL_BUILD=y | 646 | $(MAKE) -C spl all CONFIG_TPL_BUILD=y |
629 | 647 | ||
630 | updater: | 648 | updater: |
631 | $(MAKE) -C tools/updater all | 649 | $(MAKE) -C tools/updater all |
632 | 650 | ||
651 | select_makefile2 = \ | ||
652 | if grep -q "^include" $1/Makefile; then \ | ||
653 | $(MAKE) -C $1 _depend; \ | ||
654 | else \ | ||
655 | $(MAKE) -C $1 -f $(TOPDIR)/scripts/Makefile.build _depend; \ | ||
656 | fi | ||
657 | |||
633 | # Explicitly make _depend in subdirs containing multiple targets to prevent | 658 | # Explicitly make _depend in subdirs containing multiple targets to prevent |
634 | # parallel sub-makes creating .depend files simultaneously. | 659 | # parallel sub-makes creating .depend files simultaneously. |
635 | depend dep: $(TIMESTAMP_FILE) $(VERSION_FILE) \ | 660 | depend dep: $(TIMESTAMP_FILE) $(VERSION_FILE) \ |
636 | $(obj)include/spl-autoconf.mk \ | 661 | $(obj)include/spl-autoconf.mk \ |
637 | $(obj)include/tpl-autoconf.mk \ | 662 | $(obj)include/tpl-autoconf.mk \ |
638 | $(obj)include/autoconf.mk \ | 663 | $(obj)include/autoconf.mk \ |
639 | $(obj)include/generated/generic-asm-offsets.h \ | 664 | $(obj)include/generated/generic-asm-offsets.h \ |
640 | $(obj)include/generated/asm-offsets.h | 665 | $(obj)include/generated/asm-offsets.h |
641 | for dir in $(SUBDIRS) $(CPUDIR) $(LDSCRIPT_MAKEFILE_DIR) ; do \ | 666 | +for dir in $(SUBDIRS) $(CPUDIR) $(LDSCRIPT_MAKEFILE_DIR) ; do \ |
642 | $(MAKE) -C $$dir _depend ; done | 667 | $(call select_makefile2, $$dir); \ |
668 | done | ||
643 | 669 | ||
644 | TAG_SUBDIRS = $(SUBDIRS) | 670 | TAG_SUBDIRS = $(SUBDIRS) |
645 | TAG_SUBDIRS += $(dir $(__LIBS)) | 671 | TAG_SUBDIRS += $(dir $(__LIBS)) |
646 | TAG_SUBDIRS += include | 672 | TAG_SUBDIRS += include |
647 | 673 | ||
648 | FIND := find | 674 | FIND := find |
649 | FINDFLAGS := -L | 675 | FINDFLAGS := -L |
650 | 676 | ||
651 | checkstack: | 677 | checkstack: |
652 | $(CROSS_COMPILE)objdump -d $(obj)u-boot \ | 678 | $(CROSS_COMPILE)objdump -d $(obj)u-boot \ |
653 | `$(FIND) $(obj) -name u-boot-spl -print` | \ | 679 | `$(FIND) $(obj) -name u-boot-spl -print` | \ |
654 | perl $(src)tools/checkstack.pl $(ARCH) | 680 | perl $(src)tools/checkstack.pl $(ARCH) |
655 | 681 | ||
656 | tags ctags: | 682 | tags ctags: |
657 | ctags -w -o $(obj)ctags `$(FIND) $(FINDFLAGS) $(TAG_SUBDIRS) \ | 683 | ctags -w -o $(obj)ctags `$(FIND) $(FINDFLAGS) $(TAG_SUBDIRS) \ |
658 | -name '*.[chS]' -print` | 684 | -name '*.[chS]' -print` |
659 | 685 | ||
660 | etags: | 686 | etags: |
661 | etags -a -o $(obj)etags `$(FIND) $(FINDFLAGS) $(TAG_SUBDIRS) \ | 687 | etags -a -o $(obj)etags `$(FIND) $(FINDFLAGS) $(TAG_SUBDIRS) \ |
662 | -name '*.[chS]' -print` | 688 | -name '*.[chS]' -print` |
663 | cscope: | 689 | cscope: |
664 | $(FIND) $(FINDFLAGS) $(TAG_SUBDIRS) -name '*.[chS]' -print > \ | 690 | $(FIND) $(FINDFLAGS) $(TAG_SUBDIRS) -name '*.[chS]' -print > \ |
665 | cscope.files | 691 | cscope.files |
666 | cscope -b -q -k | 692 | cscope -b -q -k |
667 | 693 | ||
668 | SYSTEM_MAP = \ | 694 | SYSTEM_MAP = \ |
669 | $(NM) $1 | \ | 695 | $(NM) $1 | \ |
670 | grep -v '\(compiled\)\|\(\.o$$\)\|\( [aUw] \)\|\(\.\.ng$$\)\|\(LASH[RL]DI\)' | \ | 696 | grep -v '\(compiled\)\|\(\.o$$\)\|\( [aUw] \)\|\(\.\.ng$$\)\|\(LASH[RL]DI\)' | \ |
671 | LC_ALL=C sort | 697 | LC_ALL=C sort |
672 | $(obj)System.map: $(obj)u-boot | 698 | $(obj)System.map: $(obj)u-boot |
673 | @$(call SYSTEM_MAP,$<) > $(obj)System.map | 699 | @$(call SYSTEM_MAP,$<) > $(obj)System.map |
674 | 700 | ||
675 | checkthumb: | 701 | checkthumb: |
676 | @if test $(call cc-version) -lt 0404; then \ | 702 | @if test $(call cc-version) -lt 0404; then \ |
677 | echo -n '*** Your GCC does not produce working '; \ | 703 | echo -n '*** Your GCC does not produce working '; \ |
678 | echo 'binaries in THUMB mode.'; \ | 704 | echo 'binaries in THUMB mode.'; \ |
679 | echo '*** Your board is configured for THUMB mode.'; \ | 705 | echo '*** Your board is configured for THUMB mode.'; \ |
680 | false; \ | 706 | false; \ |
681 | fi | 707 | fi |
682 | 708 | ||
683 | # GCC 3.x is reported to have problems generating the type of relocation | 709 | # GCC 3.x is reported to have problems generating the type of relocation |
684 | # that U-Boot wants. | 710 | # that U-Boot wants. |
685 | # See http://lists.denx.de/pipermail/u-boot/2012-September/135156.html | 711 | # See http://lists.denx.de/pipermail/u-boot/2012-September/135156.html |
686 | checkgcc4: | 712 | checkgcc4: |
687 | @if test $(call cc-version) -lt 0400; then \ | 713 | @if test $(call cc-version) -lt 0400; then \ |
688 | echo -n '*** Your GCC is too old, please upgrade to GCC 4.x or newer'; \ | 714 | echo -n '*** Your GCC is too old, please upgrade to GCC 4.x or newer'; \ |
689 | false; \ | 715 | false; \ |
690 | fi | 716 | fi |
691 | 717 | ||
692 | checkdtc: | 718 | checkdtc: |
693 | @if test $(call dtc-version) -lt 0104; then \ | 719 | @if test $(call dtc-version) -lt 0104; then \ |
694 | echo '*** Your dtc is too old, please upgrade to dtc 1.4 or newer'; \ | 720 | echo '*** Your dtc is too old, please upgrade to dtc 1.4 or newer'; \ |
695 | false; \ | 721 | false; \ |
696 | fi | 722 | fi |
697 | 723 | ||
698 | # | 724 | # |
699 | # Auto-generate the autoconf.mk file (which is included by all makefiles) | 725 | # Auto-generate the autoconf.mk file (which is included by all makefiles) |
700 | # | 726 | # |
701 | # This target actually generates 2 files; autoconf.mk and autoconf.mk.dep. | 727 | # This target actually generates 2 files; autoconf.mk and autoconf.mk.dep. |
702 | # the dep file is only include in this top level makefile to determine when | 728 | # the dep file is only include in this top level makefile to determine when |
703 | # to regenerate the autoconf.mk file. | 729 | # to regenerate the autoconf.mk file. |
704 | $(obj)include/autoconf.mk.dep: $(obj)include/config.h include/common.h | 730 | $(obj)include/autoconf.mk.dep: $(obj)include/config.h include/common.h |
705 | @$(XECHO) Generating $@ ; \ | 731 | @$(XECHO) Generating $@ ; \ |
706 | set -e ; \ | 732 | set -e ; \ |
707 | : Generate the dependancies ; \ | 733 | : Generate the dependancies ; \ |
708 | $(CC) -x c -DDO_DEPS_ONLY -M $(CFLAGS) $(CPPFLAGS) \ | 734 | $(CC) -x c -DDO_DEPS_ONLY -M $(CFLAGS) $(CPPFLAGS) \ |
709 | -MQ $(obj)include/autoconf.mk include/common.h > $@ | 735 | -MQ $(obj)include/autoconf.mk include/common.h > $@ |
710 | 736 | ||
711 | $(obj)include/autoconf.mk: $(obj)include/config.h | 737 | $(obj)include/autoconf.mk: $(obj)include/config.h |
712 | @$(XECHO) Generating $@ ; \ | 738 | @$(XECHO) Generating $@ ; \ |
713 | set -e ; \ | 739 | set -e ; \ |
714 | : Extract the config macros ; \ | 740 | : Extract the config macros ; \ |
715 | $(CPP) $(CFLAGS) -DDO_DEPS_ONLY -dM include/common.h | \ | 741 | $(CPP) $(CFLAGS) -DDO_DEPS_ONLY -dM include/common.h | \ |
716 | sed -n -f tools/scripts/define2mk.sed > $@.tmp && \ | 742 | sed -n -f tools/scripts/define2mk.sed > $@.tmp && \ |
717 | mv $@.tmp $@ | 743 | mv $@.tmp $@ |
718 | 744 | ||
719 | # Auto-generate the spl-autoconf.mk file (which is included by all makefiles for SPL) | 745 | # Auto-generate the spl-autoconf.mk file (which is included by all makefiles for SPL) |
720 | $(obj)include/tpl-autoconf.mk: $(obj)include/config.h | 746 | $(obj)include/tpl-autoconf.mk: $(obj)include/config.h |
721 | @$(XECHO) Generating $@ ; \ | 747 | @$(XECHO) Generating $@ ; \ |
722 | set -e ; \ | 748 | set -e ; \ |
723 | : Extract the config macros ; \ | 749 | : Extract the config macros ; \ |
724 | $(CPP) $(CFLAGS) -DCONFIG_TPL_BUILD -DCONFIG_SPL_BUILD\ | 750 | $(CPP) $(CFLAGS) -DCONFIG_TPL_BUILD -DCONFIG_SPL_BUILD\ |
725 | -DDO_DEPS_ONLY -dM include/common.h | \ | 751 | -DDO_DEPS_ONLY -dM include/common.h | \ |
726 | sed -n -f tools/scripts/define2mk.sed > $@.tmp && \ | 752 | sed -n -f tools/scripts/define2mk.sed > $@.tmp && \ |
727 | mv $@.tmp $@ | 753 | mv $@.tmp $@ |
728 | 754 | ||
729 | $(obj)include/spl-autoconf.mk: $(obj)include/config.h | 755 | $(obj)include/spl-autoconf.mk: $(obj)include/config.h |
730 | @$(XECHO) Generating $@ ; \ | 756 | @$(XECHO) Generating $@ ; \ |
731 | set -e ; \ | 757 | set -e ; \ |
732 | : Extract the config macros ; \ | 758 | : Extract the config macros ; \ |
733 | $(CPP) $(CFLAGS) -DCONFIG_SPL_BUILD -DDO_DEPS_ONLY -dM include/common.h | \ | 759 | $(CPP) $(CFLAGS) -DCONFIG_SPL_BUILD -DDO_DEPS_ONLY -dM include/common.h | \ |
734 | sed -n -f tools/scripts/define2mk.sed > $@.tmp && \ | 760 | sed -n -f tools/scripts/define2mk.sed > $@.tmp && \ |
735 | mv $@.tmp $@ | 761 | mv $@.tmp $@ |
736 | 762 | ||
737 | $(obj)include/generated/generic-asm-offsets.h: $(obj)include/autoconf.mk.dep \ | 763 | $(obj)include/generated/generic-asm-offsets.h: $(obj)include/autoconf.mk.dep \ |
738 | $(obj)include/spl-autoconf.mk \ | 764 | $(obj)include/spl-autoconf.mk \ |
739 | $(obj)include/tpl-autoconf.mk \ | 765 | $(obj)include/tpl-autoconf.mk \ |
740 | $(obj)lib/asm-offsets.s | 766 | $(obj)lib/asm-offsets.s |
741 | @$(XECHO) Generating $@ | 767 | @$(XECHO) Generating $@ |
742 | tools/scripts/make-asm-offsets $(obj)lib/asm-offsets.s $@ | 768 | tools/scripts/make-asm-offsets $(obj)lib/asm-offsets.s $@ |
743 | 769 | ||
744 | $(obj)lib/asm-offsets.s: $(obj)include/autoconf.mk.dep \ | 770 | $(obj)lib/asm-offsets.s: $(obj)include/autoconf.mk.dep \ |
745 | $(obj)include/spl-autoconf.mk \ | 771 | $(obj)include/spl-autoconf.mk \ |
746 | $(obj)include/tpl-autoconf.mk \ | 772 | $(obj)include/tpl-autoconf.mk \ |
747 | $(src)lib/asm-offsets.c | 773 | $(src)lib/asm-offsets.c |
748 | @mkdir -p $(obj)lib | 774 | @mkdir -p $(obj)lib |
749 | $(CC) -DDO_DEPS_ONLY \ | 775 | $(CC) -DDO_DEPS_ONLY \ |
750 | $(CFLAGS) $(CFLAGS_$(BCURDIR)/$(@F)) $(CFLAGS_$(BCURDIR)) \ | 776 | $(CFLAGS) $(CFLAGS_$(BCURDIR)/$(@F)) $(CFLAGS_$(BCURDIR)) \ |
751 | -o $@ $(src)lib/asm-offsets.c -c -S | 777 | -o $@ $(src)lib/asm-offsets.c -c -S |
752 | 778 | ||
753 | $(obj)include/generated/asm-offsets.h: $(obj)include/autoconf.mk.dep \ | 779 | $(obj)include/generated/asm-offsets.h: $(obj)include/autoconf.mk.dep \ |
754 | $(obj)include/spl-autoconf.mk \ | 780 | $(obj)include/spl-autoconf.mk \ |
755 | $(obj)include/tpl-autoconf.mk \ | 781 | $(obj)include/tpl-autoconf.mk \ |
756 | $(obj)$(CPUDIR)/$(SOC)/asm-offsets.s | 782 | $(obj)$(CPUDIR)/$(SOC)/asm-offsets.s |
757 | @$(XECHO) Generating $@ | 783 | @$(XECHO) Generating $@ |
758 | tools/scripts/make-asm-offsets $(obj)$(CPUDIR)/$(SOC)/asm-offsets.s $@ | 784 | tools/scripts/make-asm-offsets $(obj)$(CPUDIR)/$(SOC)/asm-offsets.s $@ |
759 | 785 | ||
760 | $(obj)$(CPUDIR)/$(SOC)/asm-offsets.s: $(obj)include/autoconf.mk.dep \ | 786 | $(obj)$(CPUDIR)/$(SOC)/asm-offsets.s: $(obj)include/autoconf.mk.dep \ |
761 | $(obj)include/spl-autoconf.mk \ | 787 | $(obj)include/spl-autoconf.mk \ |
762 | $(obj)include/tpl-autoconf.mk | 788 | $(obj)include/tpl-autoconf.mk |
763 | @mkdir -p $(obj)$(CPUDIR)/$(SOC) | 789 | @mkdir -p $(obj)$(CPUDIR)/$(SOC) |
764 | if [ -f $(src)$(CPUDIR)/$(SOC)/asm-offsets.c ];then \ | 790 | if [ -f $(src)$(CPUDIR)/$(SOC)/asm-offsets.c ];then \ |
765 | $(CC) -DDO_DEPS_ONLY \ | 791 | $(CC) -DDO_DEPS_ONLY \ |
766 | $(CFLAGS) $(CFLAGS_$(BCURDIR)/$(@F)) $(CFLAGS_$(BCURDIR)) \ | 792 | $(CFLAGS) $(CFLAGS_$(BCURDIR)/$(@F)) $(CFLAGS_$(BCURDIR)) \ |
767 | -o $@ $(src)$(CPUDIR)/$(SOC)/asm-offsets.c -c -S; \ | 793 | -o $@ $(src)$(CPUDIR)/$(SOC)/asm-offsets.c -c -S; \ |
768 | else \ | 794 | else \ |
769 | touch $@; \ | 795 | touch $@; \ |
770 | fi | 796 | fi |
771 | 797 | ||
772 | ######################################################################### | 798 | ######################################################################### |
773 | else # !config.mk | 799 | else # !config.mk |
774 | all $(obj)u-boot.hex $(obj)u-boot.srec $(obj)u-boot.bin \ | 800 | all $(obj)u-boot.hex $(obj)u-boot.srec $(obj)u-boot.bin \ |
775 | $(obj)u-boot.img $(obj)u-boot.dis $(obj)u-boot \ | 801 | $(obj)u-boot.img $(obj)u-boot.dis $(obj)u-boot \ |
776 | $(filter-out tools,$(SUBDIRS)) \ | 802 | $(filter-out tools,$(SUBDIRS)) \ |
777 | updater depend dep tags ctags etags cscope $(obj)System.map: | 803 | updater depend dep tags ctags etags cscope $(obj)System.map: |
778 | @echo "System not configured - see README" >&2 | 804 | @echo "System not configured - see README" >&2 |
779 | @ exit 1 | 805 | @ exit 1 |
780 | 806 | ||
781 | tools: $(VERSION_FILE) $(TIMESTAMP_FILE) | 807 | tools: $(VERSION_FILE) $(TIMESTAMP_FILE) |
782 | $(MAKE) -C $@ all | 808 | $(MAKE) -C $@ all |
783 | endif # config.mk | 809 | endif # config.mk |
784 | 810 | ||
785 | # ARM relocations should all be R_ARM_RELATIVE. | 811 | # ARM relocations should all be R_ARM_RELATIVE. |
786 | checkarmreloc: $(obj)u-boot | 812 | checkarmreloc: $(obj)u-boot |
787 | @if test "R_ARM_RELATIVE" != \ | 813 | @if test "R_ARM_RELATIVE" != \ |
788 | "`$(CROSS_COMPILE)readelf -r $< | cut -d ' ' -f 4 | grep R_ARM | sort -u`"; \ | 814 | "`$(CROSS_COMPILE)readelf -r $< | cut -d ' ' -f 4 | grep R_ARM | sort -u`"; \ |
789 | then echo "$< contains relocations other than \ | 815 | then echo "$< contains relocations other than \ |
790 | R_ARM_RELATIVE"; false; fi | 816 | R_ARM_RELATIVE"; false; fi |
791 | 817 | ||
792 | $(VERSION_FILE): | 818 | $(VERSION_FILE): |
793 | @mkdir -p $(dir $(VERSION_FILE)) | 819 | @mkdir -p $(dir $(VERSION_FILE)) |
794 | @( localvers='$(shell $(TOPDIR)/tools/setlocalversion $(TOPDIR))' ; \ | 820 | @( localvers='$(shell $(TOPDIR)/tools/setlocalversion $(TOPDIR))' ; \ |
795 | printf '#define PLAIN_VERSION "%s%s"\n' \ | 821 | printf '#define PLAIN_VERSION "%s%s"\n' \ |
796 | "$(U_BOOT_VERSION)" "$${localvers}" ; \ | 822 | "$(U_BOOT_VERSION)" "$${localvers}" ; \ |
797 | printf '#define U_BOOT_VERSION "U-Boot %s%s"\n' \ | 823 | printf '#define U_BOOT_VERSION "U-Boot %s%s"\n' \ |
798 | "$(U_BOOT_VERSION)" "$${localvers}" ; \ | 824 | "$(U_BOOT_VERSION)" "$${localvers}" ; \ |
799 | ) > $@.tmp | 825 | ) > $@.tmp |
800 | @( printf '#define CC_VERSION_STRING "%s"\n' \ | 826 | @( printf '#define CC_VERSION_STRING "%s"\n' \ |
801 | '$(shell $(CC) --version | head -n 1)' )>> $@.tmp | 827 | '$(shell $(CC) --version | head -n 1)' )>> $@.tmp |
802 | @( printf '#define LD_VERSION_STRING "%s"\n' \ | 828 | @( printf '#define LD_VERSION_STRING "%s"\n' \ |
803 | '$(shell $(LD) -v | head -n 1)' )>> $@.tmp | 829 | '$(shell $(LD) -v | head -n 1)' )>> $@.tmp |
804 | @cmp -s $@ $@.tmp && rm -f $@.tmp || mv -f $@.tmp $@ | 830 | @cmp -s $@ $@.tmp && rm -f $@.tmp || mv -f $@.tmp $@ |
805 | 831 | ||
806 | $(TIMESTAMP_FILE): | 832 | $(TIMESTAMP_FILE): |
807 | @mkdir -p $(dir $(TIMESTAMP_FILE)) | 833 | @mkdir -p $(dir $(TIMESTAMP_FILE)) |
808 | @LC_ALL=C date +'#define U_BOOT_DATE "%b %d %C%y"' > $@.tmp | 834 | @LC_ALL=C date +'#define U_BOOT_DATE "%b %d %C%y"' > $@.tmp |
809 | @LC_ALL=C date +'#define U_BOOT_TIME "%T"' >> $@.tmp | 835 | @LC_ALL=C date +'#define U_BOOT_TIME "%T"' >> $@.tmp |
810 | @cmp -s $@ $@.tmp && rm -f $@.tmp || mv -f $@.tmp $@ | 836 | @cmp -s $@ $@.tmp && rm -f $@.tmp || mv -f $@.tmp $@ |
811 | 837 | ||
812 | easylogo env gdb: | 838 | easylogo env gdb: |
813 | $(MAKE) -C tools/$@ all MTD_VERSION=${MTD_VERSION} | 839 | $(MAKE) -C tools/$@ all MTD_VERSION=${MTD_VERSION} |
814 | gdbtools: gdb | 840 | gdbtools: gdb |
815 | 841 | ||
816 | xmldocs pdfdocs psdocs htmldocs mandocs: tools/kernel-doc/docproc | 842 | xmldocs pdfdocs psdocs htmldocs mandocs: tools/kernel-doc/docproc |
817 | $(MAKE) U_BOOT_VERSION=$(U_BOOT_VERSION) -C doc/DocBook/ $@ | 843 | $(MAKE) U_BOOT_VERSION=$(U_BOOT_VERSION) -C doc/DocBook/ $@ |
818 | 844 | ||
819 | tools-all: easylogo env gdb $(VERSION_FILE) $(TIMESTAMP_FILE) | 845 | tools-all: easylogo env gdb $(VERSION_FILE) $(TIMESTAMP_FILE) |
820 | $(MAKE) -C tools HOST_TOOLS_ALL=y | 846 | $(MAKE) -C tools HOST_TOOLS_ALL=y |
821 | 847 | ||
822 | .PHONY : CHANGELOG | 848 | .PHONY : CHANGELOG |
823 | CHANGELOG: | 849 | CHANGELOG: |
824 | git log --no-merges U-Boot-1_1_5.. | \ | 850 | git log --no-merges U-Boot-1_1_5.. | \ |
825 | unexpand -a | sed -e 's/\s\s*$$//' > $@ | 851 | unexpand -a | sed -e 's/\s\s*$$//' > $@ |
826 | 852 | ||
827 | include/license.h: tools/bin2header COPYING | 853 | include/license.h: tools/bin2header COPYING |
828 | cat COPYING | gzip -9 -c | ./tools/bin2header license_gzip > include/license.h | 854 | cat COPYING | gzip -9 -c | ./tools/bin2header license_gzip > include/license.h |
829 | ######################################################################### | 855 | ######################################################################### |
830 | 856 | ||
831 | unconfig: | 857 | unconfig: |
832 | @rm -f $(obj)include/config.h $(obj)include/config.mk \ | 858 | @rm -f $(obj)include/config.h $(obj)include/config.mk \ |
833 | $(obj)board/*/config.tmp $(obj)board/*/*/config.tmp \ | 859 | $(obj)board/*/config.tmp $(obj)board/*/*/config.tmp \ |
834 | $(obj)include/autoconf.mk $(obj)include/autoconf.mk.dep \ | 860 | $(obj)include/autoconf.mk $(obj)include/autoconf.mk.dep \ |
835 | $(obj)include/spl-autoconf.mk \ | 861 | $(obj)include/spl-autoconf.mk \ |
836 | $(obj)include/tpl-autoconf.mk | 862 | $(obj)include/tpl-autoconf.mk |
837 | 863 | ||
838 | %_config:: unconfig | 864 | %_config:: unconfig |
839 | @$(MKCONFIG) -A $(@:_config=) | 865 | @$(MKCONFIG) -A $(@:_config=) |
840 | 866 | ||
841 | sinclude $(obj).boards.depend | 867 | sinclude $(obj).boards.depend |
842 | $(obj).boards.depend: boards.cfg | 868 | $(obj).boards.depend: boards.cfg |
843 | @awk '(NF && $$1 !~ /^#/) { print $$7 ": " $$7 "_config; $$(MAKE)" }' $< > $@ | 869 | @awk '(NF && $$1 !~ /^#/) { print $$7 ": " $$7 "_config; $$(MAKE)" }' $< > $@ |
844 | 870 | ||
845 | # | 871 | # |
846 | # Functions to generate common board directory names | 872 | # Functions to generate common board directory names |
847 | # | 873 | # |
848 | lcname = $(shell echo $(1) | sed -e 's/\(.*\)_config/\L\1/') | 874 | lcname = $(shell echo $(1) | sed -e 's/\(.*\)_config/\L\1/') |
849 | ucname = $(shell echo $(1) | sed -e 's/\(.*\)_config/\U\1/') | 875 | ucname = $(shell echo $(1) | sed -e 's/\(.*\)_config/\U\1/') |
850 | 876 | ||
851 | ######################################################################### | 877 | ######################################################################### |
852 | ######################################################################### | 878 | ######################################################################### |
853 | 879 | ||
854 | clean: | 880 | clean: |
855 | @rm -f $(obj)examples/standalone/82559_eeprom \ | 881 | @rm -f $(obj)examples/standalone/82559_eeprom \ |
856 | $(obj)examples/standalone/atmel_df_pow2 \ | 882 | $(obj)examples/standalone/atmel_df_pow2 \ |
857 | $(obj)examples/standalone/eepro100_eeprom \ | 883 | $(obj)examples/standalone/eepro100_eeprom \ |
858 | $(obj)examples/standalone/hello_world \ | 884 | $(obj)examples/standalone/hello_world \ |
859 | $(obj)examples/standalone/interrupt \ | 885 | $(obj)examples/standalone/interrupt \ |
860 | $(obj)examples/standalone/mem_to_mem_idma2intr \ | 886 | $(obj)examples/standalone/mem_to_mem_idma2intr \ |
861 | $(obj)examples/standalone/sched \ | 887 | $(obj)examples/standalone/sched \ |
862 | $(obj)examples/standalone/smc911{11,x}_eeprom \ | 888 | $(obj)examples/standalone/smc911{11,x}_eeprom \ |
863 | $(obj)examples/standalone/test_burst \ | 889 | $(obj)examples/standalone/test_burst \ |
864 | $(obj)examples/standalone/timer | 890 | $(obj)examples/standalone/timer |
865 | @rm -f $(obj)examples/api/demo{,.bin} | 891 | @rm -f $(obj)examples/api/demo{,.bin} |
866 | @rm -f $(obj)tools/bmp_logo $(obj)tools/easylogo/easylogo \ | 892 | @rm -f $(obj)tools/bmp_logo $(obj)tools/easylogo/easylogo \ |
867 | $(obj)tools/env/{fw_printenv,fw_setenv} \ | 893 | $(obj)tools/env/{fw_printenv,fw_setenv} \ |
868 | $(obj)tools/envcrc \ | 894 | $(obj)tools/envcrc \ |
869 | $(obj)tools/gdb/{astest,gdbcont,gdbsend} \ | 895 | $(obj)tools/gdb/{astest,gdbcont,gdbsend} \ |
870 | $(obj)tools/gen_eth_addr $(obj)tools/img2srec \ | 896 | $(obj)tools/gen_eth_addr $(obj)tools/img2srec \ |
871 | $(obj)tools/mk{env,}image $(obj)tools/mpc86x_clk \ | 897 | $(obj)tools/mk{env,}image $(obj)tools/mpc86x_clk \ |
872 | $(obj)tools/mk{$(BOARD),}spl \ | 898 | $(obj)tools/mk{$(BOARD),}spl \ |
873 | $(obj)tools/mxsboot \ | 899 | $(obj)tools/mxsboot \ |
874 | $(obj)tools/ncb $(obj)tools/ubsha1 \ | 900 | $(obj)tools/ncb $(obj)tools/ubsha1 \ |
875 | $(obj)tools/kernel-doc/docproc \ | 901 | $(obj)tools/kernel-doc/docproc \ |
876 | $(obj)tools/proftool | 902 | $(obj)tools/proftool |
877 | @rm -f $(obj)board/cray/L1/{bootscript.c,bootscript.image} \ | 903 | @rm -f $(obj)board/cray/L1/{bootscript.c,bootscript.image} \ |
878 | $(obj)board/matrix_vision/*/bootscript.img \ | 904 | $(obj)board/matrix_vision/*/bootscript.img \ |
879 | $(obj)board/voiceblue/eeprom \ | 905 | $(obj)board/voiceblue/eeprom \ |
880 | $(obj)u-boot.lds \ | 906 | $(obj)u-boot.lds \ |
881 | $(obj)arch/blackfin/cpu/bootrom-asm-offsets.[chs] \ | 907 | $(obj)arch/blackfin/cpu/bootrom-asm-offsets.[chs] \ |
882 | $(obj)arch/blackfin/cpu/init.{lds,elf} | 908 | $(obj)arch/blackfin/cpu/init.{lds,elf} |
883 | @rm -f $(obj)include/bmp_logo.h | 909 | @rm -f $(obj)include/bmp_logo.h |
884 | @rm -f $(obj)include/bmp_logo_data.h | 910 | @rm -f $(obj)include/bmp_logo_data.h |
885 | @rm -f $(obj)lib/asm-offsets.s | 911 | @rm -f $(obj)lib/asm-offsets.s |
886 | @rm -f $(obj)include/generated/asm-offsets.h | 912 | @rm -f $(obj)include/generated/asm-offsets.h |
887 | @rm -f $(obj)$(CPUDIR)/$(SOC)/asm-offsets.s | 913 | @rm -f $(obj)$(CPUDIR)/$(SOC)/asm-offsets.s |
888 | @rm -f $(TIMESTAMP_FILE) $(VERSION_FILE) | 914 | @rm -f $(TIMESTAMP_FILE) $(VERSION_FILE) |
889 | @$(MAKE) -s -C doc/DocBook/ cleandocs | 915 | @$(MAKE) -s -C doc/DocBook/ cleandocs |
890 | @find $(OBJTREE) -type f \ | 916 | @find $(OBJTREE) -type f \ |
891 | \( -name 'core' -o -name '*.bak' -o -name '*~' -o -name '*.su' \ | 917 | \( -name 'core' -o -name '*.bak' -o -name '*~' -o -name '*.su' \ |
892 | -o -name '*.o' -o -name '*.a' -o -name '*.exe' \ | 918 | -o -name '*.o' -o -name '*.a' -o -name '*.exe' \ |
893 | -o -name '*.cfgtmp' \) -print \ | 919 | -o -name '*.cfgtmp' \) -print \ |
894 | | xargs rm -f | 920 | | xargs rm -f |
895 | 921 | ||
896 | # Removes everything not needed for testing u-boot | 922 | # Removes everything not needed for testing u-boot |
897 | tidy: clean | 923 | tidy: clean |
898 | @find $(OBJTREE) -type f \( -name '*.depend*' \) -print | xargs rm -f | 924 | @find $(OBJTREE) -type f \( -name '*.depend*' \) -print | xargs rm -f |
899 | 925 | ||
900 | clobber: tidy | 926 | clobber: tidy |
901 | @find $(OBJTREE) -type f \( -name '*.srec' \ | 927 | @find $(OBJTREE) -type f \( -name '*.srec' \ |
902 | -o -name '*.bin' -o -name u-boot.img \) \ | 928 | -o -name '*.bin' -o -name u-boot.img \) \ |
903 | -print0 | xargs -0 rm -f | 929 | -print0 | xargs -0 rm -f |
904 | @rm -f $(OBJS) $(obj)*.bak $(obj)ctags $(obj)etags $(obj)TAGS \ | 930 | @rm -f $(OBJS) $(obj)*.bak $(obj)ctags $(obj)etags $(obj)TAGS \ |
905 | $(obj)cscope.* $(obj)*.*~ | 931 | $(obj)cscope.* $(obj)*.*~ |
906 | @rm -f $(obj)u-boot $(obj)u-boot.map $(obj)u-boot.hex $(ALL-y) | 932 | @rm -f $(obj)u-boot $(obj)u-boot.map $(obj)u-boot.hex $(ALL-y) |
907 | @rm -f $(obj)u-boot.kwb | 933 | @rm -f $(obj)u-boot.kwb |
908 | @rm -f $(obj)u-boot.pbl | 934 | @rm -f $(obj)u-boot.pbl |
909 | @rm -f $(obj)u-boot.imx | 935 | @rm -f $(obj)u-boot.imx |
910 | @rm -f $(obj)u-boot-with-spl.imx | 936 | @rm -f $(obj)u-boot-with-spl.imx |
911 | @rm -f $(obj)u-boot-with-nand-spl.imx | 937 | @rm -f $(obj)u-boot-with-nand-spl.imx |
912 | @rm -f $(obj)u-boot.ubl | 938 | @rm -f $(obj)u-boot.ubl |
913 | @rm -f $(obj)u-boot.ais | 939 | @rm -f $(obj)u-boot.ais |
914 | @rm -f $(obj)u-boot.dtb | 940 | @rm -f $(obj)u-boot.dtb |
915 | @rm -f $(obj)u-boot.sb | 941 | @rm -f $(obj)u-boot.sb |
916 | @rm -f $(obj)u-boot.bd | 942 | @rm -f $(obj)u-boot.bd |
917 | @rm -f $(obj)u-boot.spr | 943 | @rm -f $(obj)u-boot.spr |
918 | @rm -f $(obj)nand_spl/{u-boot.{lds,lst},System.map} | 944 | @rm -f $(obj)nand_spl/{u-boot.{lds,lst},System.map} |
919 | @rm -f $(obj)nand_spl/{u-boot-nand_spl.lds,u-boot-spl,u-boot-spl.map} | 945 | @rm -f $(obj)nand_spl/{u-boot-nand_spl.lds,u-boot-spl,u-boot-spl.map} |
920 | @rm -f $(obj)spl/{u-boot-spl,u-boot-spl.bin,u-boot-spl.map} | 946 | @rm -f $(obj)spl/{u-boot-spl,u-boot-spl.bin,u-boot-spl.map} |
921 | @rm -f $(obj)spl/u-boot-spl.lds | 947 | @rm -f $(obj)spl/u-boot-spl.lds |
922 | @rm -f $(obj)tpl/{u-boot-tpl,u-boot-tpl.bin,u-boot-tpl.map} | 948 | @rm -f $(obj)tpl/{u-boot-tpl,u-boot-tpl.bin,u-boot-tpl.map} |
923 | @rm -f $(obj)tpl/u-boot-spl.lds | 949 | @rm -f $(obj)tpl/u-boot-spl.lds |
924 | @rm -f $(obj)MLO MLO.byteswap | 950 | @rm -f $(obj)MLO MLO.byteswap |
925 | @rm -f $(obj)SPL | 951 | @rm -f $(obj)SPL |
926 | @rm -f $(obj)tools/xway-swap-bytes | 952 | @rm -f $(obj)tools/xway-swap-bytes |
927 | @rm -f $(obj)arch/powerpc/cpu/mpc824x/bedbug_603e.c | 953 | @rm -f $(obj)arch/powerpc/cpu/mpc824x/bedbug_603e.c |
928 | @rm -f $(obj)arch/powerpc/cpu/mpc83xx/ddr-gen?.c | 954 | @rm -f $(obj)arch/powerpc/cpu/mpc83xx/ddr-gen?.c |
929 | @rm -fr $(obj)include/asm/proc $(obj)include/asm/arch $(obj)include/asm | 955 | @rm -fr $(obj)include/asm/proc $(obj)include/asm/arch $(obj)include/asm |
930 | @rm -fr $(obj)include/generated | 956 | @rm -fr $(obj)include/generated |
931 | @[ ! -d $(obj)nand_spl ] || find $(obj)nand_spl -name "*" -type l -print | xargs rm -f | 957 | @[ ! -d $(obj)nand_spl ] || find $(obj)nand_spl -name "*" -type l -print | xargs rm -f |
932 | @rm -f $(obj)dts/*.tmp | 958 | @rm -f $(obj)dts/*.tmp |
933 | @rm -f $(obj)spl/u-boot-spl{,-pad}.ais | 959 | @rm -f $(obj)spl/u-boot-spl{,-pad}.ais |
934 | 960 | ||
935 | mrproper \ | 961 | mrproper \ |
936 | distclean: clobber unconfig | 962 | distclean: clobber unconfig |
937 | ifneq ($(OBJTREE),$(SRCTREE)) | 963 | ifneq ($(OBJTREE),$(SRCTREE)) |
938 | rm -rf $(obj)* | 964 | rm -rf $(obj)* |
939 | endif | 965 | endif |
940 | 966 | ||
941 | backup: | 967 | backup: |
942 | F=`basename $(TOPDIR)` ; cd .. ; \ | 968 | F=`basename $(TOPDIR)` ; cd .. ; \ |
943 | gtar --force-local -zcvf `LC_ALL=C date "+$$F-%Y-%m-%d-%T.tar.gz"` $$F | 969 | gtar --force-local -zcvf `LC_ALL=C date "+$$F-%Y-%m-%d-%T.tar.gz"` $$F |
944 | 970 | ||
945 | ######################################################################### | 971 | ######################################################################### |
946 | 972 |
scripts/Makefile.build
File was created | 1 | # our default target | |
2 | .PHONY: all | ||
3 | all: | ||
4 | |||
5 | include $(TOPDIR)/config.mk | ||
6 | |||
7 | LIB := $(obj)built-in.o | ||
8 | LIBGCC = $(obj)libgcc.o | ||
9 | SRCS := | ||
10 | |||
11 | include Makefile | ||
12 | |||
13 | # Backward compatible: obj-y is preferable | ||
14 | COBJS := $(sort $(COBJS) $(COBJS-y)) | ||
15 | SOBJS := $(sort $(SOBJS) $(SOBJS-y)) | ||
16 | |||
17 | # Going forward use the following | ||
18 | obj-y := $(sort $(obj-y)) | ||
19 | extra-y := $(sort $(extra-y)) | ||
20 | lib-y := $(sort $(lib-y)) | ||
21 | |||
22 | SRCS += $(COBJS:.o=.c) $(SOBJS:.o=.S) \ | ||
23 | $(wildcard $(obj-y:.o=.c) $(obj-y:.o=.S) $(lib-y:.o=.c) $(lib-y:.o=.S) $(extra-y:.o=.c) $(extra-y:.o=.S)) | ||
24 | OBJS := $(addprefix $(obj),$(COBJS) $(SOBJS) $(obj-y)) | ||
25 | |||
26 | LGOBJS := $(addprefix $(obj),$(sort $(GLSOBJS) $(GLCOBJS)) $(lib-y)) | ||
27 | |||
28 | all: $(LIB) $(addprefix $(obj),$(extra-y)) | ||
29 | |||
30 | $(LIB): $(obj).depend $(OBJS) | ||
31 | $(call cmd_link_o_target, $(OBJS)) | ||
32 | |||
33 | ifneq ($(strip $(lib-y)),) | ||
34 | all: $(LIBGCC) | ||
35 | |||
36 | $(LIBGCC): $(obj).depend $(LGOBJS) | ||
37 | $(call cmd_link_o_target, $(LGOBJS)) | ||
38 | endif | ||
39 | |||
40 | ######################################################################### | ||
41 | |||
42 | # defines $(obj).depend target | ||
43 | |||
44 | include $(TOPDIR)/rules.mk | ||
45 | |||
46 | sinclude $(obj).depend | ||
47 | |||
48 | ######################################################################### | ||
49 |
spl/Makefile
1 | # | 1 | # |
2 | # (C) Copyright 2000-2011 | 2 | # (C) Copyright 2000-2011 |
3 | # Wolfgang Denk, DENX Software Engineering, wd@denx.de. | 3 | # Wolfgang Denk, DENX Software Engineering, wd@denx.de. |
4 | # | 4 | # |
5 | # (C) Copyright 2011 | 5 | # (C) Copyright 2011 |
6 | # Daniel Schwierzeck, daniel.schwierzeck@googlemail.com. | 6 | # Daniel Schwierzeck, daniel.schwierzeck@googlemail.com. |
7 | # | 7 | # |
8 | # (C) Copyright 2011 | 8 | # (C) Copyright 2011 |
9 | # Texas Instruments Incorporated - http://www.ti.com/ | 9 | # Texas Instruments Incorporated - http://www.ti.com/ |
10 | # Aneesh V <aneesh@ti.com> | 10 | # Aneesh V <aneesh@ti.com> |
11 | # | 11 | # |
12 | # SPDX-License-Identifier: GPL-2.0+ | 12 | # SPDX-License-Identifier: GPL-2.0+ |
13 | # | 13 | # |
14 | # Based on top-level Makefile. | 14 | # Based on top-level Makefile. |
15 | # | 15 | # |
16 | 16 | ||
17 | CONFIG_SPL_BUILD := y | 17 | CONFIG_SPL_BUILD := y |
18 | export CONFIG_SPL_BUILD | 18 | export CONFIG_SPL_BUILD |
19 | 19 | ||
20 | ifeq ($(CONFIG_TPL_BUILD),y) | 20 | ifeq ($(CONFIG_TPL_BUILD),y) |
21 | export CONFIG_TPL_BUILD | 21 | export CONFIG_TPL_BUILD |
22 | SPL_BIN := u-boot-tpl | 22 | SPL_BIN := u-boot-tpl |
23 | else | 23 | else |
24 | SPL_BIN := u-boot-spl | 24 | SPL_BIN := u-boot-spl |
25 | endif | 25 | endif |
26 | 26 | ||
27 | include $(TOPDIR)/config.mk | 27 | include $(TOPDIR)/config.mk |
28 | 28 | ||
29 | # We want the final binaries in this directory | 29 | # We want the final binaries in this directory |
30 | ifeq ($(CONFIG_TPL_BUILD),y) | 30 | ifeq ($(CONFIG_TPL_BUILD),y) |
31 | obj := $(OBJTREE)/tpl/ | 31 | obj := $(OBJTREE)/tpl/ |
32 | SPLTREE := $(TPLTREE) | 32 | SPLTREE := $(TPLTREE) |
33 | else | 33 | else |
34 | obj := $(OBJTREE)/spl/ | 34 | obj := $(OBJTREE)/spl/ |
35 | endif | 35 | endif |
36 | 36 | ||
37 | HAVE_VENDOR_COMMON_LIB = $(if $(wildcard $(SRCTREE)/board/$(VENDOR)/common/Makefile),y,n) | 37 | HAVE_VENDOR_COMMON_LIB = $(if $(wildcard $(SRCTREE)/board/$(VENDOR)/common/Makefile),y,n) |
38 | 38 | ||
39 | ifdef CONFIG_SPL_START_S_PATH | 39 | ifdef CONFIG_SPL_START_S_PATH |
40 | START_PATH := $(subst ",,$(CONFIG_SPL_START_S_PATH)) | 40 | START_PATH := $(subst ",,$(CONFIG_SPL_START_S_PATH)) |
41 | else | 41 | else |
42 | START_PATH := $(CPUDIR) | 42 | START_PATH := $(CPUDIR) |
43 | endif | 43 | endif |
44 | 44 | ||
45 | START := $(START_PATH)/start.o | 45 | START := $(START_PATH)/start.o |
46 | ifeq ($(CPU),x86) | 46 | ifeq ($(CPU),x86) |
47 | START += $(START_PATH)/start16.o | 47 | START += $(START_PATH)/start16.o |
48 | START += $(START_PATH)/resetvec.o | 48 | START += $(START_PATH)/resetvec.o |
49 | endif | 49 | endif |
50 | ifeq ($(CPU),ppc4xx) | 50 | ifeq ($(CPU),ppc4xx) |
51 | START += $(START_PATH)/resetvec.o | 51 | START += $(START_PATH)/resetvec.o |
52 | endif | 52 | endif |
53 | ifeq ($(CPU),mpc85xx) | 53 | ifeq ($(CPU),mpc85xx) |
54 | START += $(START_PATH)/resetvec.o | 54 | START += $(START_PATH)/resetvec.o |
55 | endif | 55 | endif |
56 | 56 | ||
57 | LIBS-y += arch/$(ARCH)/lib/lib$(ARCH).o | 57 | LIBS-y += arch/$(ARCH)/lib/lib$(ARCH).o |
58 | 58 | ||
59 | LIBS-y += $(CPUDIR)/lib$(CPU).o | 59 | LIBS-y += $(CPUDIR)/lib$(CPU).o |
60 | ifeq ($(CPU),mpc83xx) | 60 | ifeq ($(CPU),mpc83xx) |
61 | LIBS-y += arch/powerpc/cpu/mpc8xxx/lib8xxx.o | 61 | LIBS-y += arch/powerpc/cpu/mpc8xxx/lib8xxx.o |
62 | endif | 62 | endif |
63 | ifeq ($(CPU),mpc85xx) | 63 | ifeq ($(CPU),mpc85xx) |
64 | LIBS-y += arch/powerpc/cpu/mpc8xxx/lib8xxx.o | 64 | LIBS-y += arch/powerpc/cpu/mpc8xxx/lib8xxx.o |
65 | ifdef CONFIG_SPL_MPC8XXX_INIT_DDR_SUPPORT | 65 | ifdef CONFIG_SPL_MPC8XXX_INIT_DDR_SUPPORT |
66 | LIBS-y += arch/powerpc/cpu/mpc8xxx/ddr/libddr.o | 66 | LIBS-y += arch/powerpc/cpu/mpc8xxx/ddr/libddr.o |
67 | endif | 67 | endif |
68 | endif | 68 | endif |
69 | ifeq ($(CPU),mpc86xx) | 69 | ifeq ($(CPU),mpc86xx) |
70 | LIBS-y += arch/powerpc/cpu/mpc8xxx/lib8xxx.o | 70 | LIBS-y += arch/powerpc/cpu/mpc8xxx/lib8xxx.o |
71 | endif | 71 | endif |
72 | 72 | ||
73 | ifdef SOC | 73 | ifdef SOC |
74 | LIBS-y += $(CPUDIR)/$(SOC)/lib$(SOC).o | 74 | LIBS-y += $(CPUDIR)/$(SOC)/lib$(SOC).o |
75 | endif | 75 | endif |
76 | LIBS-y += board/$(BOARDDIR)/lib$(BOARD).o | 76 | LIBS-y += board/$(BOARDDIR)/lib$(BOARD).o |
77 | LIBS-$(HAVE_VENDOR_COMMON_LIB) += board/$(VENDOR)/common/lib$(VENDOR).o | 77 | LIBS-$(HAVE_VENDOR_COMMON_LIB) += board/$(VENDOR)/common/lib$(VENDOR).o |
78 | 78 | ||
79 | LIBS-$(CONFIG_SPL_FRAMEWORK) += common/spl/libspl.o | 79 | LIBS-$(CONFIG_SPL_FRAMEWORK) += common/spl/libspl.o |
80 | LIBS-$(CONFIG_SPL_LIBCOMMON_SUPPORT) += common/libcommon.o | 80 | LIBS-$(CONFIG_SPL_LIBCOMMON_SUPPORT) += common/libcommon.o |
81 | LIBS-$(CONFIG_SPL_LIBDISK_SUPPORT) += disk/libdisk.o | 81 | LIBS-$(CONFIG_SPL_LIBDISK_SUPPORT) += disk/libdisk.o |
82 | LIBS-$(CONFIG_SPL_I2C_SUPPORT) += drivers/i2c/libi2c.o | 82 | LIBS-$(CONFIG_SPL_I2C_SUPPORT) += drivers/i2c/libi2c.o |
83 | LIBS-$(CONFIG_SPL_GPIO_SUPPORT) += drivers/gpio/libgpio.o | 83 | LIBS-$(CONFIG_SPL_GPIO_SUPPORT) += drivers/gpio/libgpio.o |
84 | LIBS-$(CONFIG_SPL_MMC_SUPPORT) += drivers/mmc/libmmc.o | 84 | LIBS-$(CONFIG_SPL_MMC_SUPPORT) += drivers/mmc/libmmc.o |
85 | LIBS-$(CONFIG_SPL_SERIAL_SUPPORT) += drivers/serial/libserial.o | 85 | LIBS-$(CONFIG_SPL_SERIAL_SUPPORT) += drivers/serial/libserial.o |
86 | LIBS-$(CONFIG_SPL_SPI_FLASH_SUPPORT) += drivers/mtd/spi/libspi_flash.o | 86 | LIBS-$(CONFIG_SPL_SPI_FLASH_SUPPORT) += drivers/mtd/spi/libspi_flash.o |
87 | LIBS-$(CONFIG_SPL_SPI_SUPPORT) += drivers/spi/libspi.o | 87 | LIBS-$(CONFIG_SPL_SPI_SUPPORT) += drivers/spi/libspi.o |
88 | LIBS-$(CONFIG_SPL_FAT_SUPPORT) += fs/fat/libfat.o | 88 | LIBS-$(CONFIG_SPL_FAT_SUPPORT) += fs/fat/libfat.o |
89 | LIBS-$(CONFIG_SPL_LIBGENERIC_SUPPORT) += lib/libgeneric.o | 89 | LIBS-$(CONFIG_SPL_LIBGENERIC_SUPPORT) += lib/libgeneric.o |
90 | LIBS-$(CONFIG_SPL_POWER_SUPPORT) += drivers/power/libpower.o \ | 90 | LIBS-$(CONFIG_SPL_POWER_SUPPORT) += drivers/power/libpower.o \ |
91 | drivers/power/pmic/libpmic.o | 91 | drivers/power/pmic/libpmic.o |
92 | LIBS-$(CONFIG_SPL_NAND_SUPPORT) += drivers/mtd/nand/libnand.o | 92 | LIBS-$(CONFIG_SPL_NAND_SUPPORT) += drivers/mtd/nand/libnand.o |
93 | LIBS-$(CONFIG_SPL_ONENAND_SUPPORT) += drivers/mtd/onenand/libonenand.o | 93 | LIBS-$(CONFIG_SPL_ONENAND_SUPPORT) += drivers/mtd/onenand/libonenand.o |
94 | LIBS-$(CONFIG_SPL_DMA_SUPPORT) += drivers/dma/libdma.o | 94 | LIBS-$(CONFIG_SPL_DMA_SUPPORT) += drivers/dma/libdma.o |
95 | LIBS-$(CONFIG_SPL_POST_MEM_SUPPORT) += post/drivers/memory.o | 95 | LIBS-$(CONFIG_SPL_POST_MEM_SUPPORT) += post/drivers/memory.o |
96 | LIBS-$(CONFIG_SPL_NET_SUPPORT) += net/libnet.o | 96 | LIBS-$(CONFIG_SPL_NET_SUPPORT) += net/libnet.o |
97 | LIBS-$(CONFIG_SPL_ETH_SUPPORT) += drivers/net/libnet.o | 97 | LIBS-$(CONFIG_SPL_ETH_SUPPORT) += drivers/net/libnet.o |
98 | LIBS-$(CONFIG_SPL_ETH_SUPPORT) += drivers/net/phy/libphy.o | 98 | LIBS-$(CONFIG_SPL_ETH_SUPPORT) += drivers/net/phy/libphy.o |
99 | LIBS-$(CONFIG_SPL_USBETH_SUPPORT) += drivers/net/phy/libphy.o | 99 | LIBS-$(CONFIG_SPL_USBETH_SUPPORT) += drivers/net/phy/libphy.o |
100 | LIBS-$(CONFIG_SPL_MUSB_NEW_SUPPORT) += drivers/usb/musb-new/libusb_musb-new.o | 100 | LIBS-$(CONFIG_SPL_MUSB_NEW_SUPPORT) += drivers/usb/musb-new/libusb_musb-new.o |
101 | LIBS-$(CONFIG_SPL_USBETH_SUPPORT) += drivers/usb/gadget/libusb_gadget.o | 101 | LIBS-$(CONFIG_SPL_USBETH_SUPPORT) += drivers/usb/gadget/libusb_gadget.o |
102 | LIBS-$(CONFIG_SPL_WATCHDOG_SUPPORT) += drivers/watchdog/libwatchdog.o | 102 | LIBS-$(CONFIG_SPL_WATCHDOG_SUPPORT) += drivers/watchdog/libwatchdog.o |
103 | 103 | ||
104 | ifneq ($(CONFIG_OMAP_COMMON),) | 104 | ifneq ($(CONFIG_OMAP_COMMON),) |
105 | LIBS-y += $(CPUDIR)/omap-common/libomap-common.o | 105 | LIBS-y += $(CPUDIR)/omap-common/libomap-common.o |
106 | endif | 106 | endif |
107 | 107 | ||
108 | ifneq (,$(CONFIG_MX23)$(filter $(SOC), mx25 mx27 mx5 mx6 mx31 mx35)) | 108 | ifneq (,$(CONFIG_MX23)$(filter $(SOC), mx25 mx27 mx5 mx6 mx31 mx35)) |
109 | LIBS-y += arch/$(ARCH)/imx-common/libimx-common.o | 109 | LIBS-y += arch/$(ARCH)/imx-common/libimx-common.o |
110 | endif | 110 | endif |
111 | 111 | ||
112 | ifneq ($(CONFIG_TEGRA),) | 112 | ifneq ($(CONFIG_TEGRA),) |
113 | LIBS-y += arch/$(ARCH)/cpu/$(SOC)-common/lib$(SOC)-common.o | 113 | LIBS-y += arch/$(ARCH)/cpu/$(SOC)-common/lib$(SOC)-common.o |
114 | LIBS-y += arch/$(ARCH)/cpu/tegra-common/libcputegra-common.o | 114 | LIBS-y += arch/$(ARCH)/cpu/tegra-common/libcputegra-common.o |
115 | LIBS-y += $(CPUDIR)/tegra-common/libtegra-common.o | 115 | LIBS-y += $(CPUDIR)/tegra-common/libtegra-common.o |
116 | endif | 116 | endif |
117 | 117 | ||
118 | ifneq ($(CONFIG_MX23)$(CONFIG_MX35),) | 118 | ifneq ($(CONFIG_MX23)$(CONFIG_MX35),) |
119 | LIBS-y += arch/$(ARCH)/imx-common/libimx-common.o | 119 | LIBS-y += arch/$(ARCH)/imx-common/libimx-common.o |
120 | endif | 120 | endif |
121 | 121 | ||
122 | ifeq ($(SOC),exynos) | 122 | ifeq ($(SOC),exynos) |
123 | LIBS-y += $(CPUDIR)/s5p-common/libs5p-common.o | 123 | LIBS-y += $(CPUDIR)/s5p-common/libs5p-common.o |
124 | endif | 124 | endif |
125 | 125 | ||
126 | # Add GCC lib | 126 | # Add GCC lib |
127 | ifeq ("$(USE_PRIVATE_LIBGCC)", "yes") | 127 | ifeq ("$(USE_PRIVATE_LIBGCC)", "yes") |
128 | PLATFORM_LIBGCC = $(SPLTREE)/arch/$(ARCH)/lib/libgcc.o | 128 | PLATFORM_LIBGCC = $(SPLTREE)/arch/$(ARCH)/lib/libgcc.o |
129 | PLATFORM_LIBS := $(filter-out %/libgcc.o, $(filter-out -lgcc, $(PLATFORM_LIBS))) $(PLATFORM_LIBGCC) | 129 | PLATFORM_LIBS := $(filter-out %/libgcc.o, $(filter-out -lgcc, $(PLATFORM_LIBS))) $(PLATFORM_LIBGCC) |
130 | endif | 130 | endif |
131 | 131 | ||
132 | START := $(addprefix $(SPLTREE)/,$(START)) | 132 | START := $(addprefix $(SPLTREE)/,$(START)) |
133 | LIBS := $(addprefix $(SPLTREE)/,$(sort $(LIBS-y))) | 133 | LIBS := $(addprefix $(SPLTREE)/,$(sort $(LIBS-y))) |
134 | 134 | ||
135 | __START := $(subst $(obj),,$(START)) | 135 | __START := $(subst $(obj),,$(START)) |
136 | __LIBS := $(subst $(obj),,$(LIBS)) | 136 | __LIBS := $(subst $(obj),,$(LIBS)) |
137 | 137 | ||
138 | # Linker Script | 138 | # Linker Script |
139 | ifdef CONFIG_SPL_LDSCRIPT | 139 | ifdef CONFIG_SPL_LDSCRIPT |
140 | # need to strip off double quotes | 140 | # need to strip off double quotes |
141 | LDSCRIPT := $(addprefix $(SRCTREE)/,$(subst ",,$(CONFIG_SPL_LDSCRIPT))) | 141 | LDSCRIPT := $(addprefix $(SRCTREE)/,$(subst ",,$(CONFIG_SPL_LDSCRIPT))) |
142 | endif | 142 | endif |
143 | 143 | ||
144 | ifeq ($(wildcard $(LDSCRIPT)),) | 144 | ifeq ($(wildcard $(LDSCRIPT)),) |
145 | LDSCRIPT := $(TOPDIR)/board/$(BOARDDIR)/u-boot-spl.lds | 145 | LDSCRIPT := $(TOPDIR)/board/$(BOARDDIR)/u-boot-spl.lds |
146 | endif | 146 | endif |
147 | ifeq ($(wildcard $(LDSCRIPT)),) | 147 | ifeq ($(wildcard $(LDSCRIPT)),) |
148 | LDSCRIPT := $(TOPDIR)/$(CPUDIR)/u-boot-spl.lds | 148 | LDSCRIPT := $(TOPDIR)/$(CPUDIR)/u-boot-spl.lds |
149 | endif | 149 | endif |
150 | ifeq ($(wildcard $(LDSCRIPT)),) | 150 | ifeq ($(wildcard $(LDSCRIPT)),) |
151 | LDSCRIPT := $(TOPDIR)/arch/$(ARCH)/cpu/u-boot-spl.lds | 151 | LDSCRIPT := $(TOPDIR)/arch/$(ARCH)/cpu/u-boot-spl.lds |
152 | endif | 152 | endif |
153 | ifeq ($(wildcard $(LDSCRIPT)),) | 153 | ifeq ($(wildcard $(LDSCRIPT)),) |
154 | $(error could not find linker script) | 154 | $(error could not find linker script) |
155 | endif | 155 | endif |
156 | 156 | ||
157 | # Special flags for CPP when processing the linker script. | 157 | # Special flags for CPP when processing the linker script. |
158 | # Pass the version down so we can handle backwards compatibility | 158 | # Pass the version down so we can handle backwards compatibility |
159 | # on the fly. | 159 | # on the fly. |
160 | LDPPFLAGS += \ | 160 | LDPPFLAGS += \ |
161 | -include $(TOPDIR)/include/u-boot/u-boot.lds.h \ | 161 | -include $(TOPDIR)/include/u-boot/u-boot.lds.h \ |
162 | -include $(OBJTREE)/include/config.h \ | 162 | -include $(OBJTREE)/include/config.h \ |
163 | -DCPUDIR=$(CPUDIR) \ | 163 | -DCPUDIR=$(CPUDIR) \ |
164 | $(shell $(LD) --version | \ | 164 | $(shell $(LD) --version | \ |
165 | sed -ne 's/GNU ld version \([0-9][0-9]*\)\.\([0-9][0-9]*\).*/-DLD_MAJOR=\1 -DLD_MINOR=\2/p') | 165 | sed -ne 's/GNU ld version \([0-9][0-9]*\)\.\([0-9][0-9]*\).*/-DLD_MAJOR=\1 -DLD_MINOR=\2/p') |
166 | 166 | ||
167 | $(OBJTREE)/MLO: $(obj)u-boot-spl.bin | 167 | $(OBJTREE)/MLO: $(obj)u-boot-spl.bin |
168 | $(OBJTREE)/tools/mkimage -T omapimage \ | 168 | $(OBJTREE)/tools/mkimage -T omapimage \ |
169 | -a $(CONFIG_SPL_TEXT_BASE) -d $< $@ | 169 | -a $(CONFIG_SPL_TEXT_BASE) -d $< $@ |
170 | 170 | ||
171 | $(OBJTREE)/MLO.byteswap: $(obj)u-boot-spl.bin | 171 | $(OBJTREE)/MLO.byteswap: $(obj)u-boot-spl.bin |
172 | $(OBJTREE)/tools/mkimage -T omapimage -n byteswap \ | 172 | $(OBJTREE)/tools/mkimage -T omapimage -n byteswap \ |
173 | -a $(CONFIG_SPL_TEXT_BASE) -d $< $@ | 173 | -a $(CONFIG_SPL_TEXT_BASE) -d $< $@ |
174 | 174 | ||
175 | $(OBJTREE)/SPL : $(obj)u-boot-spl.bin depend | 175 | $(OBJTREE)/SPL : $(obj)u-boot-spl.bin depend |
176 | $(MAKE) -C $(SRCTREE)/arch/arm/imx-common $@ | 176 | $(MAKE) -C $(SRCTREE)/arch/arm/imx-common $@ |
177 | 177 | ||
178 | ALL-y += $(obj)$(SPL_BIN).bin | 178 | ALL-y += $(obj)$(SPL_BIN).bin |
179 | 179 | ||
180 | ifdef CONFIG_SAMSUNG | 180 | ifdef CONFIG_SAMSUNG |
181 | ALL-y += $(obj)$(BOARD)-spl.bin | 181 | ALL-y += $(obj)$(BOARD)-spl.bin |
182 | endif | 182 | endif |
183 | 183 | ||
184 | all: $(ALL-y) | 184 | all: $(ALL-y) |
185 | 185 | ||
186 | ifdef CONFIG_SAMSUNG | 186 | ifdef CONFIG_SAMSUNG |
187 | $(obj)$(BOARD)-spl.bin: $(obj)u-boot-spl.bin | 187 | $(obj)$(BOARD)-spl.bin: $(obj)u-boot-spl.bin |
188 | $(OBJTREE)/tools/mk$(BOARD)spl \ | 188 | $(OBJTREE)/tools/mk$(BOARD)spl \ |
189 | $(obj)u-boot-spl.bin $(obj)$(BOARD)-spl.bin | 189 | $(obj)u-boot-spl.bin $(obj)$(BOARD)-spl.bin |
190 | endif | 190 | endif |
191 | 191 | ||
192 | $(obj)$(SPL_BIN).bin: $(obj)$(SPL_BIN) | 192 | $(obj)$(SPL_BIN).bin: $(obj)$(SPL_BIN) |
193 | $(OBJCOPY) $(OBJCFLAGS) -O binary $< $@ | 193 | $(OBJCOPY) $(OBJCFLAGS) -O binary $< $@ |
194 | 194 | ||
195 | GEN_UBOOT = \ | 195 | GEN_UBOOT = \ |
196 | cd $(obj) && $(LD) $(LDFLAGS) $(LDFLAGS_$(@F)) $(__START) \ | 196 | cd $(obj) && $(LD) $(LDFLAGS) $(LDFLAGS_$(@F)) $(__START) \ |
197 | --start-group $(__LIBS) --end-group $(PLATFORM_LIBS) \ | 197 | --start-group $(__LIBS) --end-group $(PLATFORM_LIBS) \ |
198 | -Map $(SPL_BIN).map -o $(SPL_BIN) | 198 | -Map $(SPL_BIN).map -o $(SPL_BIN) |
199 | 199 | ||
200 | $(obj)$(SPL_BIN): depend $(START) $(LIBS) $(obj)u-boot-spl.lds | 200 | $(obj)$(SPL_BIN): depend $(START) $(LIBS) $(obj)u-boot-spl.lds |
201 | $(GEN_UBOOT) | 201 | $(GEN_UBOOT) |
202 | 202 | ||
203 | # Tentative step for Kbuild-style makefiles coexist with conventional U-Boot style makefiles | ||
204 | # U-Boot conventional sub makefiles always include some other makefiles. | ||
205 | # So, the build system searches a line beginning with "include" before entering into the sub makefile | ||
206 | # in order to distinguish which style it is. | ||
207 | # If the Makefile include a "include" line, we assume it is an U-Boot style makefile. | ||
208 | # Otherwise, it is treated as a Kbuild-style makefile. | ||
209 | select_makefile = \ | ||
210 | if grep -q "^include" $1/Makefile; then \ | ||
211 | $(MAKE) -C $1; \ | ||
212 | else \ | ||
213 | $(MAKE) -C $1 -f $(TOPDIR)/scripts/Makefile.build; \ | ||
214 | mv $(dir $@)built-in.o $@; \ | ||
215 | fi | ||
216 | |||
217 | # We do not need to build $(START) explicitly. | ||
218 | # It is built while we are at $(CPUDIR)/lib$(CPU).o build. | ||
203 | $(START): depend | 219 | $(START): depend |
204 | $(MAKE) -C $(SRCTREE)/$(START_PATH) $@ | 220 | if grep -q "^include" $(SRCTREE)$(dir $(subst $(SPLTREE),,$@))Makefile; then \ |
221 | $(MAKE) -C $(SRCTREE)/$(START_PATH) $@; \ | ||
222 | fi | ||
205 | 223 | ||
206 | $(LIBS): depend | 224 | $(LIBS): depend |
207 | $(MAKE) -C $(SRCTREE)$(dir $(subst $(SPLTREE),,$@)) | 225 | +$(call select_makefile, $(SRCTREE)$(dir $(subst $(SPLTREE),,$@))) |
208 | 226 | ||
209 | $(obj)u-boot-spl.lds: $(LDSCRIPT) depend | 227 | $(obj)u-boot-spl.lds: $(LDSCRIPT) depend |
210 | $(CPP) $(CPPFLAGS) $(LDPPFLAGS) -I$(obj). -ansi -D__ASSEMBLY__ -P - < $< > $@ | 228 | $(CPP) $(CPPFLAGS) $(LDPPFLAGS) -I$(obj). -ansi -D__ASSEMBLY__ -P - < $< > $@ |
211 | 229 | ||
212 | depend: $(obj).depend | 230 | depend: $(obj).depend |
213 | .PHONY: depend | 231 | .PHONY: depend |
214 | 232 | ||
215 | # defines $(obj).depend target | 233 | # defines $(obj).depend target |
216 | include $(SRCTREE)/rules.mk | 234 | include $(SRCTREE)/rules.mk |
217 | 235 |