Misha Brukman | 6d5ab86 | 2004-04-24 00:10:56 +0000 | [diff] [blame] | 1 | #===- ./Makefile -------------------------------------------*- Makefile -*--===# |
Misha Brukman | ef5dc70 | 2009-01-08 02:11:55 +0000 | [diff] [blame] | 2 | # |
John Criswell | e488e93 | 2003-10-20 22:26:57 +0000 | [diff] [blame] | 3 | # The LLVM Compiler Infrastructure |
| 4 | # |
Chris Lattner | 57360d1 | 2007-12-29 20:11:13 +0000 | [diff] [blame] | 5 | # This file is distributed under the University of Illinois Open Source |
| 6 | # License. See LICENSE.TXT for details. |
Misha Brukman | ef5dc70 | 2009-01-08 02:11:55 +0000 | [diff] [blame] | 7 | # |
Misha Brukman | 6d5ab86 | 2004-04-24 00:10:56 +0000 | [diff] [blame] | 8 | #===------------------------------------------------------------------------===# |
Chris Lattner | 22033b2 | 2006-06-02 22:41:18 +0000 | [diff] [blame] | 9 | |
Chris Lattner | 5720be4 | 2006-07-26 19:10:34 +0000 | [diff] [blame] | 10 | LEVEL := . |
Chris Lattner | 87b5101 | 2006-09-04 04:27:07 +0000 | [diff] [blame] | 11 | |
| 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 Spencer | 8b2e141 | 2006-11-17 03:32:33 +0000 | [diff] [blame] | 18 | # 6. Build tools, runtime, docs. |
Chris Lattner | 87b5101 | 2006-09-04 04:27:07 +0000 | [diff] [blame] | 19 | # |
Anton Korobeynikov | 569c45c | 2008-11-10 07:33:13 +0000 | [diff] [blame] | 20 | # When cross-compiling, there are some things (tablegen) that need to |
| 21 | # be build for the build system first. |
Stuart Hastings | 4a53e1e | 2009-10-22 17:22:37 +0000 | [diff] [blame] | 22 | |
| 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 Grosbach | 2cdc80c | 2009-10-30 19:51:32 +0000 | [diff] [blame] | 27 | ifneq ($(findstring llvmCore, $(RC_ProjectName)),llvmCore) # Normal build (not "Apple-style"). |
| 28 | |
Anton Korobeynikov | 569c45c | 2008-11-10 07:33:13 +0000 | [diff] [blame] | 29 | ifeq ($(BUILD_DIRS_ONLY),1) |
| 30 | DIRS := lib/System lib/Support utils |
| 31 | OPTIONAL_DIRS := |
| 32 | else |
Jeffrey Yasskin | c901719 | 2010-02-25 06:34:33 +0000 | [diff] [blame] | 33 | DIRS := lib/System lib/Support utils lib/VMCore lib tools/llvm-shlib \ |
| 34 | tools/llvm-config tools runtime docs unittests |
Daniel Dunbar | da589a3 | 2009-11-16 22:38:00 +0000 | [diff] [blame] | 35 | OPTIONAL_DIRS := projects bindings |
| 36 | endif |
| 37 | |
| 38 | ifeq ($(BUILD_EXAMPLES),1) |
| 39 | OPTIONAL_DIRS += examples |
Anton Korobeynikov | 569c45c | 2008-11-10 07:33:13 +0000 | [diff] [blame] | 40 | endif |
David Greene | df93e57 | 2007-07-11 23:44:08 +0000 | [diff] [blame] | 41 | |
Misha Brukman | 8fb520e | 2009-01-01 02:24:48 +0000 | [diff] [blame] | 42 | EXTRA_DIST := test unittests llvm.spec include win32 Xcode |
Chris Lattner | 0095054 | 2001-06-06 20:29:01 +0000 | [diff] [blame] | 43 | |
Misha Brukman | ef5dc70 | 2009-01-08 02:11:55 +0000 | [diff] [blame] | 44 | include $(LEVEL)/Makefile.config |
Reid Spencer | 93bc3cd | 2006-04-06 22:15:51 +0000 | [diff] [blame] | 45 | |
Jeffrey Yasskin | c901719 | 2010-02-25 06:34:33 +0000 | [diff] [blame] | 46 | ifneq ($(ENABLE_SHARED),1) |
| 47 | DIRS := $(filter-out tools/llvm-shlib, $(DIRS)) |
| 48 | endif |
| 49 | |
Chris Lattner | 5720be4 | 2006-07-26 19:10:34 +0000 | [diff] [blame] | 50 | ifeq ($(MAKECMDGOALS),libs-only) |
Reid Spencer | 8b2e141 | 2006-11-17 03:32:33 +0000 | [diff] [blame] | 51 | DIRS := $(filter-out tools runtime docs, $(DIRS)) |
Chris Lattner | 22033b2 | 2006-06-02 22:41:18 +0000 | [diff] [blame] | 52 | OPTIONAL_DIRS := |
| 53 | endif |
| 54 | |
Nate Begeman | 544f83d | 2007-12-13 02:17:17 +0000 | [diff] [blame] | 55 | ifeq ($(MAKECMDGOALS),install-libs) |
| 56 | DIRS := $(filter-out tools runtime docs, $(DIRS)) |
| 57 | OPTIONAL_DIRS := $(filter bindings, $(OPTIONAL_DIRS)) |
| 58 | endif |
| 59 | |
Chris Lattner | 5720be4 | 2006-07-26 19:10:34 +0000 | [diff] [blame] | 60 | ifeq ($(MAKECMDGOALS),tools-only) |
Reid Spencer | 8b2e141 | 2006-11-17 03:32:33 +0000 | [diff] [blame] | 61 | DIRS := $(filter-out runtime docs, $(DIRS)) |
Chris Lattner | 5720be4 | 2006-07-26 19:10:34 +0000 | [diff] [blame] | 62 | OPTIONAL_DIRS := |
| 63 | endif |
Chris Lattner | 22033b2 | 2006-06-02 22:41:18 +0000 | [diff] [blame] | 64 | |
Mike Stump | b76ace3 | 2009-01-19 19:48:23 +0000 | [diff] [blame] | 65 | ifeq ($(MAKECMDGOALS),install-clang) |
Daniel Dunbar | 6b8dfed | 2010-01-20 00:43:07 +0000 | [diff] [blame] | 66 | DIRS := tools/clang/tools/driver tools/clang/lib/Headers \ |
| 67 | tools/clang/lib/Runtime tools/clang/docs |
Mike Stump | b76ace3 | 2009-01-19 19:48:23 +0000 | [diff] [blame] | 68 | OPTIONAL_DIRS := |
| 69 | NO_INSTALL = 1 |
| 70 | endif |
| 71 | |
| 72 | ifeq ($(MAKECMDGOALS),clang-only) |
Torok Edwin | 282098b | 2009-09-26 20:18:58 +0000 | [diff] [blame] | 73 | DIRS := $(filter-out tools runtime docs unittests, $(DIRS)) tools/clang |
Mike Stump | b76ace3 | 2009-01-19 19:48:23 +0000 | [diff] [blame] | 74 | OPTIONAL_DIRS := |
| 75 | endif |
| 76 | |
Misha Brukman | 8fb520e | 2009-01-01 02:24:48 +0000 | [diff] [blame] | 77 | ifeq ($(MAKECMDGOALS),unittests) |
| 78 | DIRS := $(filter-out tools runtime docs, $(DIRS)) utils unittests |
| 79 | OPTIONAL_DIRS := |
| 80 | endif |
| 81 | |
Chris Lattner | c891465 | 2009-05-08 17:32:47 +0000 | [diff] [blame] | 82 | # Use NO_INSTALL define of the Makefile of each directory for deciding |
| 83 | # if the directory is installed or not |
Chris Lattner | 122c055 | 2007-02-21 06:23:20 +0000 | [diff] [blame] | 84 | ifeq ($(MAKECMDGOALS),install) |
Gordon Henriksen | 8ef426b | 2007-09-18 12:49:39 +0000 | [diff] [blame] | 85 | OPTIONAL_DIRS := $(filter bindings, $(OPTIONAL_DIRS)) |
Chris Lattner | 122c055 | 2007-02-21 06:23:20 +0000 | [diff] [blame] | 86 | endif |
| 87 | |
Anton Korobeynikov | 569c45c | 2008-11-10 07:33:13 +0000 | [diff] [blame] | 88 | # If we're cross-compiling, build the build-hosted tools first |
| 89 | ifeq ($(LLVM_CROSS_COMPILING),1) |
| 90 | all:: cross-compile-build-tools |
| 91 | |
| 92 | clean:: |
| 93 | $(Verb) rm -rf BuildTools |
| 94 | |
| 95 | cross-compile-build-tools: |
| 96 | $(Verb) if [ ! -f BuildTools/Makefile ]; then \ |
| 97 | $(MKDIR) BuildTools; \ |
| 98 | cd BuildTools ; \ |
Jim Grosbach | 1f22d6f | 2009-10-30 19:53:38 +0000 | [diff] [blame] | 99 | unset CFLAGS ; \ |
| 100 | unset CXXFLAGS ; \ |
Shantonu Sen | 5e869c3 | 2009-09-02 23:52:23 +0000 | [diff] [blame] | 101 | $(PROJ_SRC_DIR)/configure --build=$(BUILD_TRIPLE) \ |
| 102 | --host=$(BUILD_TRIPLE) --target=$(BUILD_TRIPLE); \ |
Anton Korobeynikov | 569c45c | 2008-11-10 07:33:13 +0000 | [diff] [blame] | 103 | cd .. ; \ |
| 104 | fi; \ |
Shantonu Sen | 5e869c3 | 2009-09-02 23:52:23 +0000 | [diff] [blame] | 105 | ($(MAKE) -C BuildTools \ |
| 106 | BUILD_DIRS_ONLY=1 \ |
| 107 | UNIVERSAL= \ |
| 108 | ENABLE_OPTIMIZED=$(ENABLE_OPTIMIZED) \ |
| 109 | ENABLE_PROFILING=$(ENABLE_PROFILING) \ |
| 110 | ENABLE_COVERAGE=$(ENABLE_COVERAGE) \ |
| 111 | DISABLE_ASSERTIONS=$(DISABLE_ASSERTIONS) \ |
| 112 | ENABLE_EXPENSIVE_CHECKS=$(ENABLE_EXPENSIVE_CHECKS) \ |
| 113 | ) || exit 1; |
Anton Korobeynikov | 569c45c | 2008-11-10 07:33:13 +0000 | [diff] [blame] | 114 | endif |
| 115 | |
Chris Lattner | 22033b2 | 2006-06-02 22:41:18 +0000 | [diff] [blame] | 116 | # Include the main makefile machinery. |
Reid Spencer | 06a801a | 2006-04-08 02:14:37 +0000 | [diff] [blame] | 117 | include $(LLVM_SRC_ROOT)/Makefile.rules |
| 118 | |
Reid Spencer | 45eeed9 | 2005-05-24 02:33:20 +0000 | [diff] [blame] | 119 | # Specify options to pass to configure script when we're |
| 120 | # running the dist-check target |
| 121 | DIST_CHECK_CONFIG_OPTIONS = --with-llvmgccdir=$(LLVMGCCDIR) |
| 122 | |
Reid Spencer | df561f4 | 2004-11-25 09:08:54 +0000 | [diff] [blame] | 123 | .PHONY: debug-opt-prof |
| 124 | debug-opt-prof: |
| 125 | $(Echo) Building Debug Version |
| 126 | $(Verb) $(MAKE) |
| 127 | $(Echo) |
| 128 | $(Echo) Building Optimized Version |
| 129 | $(Echo) |
| 130 | $(Verb) $(MAKE) ENABLE_OPTIMIZED=1 |
| 131 | $(Echo) |
| 132 | $(Echo) Building Profiling Version |
| 133 | $(Echo) |
| 134 | $(Verb) $(MAKE) ENABLE_PROFILING=1 |
| 135 | |
Reid Spencer | 151f8ba | 2004-10-25 08:27:37 +0000 | [diff] [blame] | 136 | dist-hook:: |
Reid Spencer | cc2d1e2 | 2004-10-30 09:19:36 +0000 | [diff] [blame] | 137 | $(Echo) Eliminating files constructed by configure |
| 138 | $(Verb) $(RM) -f \ |
Reid Spencer | 90c2949 | 2004-10-26 07:05:09 +0000 | [diff] [blame] | 139 | $(TopDistDir)/include/llvm/Config/config.h \ |
Chandler Carruth | 8b67f77 | 2009-10-26 01:35:46 +0000 | [diff] [blame] | 140 | $(TopDistDir)/include/llvm/System/DataTypes.h |
Reid Spencer | 151f8ba | 2004-10-25 08:27:37 +0000 | [diff] [blame] | 141 | |
Mike Stump | b76ace3 | 2009-01-19 19:48:23 +0000 | [diff] [blame] | 142 | clang-only: all |
Chris Lattner | 9cf662b | 2004-02-03 22:56:40 +0000 | [diff] [blame] | 143 | tools-only: all |
Reid Spencer | 8b1f767 | 2005-05-25 21:03:17 +0000 | [diff] [blame] | 144 | libs-only: all |
Mike Stump | b76ace3 | 2009-01-19 19:48:23 +0000 | [diff] [blame] | 145 | install-clang: install |
Nate Begeman | 544f83d | 2007-12-13 02:17:17 +0000 | [diff] [blame] | 146 | install-libs: install |
Reid Spencer | ca739c6 | 2005-08-25 04:59:49 +0000 | [diff] [blame] | 147 | |
| 148 | #------------------------------------------------------------------------ |
| 149 | # Make sure the generated headers are up-to-date. This must be kept in |
| 150 | # sync with the AC_CONFIG_HEADER invocations in autoconf/configure.ac |
| 151 | #------------------------------------------------------------------------ |
| 152 | FilesToConfig := \ |
| 153 | include/llvm/Config/config.h \ |
Douglas Gregor | 1555a23 | 2009-06-16 20:12:29 +0000 | [diff] [blame] | 154 | include/llvm/Config/Targets.def \ |
Daniel Dunbar | f87ea4d | 2009-11-25 04:46:58 +0000 | [diff] [blame] | 155 | include/llvm/Config/AsmPrinters.def \ |
| 156 | include/llvm/Config/AsmParsers.def \ |
| 157 | include/llvm/Config/Disassemblers.def \ |
Chandler Carruth | 8b67f77 | 2009-10-26 01:35:46 +0000 | [diff] [blame] | 158 | include/llvm/System/DataTypes.h \ |
Daniel Dunbar | f87ea4d | 2009-11-25 04:46:58 +0000 | [diff] [blame] | 159 | tools/llvmc/plugins/Base/Base.td |
Reid Spencer | ca739c6 | 2005-08-25 04:59:49 +0000 | [diff] [blame] | 160 | FilesToConfigPATH := $(addprefix $(LLVM_OBJ_ROOT)/,$(FilesToConfig)) |
| 161 | |
| 162 | all-local:: $(FilesToConfigPATH) |
Misha Brukman | ef5dc70 | 2009-01-08 02:11:55 +0000 | [diff] [blame] | 163 | $(FilesToConfigPATH) : $(LLVM_OBJ_ROOT)/% : $(LLVM_SRC_ROOT)/%.in |
Reid Spencer | ca739c6 | 2005-08-25 04:59:49 +0000 | [diff] [blame] | 164 | $(Echo) Regenerating $* |
| 165 | $(Verb) cd $(LLVM_OBJ_ROOT) && $(ConfigStatusScript) $* |
| 166 | .PRECIOUS: $(FilesToConfigPATH) |
Reid Spencer | e22f3c0 | 2006-04-07 15:58:18 +0000 | [diff] [blame] | 167 | |
Chris Lattner | 38ab6d8 | 2006-04-07 16:21:59 +0000 | [diff] [blame] | 168 | # NOTE: This needs to remain as the last target definition in this file so |
| 169 | # that it gets executed last. |
Anton Korobeynikov | 569c45c | 2008-11-10 07:33:13 +0000 | [diff] [blame] | 170 | ifneq ($(BUILD_DIRS_ONLY),1) |
Misha Brukman | ef5dc70 | 2009-01-08 02:11:55 +0000 | [diff] [blame] | 171 | all:: |
Reid Spencer | e22f3c0 | 2006-04-07 15:58:18 +0000 | [diff] [blame] | 172 | $(Echo) '*****' Completed $(BuildMode)$(AssertMode) Build |
| 173 | ifeq ($(BuildMode),Debug) |
| 174 | $(Echo) '*****' Note: Debug build can be 10 times slower than an |
| 175 | $(Echo) '*****' optimized build. Use 'make ENABLE_OPTIMIZED=1' to |
Gabor Greif | 2ae1955 | 2008-02-28 11:48:14 +0000 | [diff] [blame] | 176 | $(Echo) '*****' make an optimized build. Alternatively you can |
| 177 | $(Echo) '*****' configure with --enable-optimized. |
Reid Spencer | e22f3c0 | 2006-04-07 15:58:18 +0000 | [diff] [blame] | 178 | endif |
Anton Korobeynikov | 569c45c | 2008-11-10 07:33:13 +0000 | [diff] [blame] | 179 | endif |
Chris Lattner | 38ab6d8 | 2006-04-07 16:21:59 +0000 | [diff] [blame] | 180 | |
Reid Spencer | 5b30ee1 | 2006-06-01 07:27:53 +0000 | [diff] [blame] | 181 | check-llvm2cpp: |
Reid Spencer | 42f98e5 | 2007-04-15 06:22:48 +0000 | [diff] [blame] | 182 | $(Verb)$(MAKE) check TESTSUITE=Feature RUNLLVM2CPP=1 |
Chris Lattner | 5720be4 | 2006-07-26 19:10:34 +0000 | [diff] [blame] | 183 | |
Reid Spencer | 9df5561 | 2007-04-15 06:18:50 +0000 | [diff] [blame] | 184 | check-one: |
Reid Spencer | 42f98e5 | 2007-04-15 06:22:48 +0000 | [diff] [blame] | 185 | $(Verb)$(MAKE) -C test check-one TESTONE=$(TESTONE) |
Reid Spencer | 9df5561 | 2007-04-15 06:18:50 +0000 | [diff] [blame] | 186 | |
Misha Brukman | ef5dc70 | 2009-01-08 02:11:55 +0000 | [diff] [blame] | 187 | srpm: $(LLVM_OBJ_ROOT)/llvm.spec |
Reid Spencer | f7c75a6 | 2006-08-16 00:43:50 +0000 | [diff] [blame] | 188 | rpmbuild -bs $(LLVM_OBJ_ROOT)/llvm.spec |
| 189 | |
Misha Brukman | ef5dc70 | 2009-01-08 02:11:55 +0000 | [diff] [blame] | 190 | rpm: $(LLVM_OBJ_ROOT)/llvm.spec |
Reid Spencer | f7c75a6 | 2006-08-16 00:43:50 +0000 | [diff] [blame] | 191 | rpmbuild -bb --target $(TARGET_TRIPLE) $(LLVM_OBJ_ROOT)/llvm.spec |
| 192 | |
Reid Spencer | 1e46ae4 | 2007-02-05 23:18:58 +0000 | [diff] [blame] | 193 | show-footprint: |
| 194 | $(Verb) du -sk $(LibDir) |
| 195 | $(Verb) du -sk $(ToolDir) |
| 196 | $(Verb) du -sk $(ExmplDir) |
| 197 | $(Verb) du -sk $(ObjDir) |
| 198 | |
Reid Spencer | 51cf642 | 2007-07-08 03:50:22 +0000 | [diff] [blame] | 199 | build-for-llvm-top: |
| 200 | $(Verb) if test ! -f ./config.status ; then \ |
| 201 | ./configure --prefix="$(LLVM_TOP)/install" \ |
| 202 | --with-llvm-gcc="$(LLVM_TOP)/llvm-gcc" ; \ |
| 203 | fi |
| 204 | $(Verb) $(MAKE) tools-only |
| 205 | |
Gabor Greif | 1d7ca71 | 2008-02-28 13:06:50 +0000 | [diff] [blame] | 206 | SVN = svn |
Gabor Greif | 9fa4226 | 2008-02-28 14:58:14 +0000 | [diff] [blame] | 207 | SVN-UPDATE-OPTIONS = |
Gabor Greif | 1d7ca71 | 2008-02-28 13:06:50 +0000 | [diff] [blame] | 208 | AWK = awk |
Gabor Greif | a4a0323 | 2008-02-28 18:46:56 +0000 | [diff] [blame] | 209 | SUB-SVN-DIRS = $(AWK) '/\?\ \ \ \ \ \ / {print $$2}' \ |
Gabor Greif | 95fc7aa | 2009-04-24 17:00:03 +0000 | [diff] [blame] | 210 | | LC_ALL=C xargs $(SVN) info 2>/dev/null \ |
Gabor Greif | a4a0323 | 2008-02-28 18:46:56 +0000 | [diff] [blame] | 211 | | $(AWK) '/Path:\ / {print $$2}' |
Gabor Greif | 1d7ca71 | 2008-02-28 13:06:50 +0000 | [diff] [blame] | 212 | |
| 213 | update: |
Gabor Greif | 8e0c20b | 2008-03-21 22:17:07 +0000 | [diff] [blame] | 214 | $(SVN) $(SVN-UPDATE-OPTIONS) update $(LLVM_SRC_ROOT) |
| 215 | @ $(SVN) status $(LLVM_SRC_ROOT) | $(SUB-SVN-DIRS) | xargs $(SVN) $(SVN-UPDATE-OPTIONS) update |
Gabor Greif | 1d7ca71 | 2008-02-28 13:06:50 +0000 | [diff] [blame] | 216 | |
Gabor Greif | 312fa75 | 2010-03-21 22:23:02 +0000 | [diff] [blame] | 217 | happiness: update all check-all |
Gabor Greif | 1d7ca71 | 2008-02-28 13:06:50 +0000 | [diff] [blame] | 218 | |
| 219 | .PHONY: srpm rpm update happiness |
Reid Spencer | 51cf642 | 2007-07-08 03:50:22 +0000 | [diff] [blame] | 220 | |
Gabor Greif | 2ae1955 | 2008-02-28 11:48:14 +0000 | [diff] [blame] | 221 | # declare all targets at this level to be serial: |
| 222 | |
| 223 | .NOTPARALLEL: |
| 224 | |
Stuart Hastings | 4a53e1e | 2009-10-22 17:22:37 +0000 | [diff] [blame] | 225 | else # Building "Apple-style." |
| 226 | # In an Apple-style build, once configuration is done, lines marked |
| 227 | # "Apple-style" are removed with sed! Please don't remove these! |
| 228 | # Look for the string "Apple-style" in utils/buildit/build_llvm. |
| 229 | include $(shell find . -name GNUmakefile) # Building "Apple-style." |
| 230 | endif # Building "Apple-style." |