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