blob: f7642d6164bb26c68a609260cec21efa8792900c [file] [log] [blame]
Misha Brukman6d5ab862004-04-24 00:10:56 +00001#===- ./Makefile -------------------------------------------*- Makefile -*--===#
Misha Brukmanef5dc702009-01-08 02:11:55 +00002#
John Criswelle488e932003-10-20 22:26:57 +00003# The LLVM Compiler Infrastructure
4#
Chris Lattner57360d12007-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 Brukmanef5dc702009-01-08 02:11:55 +00007#
Misha Brukman6d5ab862004-04-24 00:10:56 +00008#===------------------------------------------------------------------------===#
Chris Lattner22033b22006-06-02 22:41:18 +00009
Chris Lattner5720be42006-07-26 19:10:34 +000010LEVEL := .
Chris Lattner87b51012006-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 Spencer8b2e1412006-11-17 03:32:33 +000018# 6. Build tools, runtime, docs.
Chris Lattner87b51012006-09-04 04:27:07 +000019#
Anton Korobeynikov569c45c2008-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 \
27 tools runtime docs
28 OPTIONAL_DIRS := examples projects bindings
29endif
David Greenedf93e572007-07-11 23:44:08 +000030
Misha Brukman8fb520e2009-01-01 02:24:48 +000031EXTRA_DIST := test unittests llvm.spec include win32 Xcode
Chris Lattner00950542001-06-06 20:29:01 +000032
Misha Brukmanef5dc702009-01-08 02:11:55 +000033include $(LEVEL)/Makefile.config
Reid Spencer93bc3cd2006-04-06 22:15:51 +000034
Chris Lattnerc6b66eb2007-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)
Reid Spencer8b2e1412006-11-17 03:32:33 +000039 DIRS := $(filter-out runtime, $(DIRS))
Chris Lattnerc6b66eb2007-03-29 18:14:00 +000040#endif
Reid Spencer8b2e1412006-11-17 03:32:33 +000041
Chris Lattner5720be42006-07-26 19:10:34 +000042ifeq ($(MAKECMDGOALS),libs-only)
Reid Spencer8b2e1412006-11-17 03:32:33 +000043 DIRS := $(filter-out tools runtime docs, $(DIRS))
Chris Lattner22033b22006-06-02 22:41:18 +000044 OPTIONAL_DIRS :=
45endif
46
Nate Begeman544f83d2007-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 Lattner5720be42006-07-26 19:10:34 +000052ifeq ($(MAKECMDGOALS),tools-only)
Reid Spencer8b2e1412006-11-17 03:32:33 +000053 DIRS := $(filter-out runtime docs, $(DIRS))
Chris Lattner5720be42006-07-26 19:10:34 +000054 OPTIONAL_DIRS :=
55endif
Chris Lattner22033b22006-06-02 22:41:18 +000056
Misha Brukman8fb520e2009-01-01 02:24:48 +000057ifeq ($(MAKECMDGOALS),unittests)
58 DIRS := $(filter-out tools runtime docs, $(DIRS)) utils unittests
59 OPTIONAL_DIRS :=
60endif
61
Misha Brukmanef5dc702009-01-08 02:11:55 +000062# Don't install utils, examples, or projects they are only used to
Chris Lattner122c0552007-02-21 06:23:20 +000063# build LLVM.
64ifeq ($(MAKECMDGOALS),install)
65 DIRS := $(filter-out utils, $(DIRS))
Gordon Henriksen8ef426b2007-09-18 12:49:39 +000066 OPTIONAL_DIRS := $(filter bindings, $(OPTIONAL_DIRS))
Chris Lattner122c0552007-02-21 06:23:20 +000067endif
68
Anton Korobeynikov569c45c2008-11-10 07:33:13 +000069# If we're cross-compiling, build the build-hosted tools first
70ifeq ($(LLVM_CROSS_COMPILING),1)
71all:: cross-compile-build-tools
72
73clean::
74 $(Verb) rm -rf BuildTools
75
76cross-compile-build-tools:
77 $(Verb) if [ ! -f BuildTools/Makefile ]; then \
78 $(MKDIR) BuildTools; \
79 cd BuildTools ; \
80 $(PROJ_SRC_DIR)/configure ; \
81 cd .. ; \
82 fi; \
83 ($(MAKE) -C BuildTools BUILD_DIRS_ONLY=1 ) || exit 1;
84endif
85
Chris Lattner22033b22006-06-02 22:41:18 +000086# Include the main makefile machinery.
Reid Spencer06a801a2006-04-08 02:14:37 +000087include $(LLVM_SRC_ROOT)/Makefile.rules
88
Reid Spencer45eeed92005-05-24 02:33:20 +000089# Specify options to pass to configure script when we're
90# running the dist-check target
91DIST_CHECK_CONFIG_OPTIONS = --with-llvmgccdir=$(LLVMGCCDIR)
92
Reid Spencerdf561f42004-11-25 09:08:54 +000093.PHONY: debug-opt-prof
94debug-opt-prof:
95 $(Echo) Building Debug Version
96 $(Verb) $(MAKE)
97 $(Echo)
98 $(Echo) Building Optimized Version
99 $(Echo)
100 $(Verb) $(MAKE) ENABLE_OPTIMIZED=1
101 $(Echo)
102 $(Echo) Building Profiling Version
103 $(Echo)
104 $(Verb) $(MAKE) ENABLE_PROFILING=1
105
Reid Spencer151f8ba2004-10-25 08:27:37 +0000106dist-hook::
Reid Spencercc2d1e22004-10-30 09:19:36 +0000107 $(Echo) Eliminating files constructed by configure
108 $(Verb) $(RM) -f \
Anton Korobeynikov43d1fd42008-05-29 17:41:17 +0000109 $(TopDistDir)/include/llvm/ADT/hash_map.h \
110 $(TopDistDir)/include/llvm/ADT/hash_set.h \
111 $(TopDistDir)/include/llvm/ADT/iterator.h \
Reid Spencer90c29492004-10-26 07:05:09 +0000112 $(TopDistDir)/include/llvm/Config/config.h \
113 $(TopDistDir)/include/llvm/Support/DataTypes.h \
114 $(TopDistDir)/include/llvm/Support/ThreadSupport.h
Reid Spencer151f8ba2004-10-25 08:27:37 +0000115
Chris Lattner9cf662b2004-02-03 22:56:40 +0000116tools-only: all
Reid Spencer8b1f7672005-05-25 21:03:17 +0000117libs-only: all
Nate Begeman544f83d2007-12-13 02:17:17 +0000118install-libs: install
Reid Spencerca739c62005-08-25 04:59:49 +0000119
120#------------------------------------------------------------------------
121# Make sure the generated headers are up-to-date. This must be kept in
122# sync with the AC_CONFIG_HEADER invocations in autoconf/configure.ac
123#------------------------------------------------------------------------
124FilesToConfig := \
125 include/llvm/Config/config.h \
126 include/llvm/Support/DataTypes.h \
Anton Korobeynikov43d1fd42008-05-29 17:41:17 +0000127 include/llvm/ADT/hash_map.h \
128 include/llvm/ADT/hash_set.h \
129 include/llvm/ADT/iterator.h
Reid Spencerca739c62005-08-25 04:59:49 +0000130FilesToConfigPATH := $(addprefix $(LLVM_OBJ_ROOT)/,$(FilesToConfig))
131
132all-local:: $(FilesToConfigPATH)
Misha Brukmanef5dc702009-01-08 02:11:55 +0000133$(FilesToConfigPATH) : $(LLVM_OBJ_ROOT)/% : $(LLVM_SRC_ROOT)/%.in
Reid Spencerca739c62005-08-25 04:59:49 +0000134 $(Echo) Regenerating $*
135 $(Verb) cd $(LLVM_OBJ_ROOT) && $(ConfigStatusScript) $*
136.PRECIOUS: $(FilesToConfigPATH)
Reid Spencere22f3c02006-04-07 15:58:18 +0000137
Chris Lattner38ab6d82006-04-07 16:21:59 +0000138# NOTE: This needs to remain as the last target definition in this file so
139# that it gets executed last.
Anton Korobeynikov569c45c2008-11-10 07:33:13 +0000140ifneq ($(BUILD_DIRS_ONLY),1)
Misha Brukmanef5dc702009-01-08 02:11:55 +0000141all::
Reid Spencere22f3c02006-04-07 15:58:18 +0000142 $(Echo) '*****' Completed $(BuildMode)$(AssertMode) Build
143ifeq ($(BuildMode),Debug)
144 $(Echo) '*****' Note: Debug build can be 10 times slower than an
145 $(Echo) '*****' optimized build. Use 'make ENABLE_OPTIMIZED=1' to
Gabor Greif2ae19552008-02-28 11:48:14 +0000146 $(Echo) '*****' make an optimized build. Alternatively you can
147 $(Echo) '*****' configure with --enable-optimized.
Reid Spencere22f3c02006-04-07 15:58:18 +0000148endif
Anton Korobeynikov569c45c2008-11-10 07:33:13 +0000149endif
Chris Lattner38ab6d82006-04-07 16:21:59 +0000150
Reid Spencer5b30ee12006-06-01 07:27:53 +0000151check-llvm2cpp:
Reid Spencer42f98e52007-04-15 06:22:48 +0000152 $(Verb)$(MAKE) check TESTSUITE=Feature RUNLLVM2CPP=1
Chris Lattner5720be42006-07-26 19:10:34 +0000153
Reid Spencer9df55612007-04-15 06:18:50 +0000154check-one:
Reid Spencer42f98e52007-04-15 06:22:48 +0000155 $(Verb)$(MAKE) -C test check-one TESTONE=$(TESTONE)
Reid Spencer9df55612007-04-15 06:18:50 +0000156
Misha Brukmanef5dc702009-01-08 02:11:55 +0000157srpm: $(LLVM_OBJ_ROOT)/llvm.spec
Reid Spencerf7c75a62006-08-16 00:43:50 +0000158 rpmbuild -bs $(LLVM_OBJ_ROOT)/llvm.spec
159
Misha Brukmanef5dc702009-01-08 02:11:55 +0000160rpm: $(LLVM_OBJ_ROOT)/llvm.spec
Reid Spencerf7c75a62006-08-16 00:43:50 +0000161 rpmbuild -bb --target $(TARGET_TRIPLE) $(LLVM_OBJ_ROOT)/llvm.spec
162
Reid Spencer1e46ae42007-02-05 23:18:58 +0000163show-footprint:
164 $(Verb) du -sk $(LibDir)
165 $(Verb) du -sk $(ToolDir)
166 $(Verb) du -sk $(ExmplDir)
167 $(Verb) du -sk $(ObjDir)
168
Reid Spencer51cf6422007-07-08 03:50:22 +0000169build-for-llvm-top:
170 $(Verb) if test ! -f ./config.status ; then \
171 ./configure --prefix="$(LLVM_TOP)/install" \
172 --with-llvm-gcc="$(LLVM_TOP)/llvm-gcc" ; \
173 fi
174 $(Verb) $(MAKE) tools-only
175
Gabor Greif1d7ca712008-02-28 13:06:50 +0000176SVN = svn
Gabor Greif9fa42262008-02-28 14:58:14 +0000177SVN-UPDATE-OPTIONS =
Gabor Greif1d7ca712008-02-28 13:06:50 +0000178AWK = awk
Gabor Greifa4a03232008-02-28 18:46:56 +0000179SUB-SVN-DIRS = $(AWK) '/\?\ \ \ \ \ \ / {print $$2}' \
180 | LANG=C xargs $(SVN) info 2>/dev/null \
181 | $(AWK) '/Path:\ / {print $$2}'
Gabor Greif1d7ca712008-02-28 13:06:50 +0000182
183update:
Gabor Greif8e0c20b2008-03-21 22:17:07 +0000184 $(SVN) $(SVN-UPDATE-OPTIONS) update $(LLVM_SRC_ROOT)
185 @ $(SVN) status $(LLVM_SRC_ROOT) | $(SUB-SVN-DIRS) | xargs $(SVN) $(SVN-UPDATE-OPTIONS) update
Gabor Greif1d7ca712008-02-28 13:06:50 +0000186
Bill Wendling4113bd12009-01-04 23:12:21 +0000187happiness: update all check unittests
Gabor Greif1d7ca712008-02-28 13:06:50 +0000188
189.PHONY: srpm rpm update happiness
Reid Spencer51cf6422007-07-08 03:50:22 +0000190
Gabor Greif2ae19552008-02-28 11:48:14 +0000191# declare all targets at this level to be serial:
192
193.NOTPARALLEL:
194