blob: 79fb043a8ccbe65dfa435f8ceeab0350b9c7e024 [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:
Peter Collingbourne84c287e2011-10-01 16:41:13 +000013# 1. Build lib/Support and lib/TableGen, which are used by utils (tblgen).
Chris Lattner31b4aa52006-09-04 04:27:07 +000014# 2. Build utils, which is used by VMCore.
15# 3. Build VMCore, which builds the Intrinsics.inc file used by libs.
Daniel Dunbar933b43f2011-11-10 19:59:35 +000016# 4. Build libs, which are needed by llvm-config.
17# 5. Build llvm-config, which determines inter-lib dependencies for tools.
18# 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.
Stuart Hastings8de31d02009-10-22 17:22:37 +000022
23# If "RC_ProjectName" exists in the environment, and its value is
24# "llvmCore", then this is an "Apple-style" build; search for
25# "Apple-style" in the comments for more info. Anything else is a
26# normal build.
Jim Grosbachad637e92009-10-30 19:51:32 +000027ifneq ($(findstring llvmCore, $(RC_ProjectName)),llvmCore) # Normal build (not "Apple-style").
28
Anton Korobeynikov8e58c522008-11-10 07:33:13 +000029ifeq ($(BUILD_DIRS_ONLY),1)
Daniel Dunbar8d5cc332011-11-29 22:56:31 +000030 DIRS := lib/Support lib/TableGen utils tools/llvm-config
Peter Collingbourne6ddf7f42011-10-08 00:27:38 +000031 OPTIONAL_DIRS := tools/clang/utils/TableGen
Anton Korobeynikov8e58c522008-11-10 07:33:13 +000032else
Peter Collingbourne84c287e2011-10-01 16:41:13 +000033 DIRS := lib/Support lib/TableGen utils lib/VMCore lib tools/llvm-shlib \
Daniel Dunbar8d5cc332011-11-29 22:56:31 +000034 tools/llvm-config tools runtime docs unittests
Daniel Dunbar1aab2de2009-11-16 22:38:00 +000035 OPTIONAL_DIRS := projects bindings
36endif
37
38ifeq ($(BUILD_EXAMPLES),1)
39 OPTIONAL_DIRS += examples
Anton Korobeynikov8e58c522008-11-10 07:33:13 +000040endif
David Greeneb2e2be42007-07-11 23:44:08 +000041
Misha Brukmanbcf15382009-01-01 02:24:48 +000042EXTRA_DIST := test unittests llvm.spec include win32 Xcode
Chris Lattner2f7c9632001-06-06 20:29:01 +000043
Misha Brukman2879c292009-01-08 02:11:55 +000044include $(LEVEL)/Makefile.config
Reid Spenceraed84e42006-04-06 22:15:51 +000045
Jeffrey Yasskin6b718f72010-02-25 06:34:33 +000046ifneq ($(ENABLE_SHARED),1)
47 DIRS := $(filter-out tools/llvm-shlib, $(DIRS))
48endif
49
Rafael Espindola7ac506d2010-11-12 19:24:06 +000050ifneq ($(ENABLE_DOCS),1)
51 DIRS := $(filter-out docs, $(DIRS))
52endif
53
Chris Lattnerb85c3252006-07-26 19:10:34 +000054ifeq ($(MAKECMDGOALS),libs-only)
Reid Spencer4b8067f2006-11-17 03:32:33 +000055 DIRS := $(filter-out tools runtime docs, $(DIRS))
Chris Lattner2ad80c22006-06-02 22:41:18 +000056 OPTIONAL_DIRS :=
57endif
58
Nate Begeman938d8cb2007-12-13 02:17:17 +000059ifeq ($(MAKECMDGOALS),install-libs)
60 DIRS := $(filter-out tools runtime docs, $(DIRS))
61 OPTIONAL_DIRS := $(filter bindings, $(OPTIONAL_DIRS))
62endif
63
Chris Lattnerb85c3252006-07-26 19:10:34 +000064ifeq ($(MAKECMDGOALS),tools-only)
Reid Spencer4b8067f2006-11-17 03:32:33 +000065 DIRS := $(filter-out runtime docs, $(DIRS))
Chris Lattnerb85c3252006-07-26 19:10:34 +000066 OPTIONAL_DIRS :=
67endif
Chris Lattner2ad80c22006-06-02 22:41:18 +000068
Mike Stumpeb1e2002009-01-19 19:48:23 +000069ifeq ($(MAKECMDGOALS),install-clang)
Daniel Dunbare43fe7c2010-01-20 00:43:07 +000070 DIRS := tools/clang/tools/driver tools/clang/lib/Headers \
Bob Wilson4eefd2d2011-11-27 00:26:22 +000071 tools/clang/tools/libclang tools/clang/tools/c-index-test \
72 tools/clang/include/clang-c \
Daniel Dunbarc88e2cc2010-07-16 01:29:50 +000073 tools/clang/runtime tools/clang/docs \
Bill Wendlingc51d3342011-06-10 21:47:14 +000074 tools/lto runtime
Mike Stumpeb1e2002009-01-19 19:48:23 +000075 OPTIONAL_DIRS :=
76 NO_INSTALL = 1
77endif
78
Bob Wilson8e6d9da2011-11-27 01:48:54 +000079ifeq ($(MAKECMDGOALS),install-clang-c)
80 DIRS := tools/clang/tools/driver tools/clang/lib/Headers \
81 tools/clang/tools/libclang tools/clang/tools/c-index-test \
82 tools/clang/include/clang-c
83 OPTIONAL_DIRS :=
84 NO_INSTALL = 1
85endif
86
Mike Stumpeb1e2002009-01-19 19:48:23 +000087ifeq ($(MAKECMDGOALS),clang-only)
Bill Wendlingc51d3342011-06-10 21:47:14 +000088 DIRS := $(filter-out tools docs unittests, $(DIRS)) \
Daniel Dunbarc88e2cc2010-07-16 01:29:50 +000089 tools/clang tools/lto
Mike Stumpeb1e2002009-01-19 19:48:23 +000090 OPTIONAL_DIRS :=
91endif
92
Misha Brukmanbcf15382009-01-01 02:24:48 +000093ifeq ($(MAKECMDGOALS),unittests)
94 DIRS := $(filter-out tools runtime docs, $(DIRS)) utils unittests
95 OPTIONAL_DIRS :=
96endif
97
Chris Lattner8bbd76b2009-05-08 17:32:47 +000098# Use NO_INSTALL define of the Makefile of each directory for deciding
99# if the directory is installed or not
Chris Lattner31f99b92007-02-21 06:23:20 +0000100ifeq ($(MAKECMDGOALS),install)
Gordon Henriksen37582f72007-09-18 12:49:39 +0000101 OPTIONAL_DIRS := $(filter bindings, $(OPTIONAL_DIRS))
Chris Lattner31f99b92007-02-21 06:23:20 +0000102endif
103
Daniel Dunbar795ab9b2010-11-27 06:59:16 +0000104# Don't build unittests when ONLY_TOOLS is set.
105ifneq ($(ONLY_TOOLS),)
106 DIRS := $(filter-out unittests, $(DIRS))
107endif
108
Anton Korobeynikov8e58c522008-11-10 07:33:13 +0000109# If we're cross-compiling, build the build-hosted tools first
110ifeq ($(LLVM_CROSS_COMPILING),1)
111all:: cross-compile-build-tools
112
113clean::
114 $(Verb) rm -rf BuildTools
115
116cross-compile-build-tools:
117 $(Verb) if [ ! -f BuildTools/Makefile ]; then \
118 $(MKDIR) BuildTools; \
119 cd BuildTools ; \
Jim Grosbach885fdd32009-10-30 19:53:38 +0000120 unset CFLAGS ; \
121 unset CXXFLAGS ; \
Shantonu Sen96995e82009-09-02 23:52:23 +0000122 $(PROJ_SRC_DIR)/configure --build=$(BUILD_TRIPLE) \
Peter Collingbourne6ddf7f42011-10-08 00:27:38 +0000123 --host=$(BUILD_TRIPLE) --target=$(BUILD_TRIPLE) \
124 --disable-polly ; \
Anton Korobeynikov8e58c522008-11-10 07:33:13 +0000125 cd .. ; \
126 fi; \
Bob Wilsonebcadde2010-07-20 20:44:02 +0000127 (unset SDKROOT; \
128 $(MAKE) -C BuildTools \
Shantonu Sen96995e82009-09-02 23:52:23 +0000129 BUILD_DIRS_ONLY=1 \
130 UNIVERSAL= \
Daniel Dunbar48032f92011-11-12 00:18:02 +0000131 TARGET_NATIVE_ARCH="$(TARGET_NATIVE_ARCH)" \
Daniel Dunbar94f3c542011-11-11 22:59:45 +0000132 TARGETS_TO_BUILD="$(TARGETS_TO_BUILD)" \
Shantonu Sen96995e82009-09-02 23:52:23 +0000133 ENABLE_OPTIMIZED=$(ENABLE_OPTIMIZED) \
134 ENABLE_PROFILING=$(ENABLE_PROFILING) \
135 ENABLE_COVERAGE=$(ENABLE_COVERAGE) \
136 DISABLE_ASSERTIONS=$(DISABLE_ASSERTIONS) \
137 ENABLE_EXPENSIVE_CHECKS=$(ENABLE_EXPENSIVE_CHECKS) \
Eric Christopher1094ded2011-11-11 22:51:42 +0000138 ENABLE_LIBCPP=$(ENABLE_LIBCPP) \
Jim Grosbache8421402010-04-24 00:46:14 +0000139 CFLAGS= \
140 CXXFLAGS= \
Shantonu Sen96995e82009-09-02 23:52:23 +0000141 ) || exit 1;
Anton Korobeynikov8e58c522008-11-10 07:33:13 +0000142endif
143
Chris Lattner2ad80c22006-06-02 22:41:18 +0000144# Include the main makefile machinery.
Reid Spencer8ac50622006-04-08 02:14:37 +0000145include $(LLVM_SRC_ROOT)/Makefile.rules
146
Reid Spencer13f51932005-05-24 02:33:20 +0000147# Specify options to pass to configure script when we're
148# running the dist-check target
149DIST_CHECK_CONFIG_OPTIONS = --with-llvmgccdir=$(LLVMGCCDIR)
150
Reid Spencer33478272004-11-25 09:08:54 +0000151.PHONY: debug-opt-prof
152debug-opt-prof:
153 $(Echo) Building Debug Version
154 $(Verb) $(MAKE)
155 $(Echo)
156 $(Echo) Building Optimized Version
157 $(Echo)
158 $(Verb) $(MAKE) ENABLE_OPTIMIZED=1
159 $(Echo)
160 $(Echo) Building Profiling Version
161 $(Echo)
162 $(Verb) $(MAKE) ENABLE_PROFILING=1
163
Reid Spencer100080c2004-10-25 08:27:37 +0000164dist-hook::
Reid Spencerf88808a2004-10-30 09:19:36 +0000165 $(Echo) Eliminating files constructed by configure
166 $(Verb) $(RM) -f \
Reid Spencer4a9b5ff2004-10-26 07:05:09 +0000167 $(TopDistDir)/include/llvm/Config/config.h \
Michael J. Spencer447762d2010-11-29 18:16:10 +0000168 $(TopDistDir)/include/llvm/Support/DataTypes.h
Reid Spencer100080c2004-10-25 08:27:37 +0000169
Mike Stumpeb1e2002009-01-19 19:48:23 +0000170clang-only: all
Chris Lattner6bd75a62004-02-03 22:56:40 +0000171tools-only: all
Reid Spencerfec4f802005-05-25 21:03:17 +0000172libs-only: all
Mike Stumpeb1e2002009-01-19 19:48:23 +0000173install-clang: install
Bob Wilson8e6d9da2011-11-27 01:48:54 +0000174install-clang-c: install
Nate Begeman938d8cb2007-12-13 02:17:17 +0000175install-libs: install
Reid Spencer53846bc2005-08-25 04:59:49 +0000176
Daniel Dunbar0625b1f2011-04-11 22:37:39 +0000177# If SHOW_DIAGNOSTICS is enabled, clear the diagnostics file first.
178ifeq ($(SHOW_DIAGNOSTICS),1)
179clean-diagnostics:
180 $(Verb) rm -f $(LLVM_OBJ_ROOT)/$(BuildMode)/diags
181.PHONY: clean-diagnostics
182
183all-local:: clean-diagnostics
184endif
185
Reid Spencer53846bc2005-08-25 04:59:49 +0000186#------------------------------------------------------------------------
187# Make sure the generated headers are up-to-date. This must be kept in
188# sync with the AC_CONFIG_HEADER invocations in autoconf/configure.ac
189#------------------------------------------------------------------------
190FilesToConfig := \
191 include/llvm/Config/config.h \
Douglas Gregor1b731d52009-06-16 20:12:29 +0000192 include/llvm/Config/Targets.def \
Daniel Dunbare8b8cce2009-11-25 04:46:58 +0000193 include/llvm/Config/AsmPrinters.def \
194 include/llvm/Config/AsmParsers.def \
195 include/llvm/Config/Disassemblers.def \
Eric Christopher4b0ae482011-09-19 23:22:41 +0000196 include/llvm/Support/DataTypes.h
Reid Spencer53846bc2005-08-25 04:59:49 +0000197FilesToConfigPATH := $(addprefix $(LLVM_OBJ_ROOT)/,$(FilesToConfig))
198
199all-local:: $(FilesToConfigPATH)
Misha Brukman2879c292009-01-08 02:11:55 +0000200$(FilesToConfigPATH) : $(LLVM_OBJ_ROOT)/% : $(LLVM_SRC_ROOT)/%.in
Reid Spencer53846bc2005-08-25 04:59:49 +0000201 $(Echo) Regenerating $*
202 $(Verb) cd $(LLVM_OBJ_ROOT) && $(ConfigStatusScript) $*
203.PRECIOUS: $(FilesToConfigPATH)
Reid Spencer754cfec2006-04-07 15:58:18 +0000204
Chris Lattnere690a932006-04-07 16:21:59 +0000205# NOTE: This needs to remain as the last target definition in this file so
206# that it gets executed last.
Anton Korobeynikov8e58c522008-11-10 07:33:13 +0000207ifneq ($(BUILD_DIRS_ONLY),1)
Misha Brukman2879c292009-01-08 02:11:55 +0000208all::
Duncan Sands408bb192010-07-07 07:48:00 +0000209 $(Echo) '*****' Completed $(BuildMode) Build
Duncan Sands24556942010-07-07 16:48:16 +0000210ifneq ($(ENABLE_OPTIMIZED),1)
Reid Spencer754cfec2006-04-07 15:58:18 +0000211 $(Echo) '*****' Note: Debug build can be 10 times slower than an
212 $(Echo) '*****' optimized build. Use 'make ENABLE_OPTIMIZED=1' to
Gabor Greif76e70832008-02-28 11:48:14 +0000213 $(Echo) '*****' make an optimized build. Alternatively you can
214 $(Echo) '*****' configure with --enable-optimized.
Daniel Dunbar0625b1f2011-04-11 22:37:39 +0000215ifeq ($(SHOW_DIAGNOSTICS),1)
216 $(Verb) if test -s $(LLVM_OBJ_ROOT)/$(BuildMode)/diags; then \
Daniel Dunbar6c922232011-11-02 19:48:19 +0000217 $(LLVM_SRC_ROOT)/utils/clang-parse-diagnostics-file -a \
Daniel Dunbar0625b1f2011-04-11 22:37:39 +0000218 $(LLVM_OBJ_ROOT)/$(BuildMode)/diags; \
219 fi
220endif
Reid Spencer754cfec2006-04-07 15:58:18 +0000221endif
Anton Korobeynikov8e58c522008-11-10 07:33:13 +0000222endif
Chris Lattnere690a932006-04-07 16:21:59 +0000223
Reid Spencer9c226202006-06-01 07:27:53 +0000224check-llvm2cpp:
Reid Spencer6d4a4172007-04-15 06:22:48 +0000225 $(Verb)$(MAKE) check TESTSUITE=Feature RUNLLVM2CPP=1
Chris Lattnerb85c3252006-07-26 19:10:34 +0000226
Misha Brukman2879c292009-01-08 02:11:55 +0000227srpm: $(LLVM_OBJ_ROOT)/llvm.spec
Reid Spencerd14c6ca2006-08-16 00:43:50 +0000228 rpmbuild -bs $(LLVM_OBJ_ROOT)/llvm.spec
229
Misha Brukman2879c292009-01-08 02:11:55 +0000230rpm: $(LLVM_OBJ_ROOT)/llvm.spec
Reid Spencerd14c6ca2006-08-16 00:43:50 +0000231 rpmbuild -bb --target $(TARGET_TRIPLE) $(LLVM_OBJ_ROOT)/llvm.spec
232
Reid Spencer99a1e6b2007-02-05 23:18:58 +0000233show-footprint:
234 $(Verb) du -sk $(LibDir)
235 $(Verb) du -sk $(ToolDir)
236 $(Verb) du -sk $(ExmplDir)
237 $(Verb) du -sk $(ObjDir)
238
Reid Spencer64a26222007-07-08 03:50:22 +0000239build-for-llvm-top:
240 $(Verb) if test ! -f ./config.status ; then \
241 ./configure --prefix="$(LLVM_TOP)/install" \
242 --with-llvm-gcc="$(LLVM_TOP)/llvm-gcc" ; \
243 fi
244 $(Verb) $(MAKE) tools-only
245
Gabor Greifd71b4102008-02-28 13:06:50 +0000246SVN = svn
Gabor Greif376d2ce2008-02-28 14:58:14 +0000247SVN-UPDATE-OPTIONS =
Gabor Greifd71b4102008-02-28 13:06:50 +0000248AWK = awk
Gabor Greifa6e293a2008-02-28 18:46:56 +0000249SUB-SVN-DIRS = $(AWK) '/\?\ \ \ \ \ \ / {print $$2}' \
Gabor Greif33e834c2009-04-24 17:00:03 +0000250 | LC_ALL=C xargs $(SVN) info 2>/dev/null \
David Blaikie522b8942011-10-19 18:35:30 +0000251 | $(AWK) '/^Path:\ / {print $$2}'
Gabor Greifd71b4102008-02-28 13:06:50 +0000252
253update:
Gabor Greifa6c5b382008-03-21 22:17:07 +0000254 $(SVN) $(SVN-UPDATE-OPTIONS) update $(LLVM_SRC_ROOT)
255 @ $(SVN) status $(LLVM_SRC_ROOT) | $(SUB-SVN-DIRS) | xargs $(SVN) $(SVN-UPDATE-OPTIONS) update
Gabor Greifd71b4102008-02-28 13:06:50 +0000256
Gabor Greif9f228412010-03-21 22:23:02 +0000257happiness: update all check-all
Gabor Greifd71b4102008-02-28 13:06:50 +0000258
259.PHONY: srpm rpm update happiness
Reid Spencer64a26222007-07-08 03:50:22 +0000260
Gabor Greif76e70832008-02-28 11:48:14 +0000261# declare all targets at this level to be serial:
262
263.NOTPARALLEL:
264
Stuart Hastings8de31d02009-10-22 17:22:37 +0000265else # Building "Apple-style."
266# In an Apple-style build, once configuration is done, lines marked
267# "Apple-style" are removed with sed! Please don't remove these!
268# Look for the string "Apple-style" in utils/buildit/build_llvm.
269include $(shell find . -name GNUmakefile) # Building "Apple-style."
270endif # Building "Apple-style."