blob: 03ab0446522a55dff64c73aa62b687fb16474cce [file] [log] [blame]
Misha Brukman7426c892004-04-24 00:10:56 +00001#===- ./Makefile -------------------------------------------*- Makefile -*--===#
Misha Brukman2879c292009-01-08 02:11:55 +00002#
John Criswell4436c492003-10-20 22:26:57 +00003# The LLVM Compiler Infrastructure
4#
Chris Lattner11cc8b32007-12-29 20:11:13 +00005# This file is distributed under the University of Illinois Open Source
6# License. See LICENSE.TXT for details.
Misha Brukman2879c292009-01-08 02:11:55 +00007#
Misha Brukman7426c892004-04-24 00:10:56 +00008#===------------------------------------------------------------------------===#
Chris Lattner2ad80c22006-06-02 22:41:18 +00009
Chris Lattnerb85c3252006-07-26 19:10:34 +000010LEVEL := .
Chris Lattner31b4aa52006-09-04 04:27:07 +000011
12# Top-Level LLVM Build Stages:
13# 1. Build lib/System and lib/Support, which are used by utils (tblgen).
14# 2. Build utils, which is used by VMCore.
15# 3. Build VMCore, which builds the Intrinsics.inc file used by libs.
16# 4. Build libs, which are needed by llvm-config.
17# 5. Build llvm-config, which determines inter-lib dependencies for tools.
Reid Spencer4b8067f2006-11-17 03:32:33 +000018# 6. Build tools, runtime, docs.
Chris Lattner31b4aa52006-09-04 04:27:07 +000019#
Anton Korobeynikov8e58c522008-11-10 07:33:13 +000020# When cross-compiling, there are some things (tablegen) that need to
21# be build for the build system first.
22ifeq ($(BUILD_DIRS_ONLY),1)
23 DIRS := lib/System lib/Support utils
24 OPTIONAL_DIRS :=
25else
26 DIRS := lib/System lib/Support utils lib/VMCore lib tools/llvm-config \
Daniel Dunbar96ccc472009-09-13 22:39:27 +000027 tools runtime docs unittests
Anton Korobeynikov8e58c522008-11-10 07:33:13 +000028 OPTIONAL_DIRS := examples projects bindings
29endif
David Greeneb2e2be42007-07-11 23:44:08 +000030
Misha Brukmanbcf15382009-01-01 02:24:48 +000031EXTRA_DIST := test unittests llvm.spec include win32 Xcode
Chris Lattner2f7c9632001-06-06 20:29:01 +000032
Misha Brukman2879c292009-01-08 02:11:55 +000033include $(LEVEL)/Makefile.config
Reid Spenceraed84e42006-04-06 22:15:51 +000034
Chris Lattner323a5132007-03-29 18:14:00 +000035# llvm-gcc4 doesn't need runtime libs. llvm-gcc4 is the only supported one.
36# FIXME: Remove runtime entirely once we have an understanding of where
37# libprofile etc should go.
38#ifeq ($(LLVMGCC_MAJVERS),4)
Daniel Dunbar0e043942009-08-19 21:09:45 +000039# DIRS := $(filter-out runtime, $(DIRS))
Chris Lattner323a5132007-03-29 18:14:00 +000040#endif
Reid Spencer4b8067f2006-11-17 03:32:33 +000041
Chris Lattnerb85c3252006-07-26 19:10:34 +000042ifeq ($(MAKECMDGOALS),libs-only)
Reid Spencer4b8067f2006-11-17 03:32:33 +000043 DIRS := $(filter-out tools runtime docs, $(DIRS))
Chris Lattner2ad80c22006-06-02 22:41:18 +000044 OPTIONAL_DIRS :=
45endif
46
Nate Begeman938d8cb2007-12-13 02:17:17 +000047ifeq ($(MAKECMDGOALS),install-libs)
48 DIRS := $(filter-out tools runtime docs, $(DIRS))
49 OPTIONAL_DIRS := $(filter bindings, $(OPTIONAL_DIRS))
50endif
51
Chris Lattnerb85c3252006-07-26 19:10:34 +000052ifeq ($(MAKECMDGOALS),tools-only)
Reid Spencer4b8067f2006-11-17 03:32:33 +000053 DIRS := $(filter-out runtime docs, $(DIRS))
Chris Lattnerb85c3252006-07-26 19:10:34 +000054 OPTIONAL_DIRS :=
55endif
Chris Lattner2ad80c22006-06-02 22:41:18 +000056
Mike Stumpeb1e2002009-01-19 19:48:23 +000057ifeq ($(MAKECMDGOALS),install-clang)
Mike Stumpa0c86122009-03-26 23:43:14 +000058 DIRS := tools/clang/tools/driver tools/clang/tools/clang-cc \
Mike Stump43a675b2009-05-01 01:47:55 +000059 tools/clang/lib/Headers tools/clang/docs
Mike Stumpeb1e2002009-01-19 19:48:23 +000060 OPTIONAL_DIRS :=
61 NO_INSTALL = 1
62endif
63
64ifeq ($(MAKECMDGOALS),clang-only)
65 DIRS := $(filter-out tools runtime docs, $(DIRS)) tools/clang
66 OPTIONAL_DIRS :=
67endif
68
Misha Brukmanbcf15382009-01-01 02:24:48 +000069ifeq ($(MAKECMDGOALS),unittests)
70 DIRS := $(filter-out tools runtime docs, $(DIRS)) utils unittests
71 OPTIONAL_DIRS :=
72endif
73
Chris Lattner8bbd76b2009-05-08 17:32:47 +000074# Use NO_INSTALL define of the Makefile of each directory for deciding
75# if the directory is installed or not
Chris Lattner31f99b92007-02-21 06:23:20 +000076ifeq ($(MAKECMDGOALS),install)
Gordon Henriksen37582f72007-09-18 12:49:39 +000077 OPTIONAL_DIRS := $(filter bindings, $(OPTIONAL_DIRS))
Chris Lattner31f99b92007-02-21 06:23:20 +000078endif
79
Anton Korobeynikov8e58c522008-11-10 07:33:13 +000080# If we're cross-compiling, build the build-hosted tools first
81ifeq ($(LLVM_CROSS_COMPILING),1)
82all:: cross-compile-build-tools
83
84clean::
85 $(Verb) rm -rf BuildTools
86
87cross-compile-build-tools:
88 $(Verb) if [ ! -f BuildTools/Makefile ]; then \
89 $(MKDIR) BuildTools; \
90 cd BuildTools ; \
Shantonu Sen96995e82009-09-02 23:52:23 +000091 $(PROJ_SRC_DIR)/configure --build=$(BUILD_TRIPLE) \
92 --host=$(BUILD_TRIPLE) --target=$(BUILD_TRIPLE); \
Anton Korobeynikov8e58c522008-11-10 07:33:13 +000093 cd .. ; \
94 fi; \
Shantonu Sen96995e82009-09-02 23:52:23 +000095 ($(MAKE) -C BuildTools \
96 BUILD_DIRS_ONLY=1 \
97 UNIVERSAL= \
98 ENABLE_OPTIMIZED=$(ENABLE_OPTIMIZED) \
99 ENABLE_PROFILING=$(ENABLE_PROFILING) \
100 ENABLE_COVERAGE=$(ENABLE_COVERAGE) \
101 DISABLE_ASSERTIONS=$(DISABLE_ASSERTIONS) \
102 ENABLE_EXPENSIVE_CHECKS=$(ENABLE_EXPENSIVE_CHECKS) \
103 ) || exit 1;
Anton Korobeynikov8e58c522008-11-10 07:33:13 +0000104endif
105
Chris Lattner2ad80c22006-06-02 22:41:18 +0000106# Include the main makefile machinery.
Reid Spencer8ac50622006-04-08 02:14:37 +0000107include $(LLVM_SRC_ROOT)/Makefile.rules
108
Reid Spencer13f51932005-05-24 02:33:20 +0000109# Specify options to pass to configure script when we're
110# running the dist-check target
111DIST_CHECK_CONFIG_OPTIONS = --with-llvmgccdir=$(LLVMGCCDIR)
112
Reid Spencer33478272004-11-25 09:08:54 +0000113.PHONY: debug-opt-prof
114debug-opt-prof:
115 $(Echo) Building Debug Version
116 $(Verb) $(MAKE)
117 $(Echo)
118 $(Echo) Building Optimized Version
119 $(Echo)
120 $(Verb) $(MAKE) ENABLE_OPTIMIZED=1
121 $(Echo)
122 $(Echo) Building Profiling Version
123 $(Echo)
124 $(Verb) $(MAKE) ENABLE_PROFILING=1
125
Reid Spencer100080c2004-10-25 08:27:37 +0000126dist-hook::
Reid Spencerf88808a2004-10-30 09:19:36 +0000127 $(Echo) Eliminating files constructed by configure
128 $(Verb) $(RM) -f \
Reid Spencer4a9b5ff2004-10-26 07:05:09 +0000129 $(TopDistDir)/include/llvm/Config/config.h \
130 $(TopDistDir)/include/llvm/Support/DataTypes.h \
131 $(TopDistDir)/include/llvm/Support/ThreadSupport.h
Reid Spencer100080c2004-10-25 08:27:37 +0000132
Mike Stumpeb1e2002009-01-19 19:48:23 +0000133clang-only: all
Chris Lattner6bd75a62004-02-03 22:56:40 +0000134tools-only: all
Reid Spencerfec4f802005-05-25 21:03:17 +0000135libs-only: all
Mike Stumpeb1e2002009-01-19 19:48:23 +0000136install-clang: install
Nate Begeman938d8cb2007-12-13 02:17:17 +0000137install-libs: install
Reid Spencer53846bc2005-08-25 04:59:49 +0000138
139#------------------------------------------------------------------------
140# Make sure the generated headers are up-to-date. This must be kept in
141# sync with the AC_CONFIG_HEADER invocations in autoconf/configure.ac
142#------------------------------------------------------------------------
143FilesToConfig := \
144 include/llvm/Config/config.h \
Douglas Gregor1b731d52009-06-16 20:12:29 +0000145 include/llvm/Config/Targets.def \
146 include/llvm/Config/AsmPrinters.def \
Gabor Greif962c3742009-08-27 17:07:35 +0000147 include/llvm/Support/DataTypes.h
Reid Spencer53846bc2005-08-25 04:59:49 +0000148FilesToConfigPATH := $(addprefix $(LLVM_OBJ_ROOT)/,$(FilesToConfig))
149
150all-local:: $(FilesToConfigPATH)
Misha Brukman2879c292009-01-08 02:11:55 +0000151$(FilesToConfigPATH) : $(LLVM_OBJ_ROOT)/% : $(LLVM_SRC_ROOT)/%.in
Reid Spencer53846bc2005-08-25 04:59:49 +0000152 $(Echo) Regenerating $*
153 $(Verb) cd $(LLVM_OBJ_ROOT) && $(ConfigStatusScript) $*
154.PRECIOUS: $(FilesToConfigPATH)
Reid Spencer754cfec2006-04-07 15:58:18 +0000155
Chris Lattnere690a932006-04-07 16:21:59 +0000156# NOTE: This needs to remain as the last target definition in this file so
157# that it gets executed last.
Anton Korobeynikov8e58c522008-11-10 07:33:13 +0000158ifneq ($(BUILD_DIRS_ONLY),1)
Misha Brukman2879c292009-01-08 02:11:55 +0000159all::
Reid Spencer754cfec2006-04-07 15:58:18 +0000160 $(Echo) '*****' Completed $(BuildMode)$(AssertMode) Build
161ifeq ($(BuildMode),Debug)
162 $(Echo) '*****' Note: Debug build can be 10 times slower than an
163 $(Echo) '*****' optimized build. Use 'make ENABLE_OPTIMIZED=1' to
Gabor Greif76e70832008-02-28 11:48:14 +0000164 $(Echo) '*****' make an optimized build. Alternatively you can
165 $(Echo) '*****' configure with --enable-optimized.
Reid Spencer754cfec2006-04-07 15:58:18 +0000166endif
Anton Korobeynikov8e58c522008-11-10 07:33:13 +0000167endif
Chris Lattnere690a932006-04-07 16:21:59 +0000168
Reid Spencer9c226202006-06-01 07:27:53 +0000169check-llvm2cpp:
Reid Spencer6d4a4172007-04-15 06:22:48 +0000170 $(Verb)$(MAKE) check TESTSUITE=Feature RUNLLVM2CPP=1
Chris Lattnerb85c3252006-07-26 19:10:34 +0000171
Reid Spencera9482c82007-04-15 06:18:50 +0000172check-one:
Reid Spencer6d4a4172007-04-15 06:22:48 +0000173 $(Verb)$(MAKE) -C test check-one TESTONE=$(TESTONE)
Reid Spencera9482c82007-04-15 06:18:50 +0000174
Misha Brukman2879c292009-01-08 02:11:55 +0000175srpm: $(LLVM_OBJ_ROOT)/llvm.spec
Reid Spencerd14c6ca2006-08-16 00:43:50 +0000176 rpmbuild -bs $(LLVM_OBJ_ROOT)/llvm.spec
177
Misha Brukman2879c292009-01-08 02:11:55 +0000178rpm: $(LLVM_OBJ_ROOT)/llvm.spec
Reid Spencerd14c6ca2006-08-16 00:43:50 +0000179 rpmbuild -bb --target $(TARGET_TRIPLE) $(LLVM_OBJ_ROOT)/llvm.spec
180
Reid Spencer99a1e6b2007-02-05 23:18:58 +0000181show-footprint:
182 $(Verb) du -sk $(LibDir)
183 $(Verb) du -sk $(ToolDir)
184 $(Verb) du -sk $(ExmplDir)
185 $(Verb) du -sk $(ObjDir)
186
Reid Spencer64a26222007-07-08 03:50:22 +0000187build-for-llvm-top:
188 $(Verb) if test ! -f ./config.status ; then \
189 ./configure --prefix="$(LLVM_TOP)/install" \
190 --with-llvm-gcc="$(LLVM_TOP)/llvm-gcc" ; \
191 fi
192 $(Verb) $(MAKE) tools-only
193
Gabor Greifd71b4102008-02-28 13:06:50 +0000194SVN = svn
Gabor Greif376d2ce2008-02-28 14:58:14 +0000195SVN-UPDATE-OPTIONS =
Gabor Greifd71b4102008-02-28 13:06:50 +0000196AWK = awk
Gabor Greifa6e293a2008-02-28 18:46:56 +0000197SUB-SVN-DIRS = $(AWK) '/\?\ \ \ \ \ \ / {print $$2}' \
Gabor Greif33e834c2009-04-24 17:00:03 +0000198 | LC_ALL=C xargs $(SVN) info 2>/dev/null \
Gabor Greifa6e293a2008-02-28 18:46:56 +0000199 | $(AWK) '/Path:\ / {print $$2}'
Gabor Greifd71b4102008-02-28 13:06:50 +0000200
201update:
Gabor Greifa6c5b382008-03-21 22:17:07 +0000202 $(SVN) $(SVN-UPDATE-OPTIONS) update $(LLVM_SRC_ROOT)
203 @ $(SVN) status $(LLVM_SRC_ROOT) | $(SUB-SVN-DIRS) | xargs $(SVN) $(SVN-UPDATE-OPTIONS) update
Gabor Greifd71b4102008-02-28 13:06:50 +0000204
Bill Wendling8790e322009-01-04 23:12:21 +0000205happiness: update all check unittests
Gabor Greifd71b4102008-02-28 13:06:50 +0000206
207.PHONY: srpm rpm update happiness
Reid Spencer64a26222007-07-08 03:50:22 +0000208
Gabor Greif76e70832008-02-28 11:48:14 +0000209# declare all targets at this level to be serial:
210
211.NOTPARALLEL:
212