aboutsummaryrefslogtreecommitdiff
path: root/src/Makefile
diff options
context:
space:
mode:
authorRafael Ávila de Espíndola <[email protected]>2011-03-08 15:32:42 -0500
committerGraydon Hoare <[email protected]>2011-03-08 13:08:31 -0800
commit55c80e763bfd850682b3217fcfc5cdb516eafae0 (patch)
tree195be92a5e5de795986703c968e534262f61b37c /src/Makefile
parentrustc: Pass explicit type substitutions to later passes (diff)
downloadrust-55c80e763bfd850682b3217fcfc5cdb516eafae0.tar.xz
rust-55c80e763bfd850682b3217fcfc5cdb516eafae0.zip
Move the glue asm code to a .o file. This reduces how much asm we print
in each "translation unit".
Diffstat (limited to 'src/Makefile')
-rw-r--r--src/Makefile23
1 files changed, 19 insertions, 4 deletions
diff --git a/src/Makefile b/src/Makefile
index a239329f..cafd8d18 100644
--- a/src/Makefile
+++ b/src/Makefile
@@ -90,6 +90,7 @@ ifdef CFG_WINDOWSY
CFG_EXE_SUFFIX := .exe
CFG_BOOT := ./rustboot.exe
CFG_RUSTC := ./rustc.exe
+ CFG_GLUE := ./glue.exe
CFG_GCC_CFLAGS += -march=i686
CFG_GCC_LINK_FLAGS += -shared -fPIC
CFG_RUN_TARG = $(1)
@@ -101,6 +102,7 @@ ifdef CFG_UNIXY
CFG_INFO := $(info cfg: unix-y environment)
CFG_BOOT := ./rustboot
CFG_RUSTC := ./rustc
+ CFG_GLUE := ./glue
CFG_OBJ_SUFFIX := .o
CFG_RUN_TARG = LD_LIBRARY_PATH=. $(CFG_VALGRIND) $(1)
CFG_GCC := 1
@@ -111,6 +113,7 @@ ifdef CFG_UNIXY
CFG_RUNTIME := rustrt.dll
CFG_STDLIB := std.dll
CFG_RUSTC := ./rustc.exe
+ CFG_GLUE := ./glue
ifdef CFG_VALGRIND
CFG_VALGRIND += wine
endif
@@ -308,11 +311,13 @@ RUNTIME_LIBS := $(CFG_RUNTIME_LIBS)
STDLIB_CRATE := lib/std.rc
STDLIB_INPUTS := $(wildcard lib/*.rc lib/*.rs lib/*/*.rs)
COMPILER_CRATE := comp/rustc.rc
-COMPILER_INPUTS := $(wildcard comp/*.rc comp/*.rs comp/*/*.rs)
+COMPILER_INPUTS := $(wildcard comp/rustc.rc comp/*.rs comp/*/*.rs)
+GLUE_CRATE := comp/glue.rc
+GLUE_INPUTS := $(wildcard comp/glue.rc comp/*.rs comp/*/*.rs)
GENERATED := boot/fe/lexer.ml boot/util/version.ml
-all: $(CFG_RUSTC) $(MKFILES) $(GENERATED)
+all: $(CFG_RUSTC) $(CFG_GLUE) $(MKFILES) $(GENERATED) glue.o
boot/util/version.ml: Makefile
$(CFG_QUIET)git log -1 \
@@ -368,6 +373,16 @@ $(CFG_RUSTC): $(COMPILER_INPUTS) $(CFG_BOOT) $(CFG_RUNTIME) $(CFG_STDLIB)
$(BOOT) -minimal -o $@ $<
$(CFG_QUIET)chmod 0755 $@
+$(CFG_GLUE): $(GLUE_INPUTS) $(CFG_BOOT) $(CFG_RUNTIME) $(CFG_STDLIB)
+ @$(call CFG_ECHO, compile: $<)
+ $(BOOT) -minimal -o $@ $<
+ $(CFG_QUIET)chmod 0755 $@
+
+glue.o: glue.s
+
+glue.s: $(CFG_GLUE)
+ $(CFG_GLUE) > $@
+
self: $(CFG_RUSTC)
@$(call CFG_ECHO, compile: $<)
$(RUSTC) $(COMPILER_CRATE)
@@ -763,9 +778,9 @@ test/bench/shootout/%.boot$(CFG_EXE_SUFFIX): \
@$(call CFG_ECHO, assemble [llvm]: $<)
$(CFG_QUIET)gcc $(CFG_GCC_CFLAGS) -o $@ -c $<
-%.rustc$(CFG_EXE_SUFFIX): %.o $(CFG_RUNTIME)
+%.rustc$(CFG_EXE_SUFFIX): %.o $(CFG_RUNTIME) glue.o
@$(call CFG_ECHO, link [llvm]: $<)
- $(CFG_QUIET)gcc $(CFG_GCC_CFLAGS) -o $@ $< -L. -lrustrt
+ $(CFG_QUIET)gcc $(CFG_GCC_CFLAGS) glue.o -o $@ $< -L. -lrustrt
@# dsymutil sometimes fails or prints a warning, but the
@# program still runs. Since it simplifies debugging other
@# programs, I\'ll live with the noise.