]> git.lizzy.rs Git - rust.git/blob - mk/rt.mk
auto merge of #14638 : alexcrichton/rust/librustrt, r=brson
[rust.git] / mk / rt.mk
1 # Copyright 2014 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.
4 #
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.
10
11 ################################################################################
12 # Native libraries built as part of the rust build process
13 #
14 # This portion of the rust build system is meant to keep track of native
15 # dependencies and how to build them. It is currently required that all native
16 # dependencies are built as static libraries, as slinging around dynamic
17 # libraries isn't exactly the most fun thing to do.
18 #
19 # This section should need minimal modification to add new libraries. The
20 # relevant variables are:
21 #
22 #   NATIVE_LIBS
23 #       This is a list of all native libraries which are built as part of the
24 #       build process. It will build all libraries into RT_OUTPUT_DIR with the
25 #       appropriate name of static library as dictated by the target platform
26 #
27 #   NATIVE_DEPS_<lib>
28 #       This is a list of files relative to the src/rt directory which are
29 #       needed to build the native library. Each file will be compiled to an
30 #       object file, and then all the object files will be assembled into an
31 #       archive (static library). The list contains files of any extension
32 #
33 # If adding a new library, you should update the NATIVE_LIBS list, and then list
34 # the required files below it. The list of required files is a list of files
35 # that's per-target so you're allowed to conditionally add files based on the
36 # target.
37 ################################################################################
38 NATIVE_LIBS := rust_builtin hoedown uv_support morestack miniz context_switch \
39                 rustrt_native rust_test_helpers
40
41 # $(1) is the target triple
42 define NATIVE_LIBRARIES
43
44 NATIVE_DEPS_hoedown_$(1) := hoedown/src/autolink.c \
45                         hoedown/src/buffer.c \
46                         hoedown/src/document.c \
47                         hoedown/src/escape.c \
48                         hoedown/src/html.c \
49                         hoedown/src/html_blocks.c \
50                         hoedown/src/html_smartypants.c \
51                         hoedown/src/stack.c \
52                         hoedown/src/version.c
53 NATIVE_DEPS_uv_support_$(1) := rust_uv.c
54 NATIVE_DEPS_miniz_$(1) = miniz.c
55 NATIVE_DEPS_rust_builtin_$(1) := rust_builtin.c \
56                         rust_android_dummy.c
57 NATIVE_DEPS_rustrt_native_$(1) := \
58                         rust_try.ll \
59                         arch/$$(HOST_$(1))/record_sp.S
60 NATIVE_DEPS_rust_test_helpers_$(1) := rust_test_helpers.c
61 NATIVE_DEPS_morestack_$(1) := arch/$$(HOST_$(1))/morestack.S
62 NATIVE_DEPS_context_switch_$(1) := \
63                         arch/$$(HOST_$(1))/_context.S
64
65 ################################################################################
66 # You shouldn't find it that necessary to edit anything below this line.
67 ################################################################################
68
69 # While we're defining the native libraries for each target, we define some
70 # common rules used to build files for various targets.
71
72 RT_OUTPUT_DIR_$(1) := $(1)/rt
73
74 $$(RT_OUTPUT_DIR_$(1))/%.o: $(S)src/rt/%.ll $$(MKFILE_DEPS) \
75             $$(LLVM_CONFIG_$$(CFG_BUILD))
76         @mkdir -p $$(@D)
77         @$$(call E, compile: $$@)
78         $$(Q)$$(LLC_$$(CFG_BUILD)) $$(CFG_LLC_FLAGS_$(1)) \
79             -filetype=obj -mtriple=$(1) -relocation-model=pic -o $$@ $$<
80
81 $$(RT_OUTPUT_DIR_$(1))/%.o: $(S)src/rt/%.c $$(MKFILE_DEPS)
82         @mkdir -p $$(@D)
83         @$$(call E, compile: $$@)
84         $$(Q)$$(call CFG_COMPILE_C_$(1), $$@, \
85                 -I $$(S)src/rt/hoedown/src \
86                 -I $$(S)src/libuv/include -I $$(S)src/rt \
87                  $$(RUNTIME_CFLAGS_$(1))) $$<
88
89 $$(RT_OUTPUT_DIR_$(1))/%.o: $(S)src/rt/%.S $$(MKFILE_DEPS) \
90             $$(LLVM_CONFIG_$$(CFG_BUILD))
91         @mkdir -p $$(@D)
92         @$$(call E, compile: $$@)
93         $$(Q)$$(call CFG_ASSEMBLE_$(1),$$@,$$<)
94 endef
95
96 $(foreach target,$(CFG_TARGET),$(eval $(call NATIVE_LIBRARIES,$(target))))
97
98 # A macro for devining how to build third party libraries listed above (based
99 # on their dependencies).
100 #
101 # $(1) is the target
102 # $(2) is the lib name
103 define THIRD_PARTY_LIB
104
105 OBJS_$(2)_$(1) := $$(NATIVE_DEPS_$(2)_$(1):%=$$(RT_OUTPUT_DIR_$(1))/%)
106 OBJS_$(2)_$(1) := $$(OBJS_$(2)_$(1):.c=.o)
107 OBJS_$(2)_$(1) := $$(OBJS_$(2)_$(1):.cpp=.o)
108 OBJS_$(2)_$(1) := $$(OBJS_$(2)_$(1):.ll=.o)
109 OBJS_$(2)_$(1) := $$(OBJS_$(2)_$(1):.S=.o)
110 NATIVE_$(2)_$(1) := $$(call CFG_STATIC_LIB_NAME_$(1),$(2))
111 $$(RT_OUTPUT_DIR_$(1))/$$(NATIVE_$(2)_$(1)): $$(OBJS_$(2)_$(1))
112         @$$(call E, link: $$@)
113         $$(Q)$$(AR_$(1)) rcs $$@ $$^
114
115 endef
116
117 $(foreach target,$(CFG_TARGET),                                     \
118  $(eval $(call RUNTIME_RULES,$(target))))
119 $(foreach lib,$(NATIVE_LIBS),                                       \
120  $(foreach target,$(CFG_TARGET),                                    \
121   $(eval $(call THIRD_PARTY_LIB,$(target),$(lib)))))
122
123
124 ################################################################################
125 # Building third-party targets with external build systems
126 #
127 # This location is meant for dependencies which have external build systems. It
128 # is still assumed that the output of each of these steps is a static library
129 # in the correct location.
130 ################################################################################
131
132 ################################################################################
133 # libuv
134 ################################################################################
135
136 define DEF_LIBUV_ARCH_VAR
137   LIBUV_ARCH_$(1) = $$(subst i386,ia32,$$(subst x86_64,x64,$$(HOST_$(1))))
138 endef
139 $(foreach t,$(CFG_TARGET),$(eval $(call DEF_LIBUV_ARCH_VAR,$(t))))
140
141 ifdef CFG_ENABLE_FAST_MAKE
142 LIBUV_DEPS := $(S)/.gitmodules
143 else
144 LIBUV_DEPS := $(wildcard \
145               $(S)src/libuv/* \
146               $(S)src/libuv/*/* \
147               $(S)src/libuv/*/*/* \
148               $(S)src/libuv/*/*/*/*)
149 endif
150
151 LIBUV_NO_LOAD = run-benchmarks.target.mk run-tests.target.mk \
152                 uv_dtrace_header.target.mk uv_dtrace_provider.target.mk
153
154 export PYTHONPATH := $(PYTHONPATH):$(S)src/gyp/pylib
155
156 define DEF_THIRD_PARTY_TARGETS
157
158 # $(1) is the target triple
159
160 ifeq ($$(CFG_WINDOWSY_$(1)), 1)
161   LIBUV_OSTYPE_$(1) := win
162   # This isn't necessarily a desired option, but it's harmless and works around
163   # what appears to be a mingw-w64 bug.
164   #
165   # https://sourceforge.net/p/mingw-w64/bugs/395/
166   JEMALLOC_ARGS_$(1) := --enable-lazy-lock
167 else ifeq ($(OSTYPE_$(1)), apple-darwin)
168   LIBUV_OSTYPE_$(1) := mac
169 else ifeq ($(OSTYPE_$(1)), unknown-freebsd)
170   LIBUV_OSTYPE_$(1) := freebsd
171 else ifeq ($(OSTYPE_$(1)), linux-androideabi)
172   LIBUV_OSTYPE_$(1) := android
173   LIBUV_ARGS_$(1) := PLATFORM=android host=android OS=linux
174   JEMALLOC_ARGS_$(1) := --disable-tls
175 else
176   LIBUV_OSTYPE_$(1) := linux
177 endif
178
179 LIBUV_NAME_$(1) := $$(call CFG_STATIC_LIB_NAME_$(1),uv)
180 LIBUV_DIR_$(1) := $$(RT_OUTPUT_DIR_$(1))/libuv
181 LIBUV_LIB_$(1) := $$(RT_OUTPUT_DIR_$(1))/$$(LIBUV_NAME_$(1))
182
183 LIBUV_MAKEFILE_$(1) := $$(CFG_BUILD_DIR)$$(RT_OUTPUT_DIR_$(1))/libuv/Makefile
184
185 LIBUV_STAMP_$(1) = $$(LIBUV_DIR_$(1))/libuv-auto-clean-stamp
186
187 $$(LIBUV_STAMP_$(1)): $(S)src/rt/libuv-auto-clean-trigger
188         $$(Q)rm -rf $$(LIBUV_DIR_$(1))
189         $$(Q)mkdir -p $$(@D)
190         touch $$@
191
192 # libuv triggers a few warnings on some platforms
193 LIBUV_CFLAGS_$(1) := $(subst -Werror,,$(CFG_GCCISH_CFLAGS_$(1)))
194
195 $$(LIBUV_MAKEFILE_$(1)): $$(LIBUV_DEPS) $$(MKFILE_DEPS) $$(LIBUV_STAMP_$(1))
196         (cd $(S)src/libuv/ && \
197          $$(CFG_PYTHON) ./gyp_uv.py -f make -Dtarget_arch=$$(LIBUV_ARCH_$(1)) \
198            -D ninja \
199            -DOS=$$(LIBUV_OSTYPE_$(1)) \
200            -Goutput_dir=$$(@D) --generator-output $$(@D))
201         touch $$@
202
203 # Windows has a completely different build system for libuv because of mingw. In
204 # theory when we support msvc then we should be using gyp's msvc output instead
205 # of mingw's makefile for windows
206 ifdef CFG_WINDOWSY_$(1)
207 $$(LIBUV_LIB_$(1)): $$(LIBUV_DEPS) $$(MKFILE_DEPS)
208         $$(Q)$$(MAKE) -C $$(S)src/libuv -f Makefile.mingw \
209                 LDFLAGS="$$(CFG_GCCISH_LINK_FLAGS_$(1))" \
210                 CC="$$(CC_$(1)) $$(LIBUV_CFLAGS_$(1)) $$(SNAP_DEFINES)" \
211                 CXX="$$(CXX_$(1))" \
212                 AR="$$(AR_$(1))" \
213                 V=$$(VERBOSE)
214         $$(Q)cp $$(S)src/libuv/libuv.a $$@
215 else
216 $$(LIBUV_LIB_$(1)): $$(LIBUV_DIR_$(1))/Release/libuv.a $$(MKFILE_DEPS)
217         $$(Q)cp $$< $$@
218 $$(LIBUV_DIR_$(1))/Release/libuv.a: $$(LIBUV_DEPS) $$(LIBUV_MAKEFILE_$(1)) \
219                                     $$(MKFILE_DEPS)
220         $$(Q)$$(MAKE) -C $$(LIBUV_DIR_$(1)) \
221                 CFLAGS="$$(LIBUV_CFLAGS_$(1)) $$(SNAP_DEFINES)" \
222                 LDFLAGS="$$(CFG_GCCISH_LINK_FLAGS_$(1))" \
223                 CC="$$(CC_$(1))" \
224                 CXX="$$(CXX_$(1))" \
225                 AR="$$(AR_$(1))" \
226                 $$(LIBUV_ARGS_$(1)) \
227                 BUILDTYPE=Release \
228                 NO_LOAD="$$(LIBUV_NO_LOAD)" \
229                 V=$$(VERBOSE)
230         $$(Q)touch $$@
231
232 endif
233
234 ################################################################################
235 # jemalloc
236 ################################################################################
237
238 ifdef CFG_ENABLE_FAST_MAKE
239 JEMALLOC_DEPS := $(S)/.gitmodules
240 else
241 JEMALLOC_DEPS := $(wildcard \
242                    $(S)src/jemalloc/* \
243                    $(S)src/jemalloc/*/* \
244                    $(S)src/jemalloc/*/*/* \
245                    $(S)src/jemalloc/*/*/*/*)
246 endif
247
248 JEMALLOC_NAME_$(1) := $$(call CFG_STATIC_LIB_NAME_$(1),jemalloc)
249 ifeq ($$(CFG_WINDOWSY_$(1)),1)
250   JEMALLOC_REAL_NAME_$(1) := $$(call CFG_STATIC_LIB_NAME_$(1),jemalloc_s)
251 else
252   JEMALLOC_REAL_NAME_$(1) := $$(call CFG_STATIC_LIB_NAME_$(1),jemalloc_pic)
253 endif
254 JEMALLOC_LIB_$(1) := $$(RT_OUTPUT_DIR_$(1))/$$(JEMALLOC_NAME_$(1))
255 JEMALLOC_BUILD_DIR_$(1) := $$(RT_OUTPUT_DIR_$(1))/jemalloc
256
257 $$(JEMALLOC_LIB_$(1)): $$(JEMALLOC_DEPS) $$(MKFILE_DEPS)
258         @$$(call E, make: jemalloc)
259         cd "$$(JEMALLOC_BUILD_DIR_$(1))"; "$(S)src/jemalloc/configure" \
260                 $$(JEMALLOC_ARGS_$(1)) --enable-cc-silence --with-jemalloc-prefix=je_ \
261                 --disable-experimental --build=$(CFG_BUILD) --host=$(1) \
262                 CC="$$(CC_$(1))" \
263                 AR="$$(AR_$(1))" \
264                 RANLIB="$$(AR_$(1)) s" \
265                 CPPFLAGS="-I $(S)src/rt/" \
266                 EXTRA_CFLAGS="$$(CFG_CFLAGS_$(1)) -g1"
267         $$(Q)$$(MAKE) -C "$$(JEMALLOC_BUILD_DIR_$(1))" build_lib_static
268         $$(Q)cp $$(JEMALLOC_BUILD_DIR_$(1))/lib/$$(JEMALLOC_REAL_NAME_$(1)) $$(JEMALLOC_LIB_$(1))
269
270 ################################################################################
271 # compiler-rt
272 ################################################################################
273
274 ifdef CFG_ENABLE_FAST_MAKE
275 COMPRT_DEPS := $(S)/.gitmodules
276 else
277 COMPRT_DEPS := $(wildcard \
278               $(S)src/compiler-rt/* \
279               $(S)src/compiler-rt/*/* \
280               $(S)src/compiler-rt/*/*/* \
281               $(S)src/compiler-rt/*/*/*/*)
282 endif
283
284 COMPRT_NAME_$(1) := $$(call CFG_STATIC_LIB_NAME_$(1),compiler-rt)
285 COMPRT_LIB_$(1) := $$(RT_OUTPUT_DIR_$(1))/$$(COMPRT_NAME_$(1))
286 COMPRT_BUILD_DIR_$(1) := $$(RT_OUTPUT_DIR_$(1))/compiler-rt
287
288 $$(COMPRT_LIB_$(1)): $$(COMPRT_DEPS) $$(MKFILE_DEPS)
289         @$$(call E, make: compiler-rt)
290         $$(Q)$$(MAKE) -C "$(S)src/compiler-rt" \
291                 ProjSrcRoot="$(S)src/compiler-rt" \
292                 ProjObjRoot="$$(abspath $$(COMPRT_BUILD_DIR_$(1)))" \
293                 CC="$$(CC_$(1))" \
294                 AR="$$(AR_$(1))" \
295                 RANLIB="$$(AR_$(1)) s" \
296                 CFLAGS="$$(CFG_GCCISH_CFLAGS_$(1))" \
297                 TargetTriple=$(1) \
298                 triple-builtins
299         $$(Q)cp $$(COMPRT_BUILD_DIR_$(1))/triple/builtins/libcompiler_rt.a $$(COMPRT_LIB_$(1))
300
301 ################################################################################
302 # libbacktrace
303 #
304 # We use libbacktrace on linux to get symbols in backtraces, but only on linux.
305 # Elsewhere we use other system utilities, so this library is only built on
306 # linux.
307 ################################################################################
308
309 BACKTRACE_NAME_$(1) := $$(call CFG_STATIC_LIB_NAME_$(1),backtrace)
310 BACKTRACE_LIB_$(1) := $$(RT_OUTPUT_DIR_$(1))/$$(BACKTRACE_NAME_$(1))
311 BACKTRACE_BUILD_DIR_$(1) := $$(RT_OUTPUT_DIR_$(1))/libbacktrace
312
313 ifeq ($$(findstring darwin,$$(OSTYPE_$(1))),darwin)
314
315 # We don't use this on platforms that aren't linux-based, so just make the file
316 # available, the compilation of libstd won't actually build it.
317 $$(BACKTRACE_LIB_$(1)):
318         touch $$@
319
320 else
321 ifeq ($$(CFG_WINDOWSY_$(1)),1)
322 $$(BACKTRACE_LIB_$(1)):
323         touch $$@
324 else
325
326 ifdef CFG_ENABLE_FAST_MAKE
327 BACKTRACE_DEPS := $(S)/.gitmodules
328 else
329 BACKTRACE_DEPS := $(wildcard $(S)src/libbacktrace/*)
330 endif
331
332 # We need to export CFLAGS because otherwise it doesn't pick up cross compile
333 # builds. If libbacktrace doesn't realize this, it will attempt to read 64-bit
334 # elf headers when compiled for a 32-bit system, yielding blank backtraces.
335 #
336 # This also removes the -Werror flag specifically to prevent errors during
337 # configuration.
338 #
339 # Down below you'll also see echos into the config.h generated by the
340 # ./configure script. This is done to force libbacktrace to *not* use the
341 # atomic/sync functionality because it pulls in unnecessary dependencies and we
342 # never use it anyway.
343 $$(BACKTRACE_BUILD_DIR_$(1))/Makefile: \
344                 export CFLAGS:=$$(CFG_GCCISH_CFLAGS_$(1):-Werror=) \
345                                 -fno-stack-protector
346 $$(BACKTRACE_BUILD_DIR_$(1))/Makefile: export CC:=$$(CC_$(1))
347 $$(BACKTRACE_BUILD_DIR_$(1))/Makefile: export AR:=$$(AR_$(1))
348 $$(BACKTRACE_BUILD_DIR_$(1))/Makefile: export RANLIB:=$$(AR_$(1)) s
349 $$(BACKTRACE_BUILD_DIR_$(1))/Makefile: $$(BACKTRACE_DEPS) $$(MKFILE_DEPS)
350         $$(Q)rm -rf $$(BACKTRACE_BUILD_DIR_$(1))
351         $$(Q)mkdir -p $$(BACKTRACE_BUILD_DIR_$(1))
352         $$(Q)(cd $$(BACKTRACE_BUILD_DIR_$(1)) && \
353               $(S)src/libbacktrace/configure --target=$(1) --host=$(CFG_BUILD))
354         $$(Q)echo '#undef HAVE_ATOMIC_FUNCTIONS' >> \
355               $$(BACKTRACE_BUILD_DIR_$(1))/config.h
356         $$(Q)echo '#undef HAVE_SYNC_FUNCTIONS' >> \
357               $$(BACKTRACE_BUILD_DIR_$(1))/config.h
358
359 $$(BACKTRACE_LIB_$(1)): $$(BACKTRACE_BUILD_DIR_$(1))/Makefile $$(MKFILE_DEPS)
360         @$$(call E, make: libbacktrace)
361         $$(Q)$$(MAKE) -C $$(BACKTRACE_BUILD_DIR_$(1)) \
362                 INCDIR=$(S)src/libbacktrace
363         $$(Q)cp $$(BACKTRACE_BUILD_DIR_$(1))/.libs/libbacktrace.a $$@
364
365 endif # endif for windowsy
366 endif # endif for darwin
367
368 endef
369
370 # Instantiate template for all stages/targets
371 $(foreach target,$(CFG_TARGET), \
372      $(eval $(call DEF_THIRD_PARTY_TARGETS,$(target))))