1 # Copyright 2014-2015 The Rust Project Developers. See the COPYRIGHT
2 # file at the top-level directory of this distribution and at
3 # http://rust-lang.org/COPYRIGHT.
5 # Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6 # http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7 # <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8 # option. This file may not be copied, modified, or distributed
9 # except according to those terms.
11 ######################################################################
12 # Version numbers and strings
13 ######################################################################
18 # An optional number to put after the label, e.g. '.2' -> '-beta.2'
19 # NB Make sure it starts with a dot to conform to semver pre-release
20 # versions (section 9)
21 CFG_PRERELEASE_VERSION
=.4
23 # Append a version-dependent hash to each library, so we can install different
24 # versions in the same place
25 CFG_FILENAME_EXTRA
=$(shell printf
'%s' $(CFG_RELEASE
) |
$(CFG_HASH_COMMAND
))
27 ifeq ($(CFG_RELEASE_CHANNEL
),stable
)
28 # This is the normal semver version string, e.g. "0.12.0", "0.12.0-nightly"
29 CFG_RELEASE
=$(CFG_RELEASE_NUM
)
30 # This is the string used in dist artifact file names, e.g. "0.12.0", "nightly"
31 CFG_PACKAGE_VERS
=$(CFG_RELEASE_NUM
)
32 CFG_DISABLE_UNSTABLE_FEATURES
=1
34 ifeq ($(CFG_RELEASE_CHANNEL
),beta
)
35 CFG_RELEASE
=$(CFG_RELEASE_NUM
)-beta
$(CFG_PRERELEASE_VERSION
)
36 # When building beta distributables just reuse the same "beta" name
37 # so when we upload we'll always override the previous beta. This
38 # doesn't actually impact the version reported by rustc - it's just
41 CFG_DISABLE_UNSTABLE_FEATURES
=1
43 ifeq ($(CFG_RELEASE_CHANNEL
),nightly
)
44 CFG_RELEASE
=$(CFG_RELEASE_NUM
)-nightly
45 # When building nightly distributables just reuse the same "nightly" name
46 # so when we upload we'll always override the previous nighly. This
47 # doesn't actually impact the version reported by rustc - it's just
49 CFG_PACKAGE_VERS
=nightly
51 ifeq ($(CFG_RELEASE_CHANNEL
),dev
)
52 CFG_RELEASE
=$(CFG_RELEASE_NUM
)-dev
53 CFG_PACKAGE_VERS
=$(CFG_RELEASE_NUM
)-dev
56 # The name of the package to use for creating tarballs, installers etc.
57 CFG_PACKAGE_NAME
=rustc-
$(CFG_PACKAGE_VERS
)
59 # The version string plus commit information - this is what rustc reports
60 CFG_VERSION
= $(CFG_RELEASE
)
61 CFG_GIT_DIR
:= $(CFG_SRC_DIR
).git
62 # since $(CFG_GIT) may contain spaces (especially on Windows),
63 # we need to escape them. (" " to r"\ ")
64 # Note that $(subst ...) ignores space after `subst`,
65 # so we use a hack: define $(SPACE) which contains space character.
69 ifneq ($(wildcard $(subst $(SPACE
),\
$(SPACE
),$(CFG_GIT_DIR
))),)
70 CFG_VER_DATE
= $(shell git
--git-dir
='$(CFG_GIT_DIR)' log
-1 --date
=short
--pretty
=format
:'%cd')
71 CFG_VER_HASH
= $(shell git
--git-dir
='$(CFG_GIT_DIR)' rev-parse HEAD
)
72 CFG_SHORT_VER_HASH
= $(shell git
--git-dir
='$(CFG_GIT_DIR)' rev-parse
--short
=9 HEAD
)
73 CFG_VERSION
+= ($(CFG_SHORT_VER_HASH
) $(CFG_VER_DATE
))
77 # Windows exe's need numeric versions - don't use anything but
78 # numbers and dots here
79 CFG_VERSION_WIN
= $(CFG_RELEASE_NUM
)
81 CFG_INFO
:= $(info cfg
: version
$(CFG_VERSION
))
83 ######################################################################
85 ######################################################################
87 MKFILE_DEPS
:= config.stamp
$(call rwildcard
,$(CFG_SRC_DIR
)mk
/,*)
88 MKFILES_FOR_TARBALL
:=$(MKFILE_DEPS
)
89 ifneq ($(NO_MKFILE_DEPS
),)
92 NON_BUILD_HOST
= $(filter-out $(CFG_BUILD
),$(CFG_HOST
))
93 NON_BUILD_TARGET
= $(filter-out $(CFG_BUILD
),$(CFG_TARGET
))
95 ifneq ($(MAKE_RESTARTS
),)
96 CFG_INFO
:= $(info cfg
: make restarts
: $(MAKE_RESTARTS
))
99 CFG_INFO
:= $(info cfg
: build triple
$(CFG_BUILD
))
100 CFG_INFO
:= $(info cfg
: host triples
$(CFG_HOST
))
101 CFG_INFO
:= $(info cfg
: target triples
$(CFG_TARGET
))
103 ifneq ($(wildcard $(NON_BUILD_HOST
)),)
104 CFG_INFO
:= $(info cfg
: non-build host triples
$(NON_BUILD_HOST
))
106 ifneq ($(wildcard $(NON_BUILD_TARGET
)),)
107 CFG_INFO
:= $(info cfg
: non-build target triples
$(NON_BUILD_TARGET
))
110 CFG_RUSTC_FLAGS
:= $(RUSTFLAGS
)
112 CFG_GCCISH_LINK_FLAGS
:=
114 CFG_JEMALLOC_FLAGS
:=
116 ifdef CFG_DISABLE_OPTIMIZE
117 $(info cfg
: disabling rustc optimization
(CFG_DISABLE_OPTIMIZE
))
119 CFG_JEMALLOC_FLAGS
+= --enable-debug
121 # The rtopt cfg turns off runtime sanity checks
122 CFG_RUSTC_FLAGS
+= -O
--cfg rtopt
125 CFG_JEMALLOC_FLAGS
+= $(JEMALLOC_FLAGS
)
127 ifdef CFG_ENABLE_DEBUG_ASSERTIONS
128 $(info cfg
: enabling debug assertions
(CFG_ENABLE_DEBUG_ASSERTIONS
))
129 CFG_RUSTC_FLAGS
+= -C debug-assertions
=on
132 ifdef CFG_ENABLE_DEBUGINFO
133 $(info cfg
: enabling debuginfo
(CFG_ENABLE_DEBUGINFO
))
134 # FIXME: Re-enable -g in stage0 after new snapshot
135 #CFG_RUSTC_FLAGS += -g
136 RUSTFLAGS_STAGE1
+= -g
137 RUSTFLAGS_STAGE2
+= -g
138 RUSTFLAGS_STAGE3
+= -g
142 CFG_RUSTC_FLAGS
+= --save-temps
145 CFG_RUSTC_FLAGS
+= -Z asm-comments
148 CFG_RUSTC_FLAGS
+= -Z time-passes
150 ifdef TIME_LLVM_PASSES
151 CFG_RUSTC_FLAGS
+= -Z time-llvm-passes
154 CFG_RUSTC_FLAGS
+= -Z trace
156 ifdef CFG_ENABLE_RPATH
157 CFG_RUSTC_FLAGS
+= -C rpath
160 # The executables crated during this compilation process have no need to include
161 # static copies of libstd and libextra. We also generate dynamic versions of all
162 # libraries, so in the interest of space, prefer dynamic linking throughout the
163 # compilation process.
165 # Note though that these flags are omitted for the *bins* in stage2+. This means
166 # that the snapshot will be generated with a statically linked rustc so we only
167 # have to worry about the distribution of one file (with its native dynamic
169 RUSTFLAGS_STAGE0
+= -C prefer-dynamic
-C no-stack-check
170 RUSTFLAGS_STAGE1
+= -C prefer-dynamic
171 RUST_LIB_FLAGS_ST2
+= -C prefer-dynamic
172 RUST_LIB_FLAGS_ST3
+= -C prefer-dynamic
174 # Landing pads require a lot of codegen. We can get through bootstrapping faster
175 # by not emitting them.
177 ifdef CFG_DISABLE_STAGE0_LANDING_PADS
178 RUSTFLAGS_STAGE0
+= -Z no-landing-pads
181 # platform-specific auto-configuration
182 include $(CFG_SRC_DIR
)mk
/platform.mk
184 # Run the stage1/2 compilers under valgrind
185 ifdef VALGRIND_COMPILE
186 CFG_VALGRIND_COMPILE
:= $(CFG_VALGRIND
)
188 CFG_VALGRIND_COMPILE
:=
192 ifndef CFG_DISABLE_VALGRIND_RPASS
193 $(info cfg
: enabling valgrind run-pass tests
(CFG_ENABLE_VALGRIND_RPASS
))
194 $(info cfg
: valgrind-rpass command set to
$(CFG_VALGRIND
))
195 CFG_VALGRIND_RPASS
:=$(CFG_VALGRIND
)
197 $(info cfg
: disabling valgrind run-pass tests
)
198 CFG_VALGRIND_RPASS
:=
202 ifdef CFG_ENABLE_VALGRIND
203 $(info cfg
: enabling valgrind
(CFG_ENABLE_VALGRIND
))
204 CFG_JEMALLOC_FLAGS
+= --enable-valgrind
209 ######################################################################
210 # Target-and-rule "utility variables"
211 ######################################################################
213 define DEF_FOR_TARGET
214 X_
$(1) := $(CFG_EXE_SUFFIX_
$(1))
215 ifndef CFG_LLVM_TARGET_
$(1)
216 CFG_LLVM_TARGET_
$(1) := $(1)
219 $(foreach target
,$(CFG_TARGET
), \
220 $(eval
$(call DEF_FOR_TARGET
,$(target
))))
222 # "Source" files we generate in builddir along the way.
225 # Delete the built-in rules.
234 ######################################################################
235 # Cleaning out old crates
236 ######################################################################
238 # $(1) is the path for directory to match against
239 # $(2) is the glob to use in the match
241 # Note that a common bug is to accidentally construct the glob denoted
242 # by $(2) with a space character prefix, which invalidates the
243 # construction $(1)$(2).
244 define CHECK_FOR_OLD_GLOB_MATCHES
245 $(Q
)MATCHES
="$(wildcard $(1))"; if
[ -n
"$$MATCHES" ] ; then echo
"warning: there are previous" \'$(notdir $(2))\' "libraries:" $$MATCHES; fi
248 # Same interface as above, but deletes rather than just listing the files.
250 define REMOVE_ALL_OLD_GLOB_MATCHES
251 $(Q
)MATCHES
="$(wildcard $(1))"; if
[ -n
"$$MATCHES" ] ; then echo
"warning: removing previous" \'$(notdir $(1))\' "libraries:" $$MATCHES; rm $$MATCHES ; fi
254 define REMOVE_ALL_OLD_GLOB_MATCHES
255 $(Q
)MATCHES
="$(wildcard $(1))"; if
[ -n
"$$MATCHES" ] ; then
rm $$MATCHES ; fi
259 # We use a different strategy for LIST_ALL_OLD_GLOB_MATCHES_EXCEPT
260 # than in the macros above because it needs the result of running the
261 # `ls` command after other rules in the command list have run; the
262 # macro-expander for $(wildcard ...) would deliver its results too
263 # soon. (This is in contrast to the macros above, which are meant to
264 # be run at the outset of a command list in a rule.)
266 define LIST_ALL_OLD_GLOB_MATCHES
267 @echo
"info: now are following matches for" '$(notdir $(1))' "libraries:"
268 @
( ls
$(1) 2>/dev
/null || true
)
271 define LIST_ALL_OLD_GLOB_MATCHES
275 ######################################################################
277 ######################################################################
279 LLVM_COMPONENTS
=x86 arm aarch64 mips powerpc ipo bitreader bitwriter linker asmparser mcjit \
280 interpreter instrumentation
282 # Only build these LLVM tools
283 LLVM_TOOLS
=bugpoint llc llvm-ar llvm-as llvm-dis llvm-mc opt llvm-extract
286 # The configure script defines these variables with the target triples
287 # separated by Z. This defines new ones with the expected format.
288 ifeq ($$(CFG_LLVM_ROOT
),)
289 CFG_LLVM_BUILD_DIR_
$(1):=$$(CFG_LLVM_BUILD_DIR_
$(subst -,_
,$(1)))
290 CFG_LLVM_INST_DIR_
$(1):=$$(CFG_LLVM_INST_DIR_
$(subst -,_
,$(1)))
292 CFG_LLVM_INST_DIR_
$(1):=$$(CFG_LLVM_ROOT
)
295 # Any rules that depend on LLVM should depend on LLVM_CONFIG
296 LLVM_CONFIG_
$(1):=$$(CFG_LLVM_INST_DIR_
$(1))/bin
/llvm-config
$$(X_
$(1))
297 LLVM_MC_
$(1):=$$(CFG_LLVM_INST_DIR_
$(1))/bin
/llvm-mc
$$(X_
$(1))
298 LLVM_AR_
$(1):=$$(CFG_LLVM_INST_DIR_
$(1))/bin
/llvm-ar
$$(X_
$(1))
299 LLVM_VERSION_
$(1)=$$(shell "$$(LLVM_CONFIG_$(1))" --version
)
300 LLVM_BINDIR_
$(1)=$$(shell "$$(LLVM_CONFIG_$(1))" --bindir)
301 LLVM_INCDIR_
$(1)=$$(shell "$$(LLVM_CONFIG_$(1))" --includedir)
302 LLVM_LIBDIR_
$(1)=$$(shell "$$(LLVM_CONFIG_$(1))" --libdir)
303 LLVM_LIBDIR_RUSTFLAGS_
$(1)=-L native
="$$(LLVM_LIBDIR_$(1))"
304 LLVM_LDFLAGS_
$(1)=$$(shell "$$(LLVM_CONFIG_$(1))" --ldflags)
305 ifeq ($$(findstring freebsd
,$(1)),freebsd
)
306 # On FreeBSD, it may search wrong headers (that are for pre-installed LLVM),
307 # so we replace -I with -iquote to ensure that it searches bundled LLVM first.
308 LLVM_CXXFLAGS_
$(1)=$$(subst -I
, -iquote
, $$(shell "$$(LLVM_CONFIG_$(1))" --cxxflags))
310 LLVM_CXXFLAGS_
$(1)=$$(shell "$$(LLVM_CONFIG_$(1))" --cxxflags)
312 LLVM_HOST_TRIPLE_
$(1)=$$(shell "$$(LLVM_CONFIG_$(1))" --host-target
)
314 LLVM_AS_
$(1)=$$(CFG_LLVM_INST_DIR_
$(1))/bin
/llvm-as
$$(X_
$(1))
315 LLC_
$(1)=$$(CFG_LLVM_INST_DIR_
$(1))/bin
/llc
$$(X_
$(1))
319 $(foreach host
,$(CFG_HOST
), \
320 $(eval
$(call DEF_LLVM_VARS
,$(host
))))
322 ######################################################################
323 # Exports for sub-utilities
324 ######################################################################
326 # Note that any variable that re-configure should pick up needs to be
330 export CFG_SRC_DIR_RELATIVE
339 export CFG_VERSION_WIN
341 export CFG_PACKAGE_NAME
343 export CFG_RELEASE_CHANNEL
347 export CFG_LIBDIR_RELATIVE
348 export CFG_DISABLE_INJECT_STD_VERSION
349 ifdef CFG_DISABLE_UNSTABLE_FEATURES
350 CFG_INFO
:= $(info cfg
: disabling unstable features
(CFG_DISABLE_UNSTABLE_FEATURES
))
351 # Turn on feature-staging
352 export CFG_DISABLE_UNSTABLE_FEATURES
353 # Subvert unstable feature lints to do the self-build
354 export RUSTC_BOOTSTRAP_KEY
:=$(CFG_BOOTSTRAP_KEY
)
356 export CFG_BOOTSTRAP_KEY
358 ######################################################################
359 # Per-stage targets and runner
360 ######################################################################
362 # Valid setting-strings are 'all', 'none', 'gdb', 'lldb'
363 # This 'function' will determine which debugger scripts to copy based on a
364 # target triple. See debuggers.mk for more information.
365 TRIPLE_TO_DEBUGGER_SCRIPT_SETTING
=\
366 $(if
$(findstring windows
,$(1)),none
,$(if
$(findstring darwin
,$(1)),lldb
,gdb
))
371 # $(1) is the stage number
372 # $(2) is the target triple
373 # $(3) is the host triple
375 # Destinations of artifacts for the host compiler
376 HROOT
$(1)_H_
$(3) = $(3)/stage
$(1)
377 HBIN
$(1)_H_
$(3) = $$(HROOT
$(1)_H_
$(3))/bin
379 ifeq ($$(CFG_WINDOWSY_
$(3)),1)
380 # On Windows we always store host runtime libraries in the 'bin' directory because
381 # there's no rpath. Target libraries go under $CFG_LIBDIR_RELATIVE (usually 'lib').
382 HLIB_RELATIVE
$(1)_H_
$(3) = bin
383 TROOT
$(1)_T_
$(2)_H_
$(3) = $$(HROOT
$(1)_H_
$(3))/$$(CFG_LIBDIR_RELATIVE
)/rustlib
/$(2)
384 # Remove the next 3 lines after a snapshot
386 RUSTFLAGS_STAGE0
+= -L
$$(TROOT
$(1)_T_
$(2)_H_
$(3))/lib
392 HLIB_RELATIVE
$(1)_H_
$(3) = lib
394 HLIB_RELATIVE
$(1)_H_
$(3) = $$(CFG_LIBDIR_RELATIVE
)
396 TROOT
$(1)_T_
$(2)_H_
$(3) = $$(HLIB
$(1)_H_
$(3))/rustlib
/$(2)
399 HLIB
$(1)_H_
$(3) = $$(HROOT
$(1)_H_
$(3))/$$(HLIB_RELATIVE
$(1)_H_
$(3))
401 # Destinations of artifacts for target architectures
402 TBIN
$(1)_T_
$(2)_H_
$(3) = $$(TROOT
$(1)_T_
$(2)_H_
$(3))/bin
403 TLIB
$(1)_T_
$(2)_H_
$(3) = $$(TROOT
$(1)_T_
$(2)_H_
$(3))/lib
405 # Preqrequisites for using the stageN compiler
407 HSREQ
$(1)_H_
$(3) = $$(HBIN
$(1)_H_
$(3))/rustc
$$(X_
$(3))
410 $$(HBIN
$(1)_H_
$(3))/rustc
$$(X_
$(3)) \
412 tmp
/install-debugger-scripts
$(1)_H_
$(3)-$$(call TRIPLE_TO_DEBUGGER_SCRIPT_SETTING
,$(3)).done
415 # Prerequisites for using the stageN compiler to build target artifacts
416 TSREQ
$(1)_T_
$(2)_H_
$(3) = \
417 $$(HSREQ
$(1)_H_
$(3)) \
418 $$(foreach obj
,$$(REQUIRED_OBJECTS_
$(2)),\
419 $$(TLIB
$(1)_T_
$(2)_H_
$(3))/$$(obj
))
421 # Prerequisites for a working stageN compiler and libraries, for a specific
423 SREQ
$(1)_T_
$(2)_H_
$(3) = \
424 $$(TSREQ
$(1)_T_
$(2)_H_
$(3)) \
425 $$(foreach dep
,$$(TARGET_CRATES
), \
426 $$(TLIB
$(1)_T_
$(2)_H_
$(3))/stamp.
$$(dep
)) \
427 tmp
/install-debugger-scripts
$(1)_T_
$(2)_H_
$(3)-$$(call TRIPLE_TO_DEBUGGER_SCRIPT_SETTING
,$(2)).done
429 # Prerequisites for a working stageN compiler and complete set of target
431 CSREQ
$(1)_T_
$(2)_H_
$(3) = \
432 $$(TSREQ
$(1)_T_
$(2)_H_
$(3)) \
433 $$(HBIN
$(1)_H_
$(3))/rustdoc
$$(X_
$(3)) \
434 $$(foreach dep
,$$(CRATES
),$$(TLIB
$(1)_T_
$(2)_H_
$(3))/stamp.
$$(dep
))
437 # Don't run the stage0 compiler under valgrind - that ship has sailed
438 CFG_VALGRIND_COMPILE
$(1) =
440 CFG_VALGRIND_COMPILE
$(1) = $$(CFG_VALGRIND_COMPILE
)
443 # Add RUSTFLAGS_STAGEN values to the build command
444 EXTRAFLAGS_STAGE
$(1) = $$(RUSTFLAGS_STAGE
$(1))
446 CFGFLAG
$(1)_T_
$(2)_H_
$(3) = stage
$(1)
450 # Same macro/variables as above, but defined in a separate loop so it can use
451 # all the variables above for all archs. The RPATH_VAR setup sometimes needs to
452 # reach across triples to get things in order.
454 # Defines (with the standard $(1)_T_$(2)_H_$(3) suffix):
455 # * `LD_LIBRARY_PATH_ENV_NAME`: the name for the key to use in the OS
456 # environment to access or extend the lookup path for dynamic
457 # libraries. Note on Windows, that key is `$PATH`, and thus not
458 # only conflates programs with dynamic libraries, but also often
459 # contains spaces which confuse make.
460 # * `LD_LIBRARY_PATH_ENV_HOSTDIR`: the entry to add to lookup path for the host
461 # * `LD_LIBRARY_PATH_ENV_TARGETDIR`: the entry to add to lookup path for target
463 # Below that, HOST_RPATH_VAR and TARGET_RPATH_VAR are defined in terms of the
468 ifeq ($$(OSTYPE_
$(3)),apple-darwin
)
469 LD_LIBRARY_PATH_ENV_NAME
$(1)_T_
$(2)_H_
$(3) := DYLD_LIBRARY_PATH
471 ifeq ($$(CFG_WINDOWSY_
$(3)),1)
472 LD_LIBRARY_PATH_ENV_NAME
$(1)_T_
$(2)_H_
$(3) := PATH
474 LD_LIBRARY_PATH_ENV_NAME
$(1)_T_
$(2)_H_
$(3) := LD_LIBRARY_PATH
478 LD_LIBRARY_PATH_ENV_HOSTDIR
$(1)_T_
$(2)_H_
$(3) := \
479 $$(CURDIR
)/$$(HLIB
$(1)_H_
$(3))
480 LD_LIBRARY_PATH_ENV_TARGETDIR
$(1)_T_
$(2)_H_
$(3) := \
481 $$(CURDIR
)/$$(TLIB1_T_
$(2)_H_
$(CFG_BUILD
))
483 HOST_RPATH_VAR
$(1)_T_
$(2)_H_
$(3) := \
484 $$(LD_LIBRARY_PATH_ENV_NAME
$(1)_T_
$(2)_H_
$(3))=$$(LD_LIBRARY_PATH_ENV_HOSTDIR
$(1)_T_
$(2)_H_
$(3)):$$$$$$(LD_LIBRARY_PATH_ENV_NAME
$(1)_T_
$(2)_H_
$(3))
485 TARGET_RPATH_VAR
$(1)_T_
$(2)_H_
$(3) := \
486 $$(LD_LIBRARY_PATH_ENV_NAME
$(1)_T_
$(2)_H_
$(3))=$$(LD_LIBRARY_PATH_ENV_TARGETDIR
$(1)_T_
$(2)_H_
$(3)):$$$$$$(LD_LIBRARY_PATH_ENV_NAME
$(1)_T_
$(2)_H_
$(3))
488 RPATH_VAR
$(1)_T_
$(2)_H_
$(3) := $$(HOST_RPATH_VAR
$(1)_T_
$(2)_H_
$(3))
490 # Pass --cfg stage0 only for the build->host part of stage0;
491 # if you're building a cross config, the host->* parts are
492 # effectively stage1, since it uses the just-built stage0.
494 # This logic is similar to how the LD_LIBRARY_PATH variable must
495 # change be slightly different when doing cross compilations.
496 # The build doesn't copy over all target libraries into
497 # a new directory, so we need to point the library path at
498 # the build directory where all the target libraries came
499 # from (the stage0 build host). Otherwise the relative rpaths
500 # inside of the rustc binary won't get resolved correctly.
502 ifneq ($(strip $(CFG_BUILD
)),$(strip $(3)))
503 CFGFLAG
$(1)_T_
$(2)_H_
$(3) = stage1
505 RPATH_VAR
$(1)_T_
$(2)_H_
$(3) := $$(TARGET_RPATH_VAR
$(1)_T_
$(2)_H_
$(3))
509 STAGE
$(1)_T_
$(2)_H_
$(3) := \
510 $$(Q
)$$(RPATH_VAR
$(1)_T_
$(2)_H_
$(3)) \
511 $$(call CFG_RUN_TARG_
$(3),$(1), \
512 $$(CFG_VALGRIND_COMPILE
$(1)) \
513 $$(HBIN
$(1)_H_
$(3))/rustc
$$(X_
$(3)) \
514 --cfg
$$(CFGFLAG
$(1)_T_
$(2)_H_
$(3)) \
515 $$(CFG_RUSTC_FLAGS
) $$(EXTRAFLAGS_STAGE
$(1)) --target
=$(2)) \
518 PERF_STAGE
$(1)_T_
$(2)_H_
$(3) := \
519 $$(Q
)$$(call CFG_RUN_TARG_
$(3),$(1), \
521 $$(HBIN
$(1)_H_
$(3))/rustc
$$(X_
$(3)) \
522 --cfg
$$(CFGFLAG
$(1)_T_
$(2)_H_
$(3)) \
523 $$(CFG_RUSTC_FLAGS
) $$(EXTRAFLAGS_STAGE
$(1)) --target
=$(2)) \
528 $(foreach build
,$(CFG_HOST
), \
529 $(eval
$(foreach target
,$(CFG_TARGET
), \
530 $(eval
$(foreach stage
,$(STAGES
), \
531 $(eval
$(call SREQ
,$(stage
),$(target
),$(build
))))))))
533 $(foreach build
,$(CFG_HOST
), \
534 $(eval
$(foreach target
,$(CFG_TARGET
), \
535 $(eval
$(foreach stage
,$(STAGES
), \
536 $(eval
$(call SREQ_CMDS
,$(stage
),$(target
),$(build
))))))))
538 ######################################################################
541 # Builds a functional Rustc for the given host.
542 ######################################################################
544 define DEF_RUSTC_STAGE_TARGET
545 # $(1) == architecture
548 rustc-stage
$(2)-H-
$(1): \
549 $$(foreach target
,$$(CFG_TARGET
),$$(SREQ
$(2)_T_
$$(target
)_H_
$(1)))
553 $(foreach host
,$(CFG_HOST
), \
554 $(eval
$(foreach stage
,1 2 3, \
555 $(eval
$(call DEF_RUSTC_STAGE_TARGET
,$(host
),$(stage
))))))
557 rustc-stage1
: rustc-stage1-H-
$(CFG_BUILD
)
558 rustc-stage2
: rustc-stage2-H-
$(CFG_BUILD
)
559 rustc-stage3
: rustc-stage3-H-
$(CFG_BUILD
)
561 define DEF_RUSTC_TARGET
562 # $(1) == architecture
564 rustc-H-
$(1): rustc-stage2-H-
$(1)
567 $(foreach host
,$(CFG_TARGET
), \
568 $(eval
$(call DEF_RUSTC_TARGET
,$(host
))))
570 rustc-stage1
: rustc-stage1-H-
$(CFG_BUILD
)
571 rustc-stage2
: rustc-stage2-H-
$(CFG_BUILD
)
572 rustc-stage3
: rustc-stage3-H-
$(CFG_BUILD
)
573 rustc
: rustc-H-
$(CFG_BUILD
)
575 rustc-H-all
: $(foreach host
,$(CFG_HOST
),rustc-H-
$(host
))
577 ######################################################################
579 ######################################################################
584 ifneq ($$(findstring $(1),$$(CFG_HOST
)),)
586 all-target-
$(1)-host-
$(2): $$(CSREQ2_T_
$(1)_H_
$(2))
588 # This is a target only
589 all-target-
$(1)-host-
$(2): $$(SREQ2_T_
$(1)_H_
$(2))
593 $(foreach target
,$(CFG_TARGET
), \
594 $(foreach host
,$(CFG_HOST
), \
595 $(eval
$(call ALL_TARGET_N
,$(target
),$(host
)))))
597 ALL_TARGET_RULES
= $(foreach target
,$(CFG_TARGET
), \
598 $(foreach host
,$(CFG_HOST
), \
599 all-target-
$(target
)-host-
$(host
)))
601 all: $(ALL_TARGET_RULES
) $(GENERATED
) docs
603 ######################################################################
604 # Build system documentation
605 ######################################################################
607 # $(1) is the name of the doc <section> in Makefile.in
608 # pick everything between tags | remove first line | remove last line
609 # | remove extra (?) line | strip leading `#` from lines
610 SHOW_DOCS
= $(Q
)awk
'/<$(1)>/,/<\/$(1)>/' $(S
)/Makefile.in | sed
'1d' | sed
'$$d' | sed
's/^\# \?//'
613 $(call SHOW_DOCS
,help
)
616 $(call SHOW_DOCS
,tips
)
619 $(call SHOW_DOCS
,nitty-gritty
)