summaryrefslogtreecommitdiff
path: root/Makefile.common
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2003-03-14 20:25:22 +0000
committerChris Lattner <sabre@nondot.org>2003-03-14 20:25:22 +0000
commit760da06489cdb1b0adde1de70f7c70ecd24487a3 (patch)
treef5bc66c4e43698e0091a2fa85dd6272bb3c6b4ba /Makefile.common
parentc8802d2c167263a769856d2c4f070c3cfbf7260c (diff)
downloadllvm-760da06489cdb1b0adde1de70f7c70ecd24487a3.tar.gz
llvm-760da06489cdb1b0adde1de70f7c70ecd24487a3.tar.bz2
llvm-760da06489cdb1b0adde1de70f7c70ecd24487a3.tar.xz
Fix several bugs in the build system, including the use of the Debug version of Burg no matter what configuration is currently configured.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@5744 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'Makefile.common')
-rw-r--r--Makefile.common77
1 files changed, 25 insertions, 52 deletions
diff --git a/Makefile.common b/Makefile.common
index f13d412cd1..b803def09e 100644
--- a/Makefile.common
+++ b/Makefile.common
@@ -104,18 +104,30 @@ BURG_OPTS = -I
PURIFY := $(PURIFY) -cache-dir="$(BUILD_ROOT_TOP)/../purifycache" -chain-length="30" -messages=all
+ifdef ENABLE_PROFILING
+ ENABLE_OPTIMIZED = 1
+ CONFIGURATION := Profile
+else
+ ifdef ENABLE_OPTIMIZED
+ CONFIGURATION := Release
+ else
+ CONFIGURATION := Debug
+ endif
+endif
+
# Shorthand for commonly accessed directories
LIBDEBUG := $(BUILD_ROOT_TOP)/lib/Debug
LIBRELEASE := $(BUILD_ROOT_TOP)/lib/Release
LIBPROFILE := $(BUILD_ROOT_TOP)/lib/Profile
+LIBCURRENT := $(BUILD_ROOT_TOP)/lib/$(CONFIGURATION)
+
TOOLDEBUG := $(BUILD_ROOT_TOP)/tools/Debug
TOOLRELEASE := $(BUILD_ROOT_TOP)/tools/Release
TOOLPROFILE := $(BUILD_ROOT_TOP)/tools/Profile
+TOOLCURRENT := $(BUILD_ROOT_TOP)/tools/$(CONFIGURATION)
# Verbosity levels
-ifdef VERBOSE
-VERB :=
-else
+ifndef VERBOSE
VERB := @
endif
@@ -126,7 +138,7 @@ endif
# Special tools used while building the LLVM tree. Burg is built as part of the
# utils directory.
#
-BURG := $(TOOLDEBUG)/burg
+BURG := $(TOOLCURRENT)/burg
RunBurg := $(BURG) $(BURG_OPTS)
@@ -134,16 +146,10 @@ RunBurg := $(BURG) $(BURG_OPTS)
# This automatically enables optimized builds.
ifdef ENABLE_PROFILING
PROFILE = -pg
- ENABLE_OPTIMIZED = 1
-else
- PROFILE =
endif
# By default, strip symbol information from executable
-ifdef KEEP_SYMBOLS
-STRIP =
-STRIP_WARN_MSG =
-else
+ifndef KEEP_SYMBOLS
STRIP = $(PLATFORMSTRIPOPTS)
STRIP_WARN_MSG = "(without symbols) "
endif
@@ -265,43 +271,19 @@ LIBNAME_OBJO := $(LIBRELEASE)/$(LIBRARYNAME).o
LIBNAME_OBJP := $(LIBPROFILE)/$(LIBRARYNAME).o
LIBNAME_OBJG := $(LIBDEBUG)/$(LIBRARYNAME).o
+# dynamic target builds a shared object version of the library...
+dynamic:: $(LIBCURRENT)/lib$(LIBRARYNAME).so
-ifndef ENABLE_OPTIMIZED
-BUILD_LIBNAME_G := $(LIBNAME_G)
+# Does the library want a .o version built?
ifndef DONT_BUILD_RELINKED
-BUILD_LIBNAME_OBJG := $(LIBNAME_OBJG)
-endif
-ifdef BUILD_ARCHIVE
-BUILD_LIBNAME_AG := $(LIBNAME_AG)
-endif
+all:: $(LIBCURRENT)/$(LIBRARYNAME).o
endif
-# If optimized builds are enabled...
-ifdef ENABLE_OPTIMIZED
- ifdef ENABLE_PROFILING
- BUILD_LIBNAME_O := $(LIBNAME_P)
- ifndef DONT_BUILD_RELINKED
- BUILD_LIBNAME_OBJO := $(LIBNAME_OBJP)
- endif
- ifdef BUILD_ARCHIVE
- BUILD_LIBNAME_AO := $(LIBNAME_AP)
- endif
- else
- BUILD_LIBNAME_O := $(LIBNAME_O)
- ifndef DONT_BUILD_RELINKED
- BUILD_LIBNAME_OBJO := $(LIBNAME_OBJO)
- endif
- ifdef BUILD_ARCHIVE
- BUILD_LIBNAME_AO := $(LIBNAME_AO)
- endif
- endif
+# Does the library want an archive version built?
+ifdef BUILD_ARCHIVE
+all:: $(LIBCURRENT)/lib$(LIBRARYNAME).a
endif
-all:: $(BUILD_LIBNAME_AG) $(BUILD_LIBNAME_OBJG) # Debug
-all:: $(BUILD_LIBNAME_AO) $(BUILD_LIBNAME_OBJO) # Release
-all:: $(BUILD_LIBNAME_AP) $(BUILD_LIBNAME_OBJP) # Profile
-dynamic:: $(BUILD_LIBNAME_G) $(BUILD_LIBNAME_O) $(BUILD_LIBNAME_P) # .so files
-
$(LIBNAME_O): $(ObjectsO) $(LibSubDirs) $(LIBRELEASE)/.dir
@echo ======= Linking $(LIBRARYNAME) release library =======
$(VERB) $(MakeSOO) -o $@ $(ObjectsO) $(LibSubDirs) $(LibLinkOpts)
@@ -368,16 +350,7 @@ ifdef TOOLNAME
TOOLEXENAME_G := $(BUILD_ROOT_TOP)/tools/Debug/$(TOOLNAME)
TOOLEXENAME_O := $(BUILD_ROOT_TOP)/tools/Release/$(TOOLNAME)
TOOLEXENAME_P := $(BUILD_ROOT_TOP)/tools/Profile/$(TOOLNAME)
-
-ifndef ENABLE_OPTIMIZED
- TOOLEXENAMES := $(TOOLEXENAME_G)
-else
- ifdef ENABLE_PROFILING
- TOOLEXENAMES := $(TOOLEXENAME_P)
- else
- TOOLEXENAMES := $(TOOLEXENAME_O)
- endif
-endif
+TOOLEXENAMES := $(BUILD_ROOT_TOP)/tools/$(CONFIGURATION)/$(TOOLNAME)
# USED_LIBS_OPTIONS - Compute the options line that add -llib1 -llib2, etc.
USED_LIBS_OPTIONS := $(patsubst %.a.o, -l%, $(addsuffix .o, $(USEDLIBS)))