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. |
| 22 | ifeq ($(BUILD_DIRS_ONLY),1) |
| 23 | DIRS := lib/System lib/Support utils |
| 24 | OPTIONAL_DIRS := |
| 25 | else |
| 26 | DIRS := lib/System lib/Support utils lib/VMCore lib tools/llvm-config \ |
| 27 | tools runtime docs |
| 28 | OPTIONAL_DIRS := examples projects bindings |
| 29 | endif |
David Greene | df93e57 | 2007-07-11 23:44:08 +0000 | [diff] [blame] | 30 | |
Misha Brukman | 8fb520e | 2009-01-01 02:24:48 +0000 | [diff] [blame] | 31 | EXTRA_DIST := test unittests llvm.spec include win32 Xcode |
Chris Lattner | 0095054 | 2001-06-06 20:29:01 +0000 | [diff] [blame] | 32 | |
Misha Brukman | ef5dc70 | 2009-01-08 02:11:55 +0000 | [diff] [blame] | 33 | include $(LEVEL)/Makefile.config |
Reid Spencer | 93bc3cd | 2006-04-06 22:15:51 +0000 | [diff] [blame] | 34 | |
Chris Lattner | c6b66eb | 2007-03-29 18:14:00 +0000 | [diff] [blame] | 35 | # 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 Spencer | 8b2e141 | 2006-11-17 03:32:33 +0000 | [diff] [blame] | 39 | DIRS := $(filter-out runtime, $(DIRS)) |
Chris Lattner | c6b66eb | 2007-03-29 18:14:00 +0000 | [diff] [blame] | 40 | #endif |
Reid Spencer | 8b2e141 | 2006-11-17 03:32:33 +0000 | [diff] [blame] | 41 | |
Chris Lattner | 5720be4 | 2006-07-26 19:10:34 +0000 | [diff] [blame] | 42 | ifeq ($(MAKECMDGOALS),libs-only) |
Reid Spencer | 8b2e141 | 2006-11-17 03:32:33 +0000 | [diff] [blame] | 43 | DIRS := $(filter-out tools runtime docs, $(DIRS)) |
Chris Lattner | 22033b2 | 2006-06-02 22:41:18 +0000 | [diff] [blame] | 44 | OPTIONAL_DIRS := |
| 45 | endif |
| 46 | |
Nate Begeman | 544f83d | 2007-12-13 02:17:17 +0000 | [diff] [blame] | 47 | ifeq ($(MAKECMDGOALS),install-libs) |
| 48 | DIRS := $(filter-out tools runtime docs, $(DIRS)) |
| 49 | OPTIONAL_DIRS := $(filter bindings, $(OPTIONAL_DIRS)) |
| 50 | endif |
| 51 | |
Chris Lattner | 5720be4 | 2006-07-26 19:10:34 +0000 | [diff] [blame] | 52 | ifeq ($(MAKECMDGOALS),tools-only) |
Reid Spencer | 8b2e141 | 2006-11-17 03:32:33 +0000 | [diff] [blame] | 53 | DIRS := $(filter-out runtime docs, $(DIRS)) |
Chris Lattner | 5720be4 | 2006-07-26 19:10:34 +0000 | [diff] [blame] | 54 | OPTIONAL_DIRS := |
| 55 | endif |
Chris Lattner | 22033b2 | 2006-06-02 22:41:18 +0000 | [diff] [blame] | 56 | |
Mike Stump | b76ace3 | 2009-01-19 19:48:23 +0000 | [diff] [blame] | 57 | ifeq ($(MAKECMDGOALS),install-clang) |
| 58 | DIRS := tools/clang/Driver tools/clang/lib/Headers tools/clang/tools/ccc |
| 59 | OPTIONAL_DIRS := |
| 60 | NO_INSTALL = 1 |
| 61 | endif |
| 62 | |
| 63 | ifeq ($(MAKECMDGOALS),clang-only) |
| 64 | DIRS := $(filter-out tools runtime docs, $(DIRS)) tools/clang |
| 65 | OPTIONAL_DIRS := |
| 66 | endif |
| 67 | |
Misha Brukman | 8fb520e | 2009-01-01 02:24:48 +0000 | [diff] [blame] | 68 | ifeq ($(MAKECMDGOALS),unittests) |
| 69 | DIRS := $(filter-out tools runtime docs, $(DIRS)) utils unittests |
| 70 | OPTIONAL_DIRS := |
| 71 | endif |
| 72 | |
Misha Brukman | ef5dc70 | 2009-01-08 02:11:55 +0000 | [diff] [blame] | 73 | # Don't install utils, examples, or projects they are only used to |
Chris Lattner | 122c055 | 2007-02-21 06:23:20 +0000 | [diff] [blame] | 74 | # build LLVM. |
| 75 | ifeq ($(MAKECMDGOALS),install) |
| 76 | DIRS := $(filter-out utils, $(DIRS)) |
Gordon Henriksen | 8ef426b | 2007-09-18 12:49:39 +0000 | [diff] [blame] | 77 | OPTIONAL_DIRS := $(filter bindings, $(OPTIONAL_DIRS)) |
Chris Lattner | 122c055 | 2007-02-21 06:23:20 +0000 | [diff] [blame] | 78 | endif |
| 79 | |
Anton Korobeynikov | 569c45c | 2008-11-10 07:33:13 +0000 | [diff] [blame] | 80 | # If we're cross-compiling, build the build-hosted tools first |
| 81 | ifeq ($(LLVM_CROSS_COMPILING),1) |
| 82 | all:: cross-compile-build-tools |
| 83 | |
| 84 | clean:: |
| 85 | $(Verb) rm -rf BuildTools |
| 86 | |
| 87 | cross-compile-build-tools: |
| 88 | $(Verb) if [ ! -f BuildTools/Makefile ]; then \ |
| 89 | $(MKDIR) BuildTools; \ |
| 90 | cd BuildTools ; \ |
| 91 | $(PROJ_SRC_DIR)/configure ; \ |
| 92 | cd .. ; \ |
| 93 | fi; \ |
| 94 | ($(MAKE) -C BuildTools BUILD_DIRS_ONLY=1 ) || exit 1; |
| 95 | endif |
| 96 | |
Chris Lattner | 22033b2 | 2006-06-02 22:41:18 +0000 | [diff] [blame] | 97 | # Include the main makefile machinery. |
Reid Spencer | 06a801a | 2006-04-08 02:14:37 +0000 | [diff] [blame] | 98 | include $(LLVM_SRC_ROOT)/Makefile.rules |
| 99 | |
Reid Spencer | 45eeed9 | 2005-05-24 02:33:20 +0000 | [diff] [blame] | 100 | # Specify options to pass to configure script when we're |
| 101 | # running the dist-check target |
| 102 | DIST_CHECK_CONFIG_OPTIONS = --with-llvmgccdir=$(LLVMGCCDIR) |
| 103 | |
Reid Spencer | df561f4 | 2004-11-25 09:08:54 +0000 | [diff] [blame] | 104 | .PHONY: debug-opt-prof |
| 105 | debug-opt-prof: |
| 106 | $(Echo) Building Debug Version |
| 107 | $(Verb) $(MAKE) |
| 108 | $(Echo) |
| 109 | $(Echo) Building Optimized Version |
| 110 | $(Echo) |
| 111 | $(Verb) $(MAKE) ENABLE_OPTIMIZED=1 |
| 112 | $(Echo) |
| 113 | $(Echo) Building Profiling Version |
| 114 | $(Echo) |
| 115 | $(Verb) $(MAKE) ENABLE_PROFILING=1 |
| 116 | |
Reid Spencer | 151f8ba | 2004-10-25 08:27:37 +0000 | [diff] [blame] | 117 | dist-hook:: |
Reid Spencer | cc2d1e2 | 2004-10-30 09:19:36 +0000 | [diff] [blame] | 118 | $(Echo) Eliminating files constructed by configure |
| 119 | $(Verb) $(RM) -f \ |
Anton Korobeynikov | 43d1fd4 | 2008-05-29 17:41:17 +0000 | [diff] [blame] | 120 | $(TopDistDir)/include/llvm/ADT/hash_map.h \ |
| 121 | $(TopDistDir)/include/llvm/ADT/hash_set.h \ |
| 122 | $(TopDistDir)/include/llvm/ADT/iterator.h \ |
Reid Spencer | 90c2949 | 2004-10-26 07:05:09 +0000 | [diff] [blame] | 123 | $(TopDistDir)/include/llvm/Config/config.h \ |
| 124 | $(TopDistDir)/include/llvm/Support/DataTypes.h \ |
| 125 | $(TopDistDir)/include/llvm/Support/ThreadSupport.h |
Reid Spencer | 151f8ba | 2004-10-25 08:27:37 +0000 | [diff] [blame] | 126 | |
Mike Stump | b76ace3 | 2009-01-19 19:48:23 +0000 | [diff] [blame] | 127 | clang-only: all |
Chris Lattner | 9cf662b | 2004-02-03 22:56:40 +0000 | [diff] [blame] | 128 | tools-only: all |
Reid Spencer | 8b1f767 | 2005-05-25 21:03:17 +0000 | [diff] [blame] | 129 | libs-only: all |
Mike Stump | b76ace3 | 2009-01-19 19:48:23 +0000 | [diff] [blame] | 130 | install-clang: install |
Nate Begeman | 544f83d | 2007-12-13 02:17:17 +0000 | [diff] [blame] | 131 | install-libs: install |
Reid Spencer | ca739c6 | 2005-08-25 04:59:49 +0000 | [diff] [blame] | 132 | |
| 133 | #------------------------------------------------------------------------ |
| 134 | # Make sure the generated headers are up-to-date. This must be kept in |
| 135 | # sync with the AC_CONFIG_HEADER invocations in autoconf/configure.ac |
| 136 | #------------------------------------------------------------------------ |
| 137 | FilesToConfig := \ |
| 138 | include/llvm/Config/config.h \ |
| 139 | include/llvm/Support/DataTypes.h \ |
Anton Korobeynikov | 43d1fd4 | 2008-05-29 17:41:17 +0000 | [diff] [blame] | 140 | include/llvm/ADT/hash_map.h \ |
| 141 | include/llvm/ADT/hash_set.h \ |
| 142 | include/llvm/ADT/iterator.h |
Reid Spencer | ca739c6 | 2005-08-25 04:59:49 +0000 | [diff] [blame] | 143 | FilesToConfigPATH := $(addprefix $(LLVM_OBJ_ROOT)/,$(FilesToConfig)) |
| 144 | |
| 145 | all-local:: $(FilesToConfigPATH) |
Misha Brukman | ef5dc70 | 2009-01-08 02:11:55 +0000 | [diff] [blame] | 146 | $(FilesToConfigPATH) : $(LLVM_OBJ_ROOT)/% : $(LLVM_SRC_ROOT)/%.in |
Reid Spencer | ca739c6 | 2005-08-25 04:59:49 +0000 | [diff] [blame] | 147 | $(Echo) Regenerating $* |
| 148 | $(Verb) cd $(LLVM_OBJ_ROOT) && $(ConfigStatusScript) $* |
| 149 | .PRECIOUS: $(FilesToConfigPATH) |
Reid Spencer | e22f3c0 | 2006-04-07 15:58:18 +0000 | [diff] [blame] | 150 | |
Chris Lattner | 38ab6d8 | 2006-04-07 16:21:59 +0000 | [diff] [blame] | 151 | # NOTE: This needs to remain as the last target definition in this file so |
| 152 | # that it gets executed last. |
Anton Korobeynikov | 569c45c | 2008-11-10 07:33:13 +0000 | [diff] [blame] | 153 | ifneq ($(BUILD_DIRS_ONLY),1) |
Misha Brukman | ef5dc70 | 2009-01-08 02:11:55 +0000 | [diff] [blame] | 154 | all:: |
Reid Spencer | e22f3c0 | 2006-04-07 15:58:18 +0000 | [diff] [blame] | 155 | $(Echo) '*****' Completed $(BuildMode)$(AssertMode) Build |
| 156 | ifeq ($(BuildMode),Debug) |
| 157 | $(Echo) '*****' Note: Debug build can be 10 times slower than an |
| 158 | $(Echo) '*****' optimized build. Use 'make ENABLE_OPTIMIZED=1' to |
Gabor Greif | 2ae1955 | 2008-02-28 11:48:14 +0000 | [diff] [blame] | 159 | $(Echo) '*****' make an optimized build. Alternatively you can |
| 160 | $(Echo) '*****' configure with --enable-optimized. |
Reid Spencer | e22f3c0 | 2006-04-07 15:58:18 +0000 | [diff] [blame] | 161 | endif |
Anton Korobeynikov | 569c45c | 2008-11-10 07:33:13 +0000 | [diff] [blame] | 162 | endif |
Chris Lattner | 38ab6d8 | 2006-04-07 16:21:59 +0000 | [diff] [blame] | 163 | |
Reid Spencer | 5b30ee1 | 2006-06-01 07:27:53 +0000 | [diff] [blame] | 164 | check-llvm2cpp: |
Reid Spencer | 42f98e5 | 2007-04-15 06:22:48 +0000 | [diff] [blame] | 165 | $(Verb)$(MAKE) check TESTSUITE=Feature RUNLLVM2CPP=1 |
Chris Lattner | 5720be4 | 2006-07-26 19:10:34 +0000 | [diff] [blame] | 166 | |
Reid Spencer | 9df5561 | 2007-04-15 06:18:50 +0000 | [diff] [blame] | 167 | check-one: |
Reid Spencer | 42f98e5 | 2007-04-15 06:22:48 +0000 | [diff] [blame] | 168 | $(Verb)$(MAKE) -C test check-one TESTONE=$(TESTONE) |
Reid Spencer | 9df5561 | 2007-04-15 06:18:50 +0000 | [diff] [blame] | 169 | |
Misha Brukman | ef5dc70 | 2009-01-08 02:11:55 +0000 | [diff] [blame] | 170 | srpm: $(LLVM_OBJ_ROOT)/llvm.spec |
Reid Spencer | f7c75a6 | 2006-08-16 00:43:50 +0000 | [diff] [blame] | 171 | rpmbuild -bs $(LLVM_OBJ_ROOT)/llvm.spec |
| 172 | |
Misha Brukman | ef5dc70 | 2009-01-08 02:11:55 +0000 | [diff] [blame] | 173 | rpm: $(LLVM_OBJ_ROOT)/llvm.spec |
Reid Spencer | f7c75a6 | 2006-08-16 00:43:50 +0000 | [diff] [blame] | 174 | rpmbuild -bb --target $(TARGET_TRIPLE) $(LLVM_OBJ_ROOT)/llvm.spec |
| 175 | |
Reid Spencer | 1e46ae4 | 2007-02-05 23:18:58 +0000 | [diff] [blame] | 176 | show-footprint: |
| 177 | $(Verb) du -sk $(LibDir) |
| 178 | $(Verb) du -sk $(ToolDir) |
| 179 | $(Verb) du -sk $(ExmplDir) |
| 180 | $(Verb) du -sk $(ObjDir) |
| 181 | |
Reid Spencer | 51cf642 | 2007-07-08 03:50:22 +0000 | [diff] [blame] | 182 | build-for-llvm-top: |
| 183 | $(Verb) if test ! -f ./config.status ; then \ |
| 184 | ./configure --prefix="$(LLVM_TOP)/install" \ |
| 185 | --with-llvm-gcc="$(LLVM_TOP)/llvm-gcc" ; \ |
| 186 | fi |
| 187 | $(Verb) $(MAKE) tools-only |
| 188 | |
Gabor Greif | 1d7ca71 | 2008-02-28 13:06:50 +0000 | [diff] [blame] | 189 | SVN = svn |
Gabor Greif | 9fa4226 | 2008-02-28 14:58:14 +0000 | [diff] [blame] | 190 | SVN-UPDATE-OPTIONS = |
Gabor Greif | 1d7ca71 | 2008-02-28 13:06:50 +0000 | [diff] [blame] | 191 | AWK = awk |
Gabor Greif | a4a0323 | 2008-02-28 18:46:56 +0000 | [diff] [blame] | 192 | SUB-SVN-DIRS = $(AWK) '/\?\ \ \ \ \ \ / {print $$2}' \ |
| 193 | | LANG=C xargs $(SVN) info 2>/dev/null \ |
| 194 | | $(AWK) '/Path:\ / {print $$2}' |
Gabor Greif | 1d7ca71 | 2008-02-28 13:06:50 +0000 | [diff] [blame] | 195 | |
| 196 | update: |
Gabor Greif | 8e0c20b | 2008-03-21 22:17:07 +0000 | [diff] [blame] | 197 | $(SVN) $(SVN-UPDATE-OPTIONS) update $(LLVM_SRC_ROOT) |
| 198 | @ $(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] | 199 | |
Bill Wendling | 4113bd1 | 2009-01-04 23:12:21 +0000 | [diff] [blame] | 200 | happiness: update all check unittests |
Gabor Greif | 1d7ca71 | 2008-02-28 13:06:50 +0000 | [diff] [blame] | 201 | |
| 202 | .PHONY: srpm rpm update happiness |
Reid Spencer | 51cf642 | 2007-07-08 03:50:22 +0000 | [diff] [blame] | 203 | |
Gabor Greif | 2ae1955 | 2008-02-28 11:48:14 +0000 | [diff] [blame] | 204 | # declare all targets at this level to be serial: |
| 205 | |
| 206 | .NOTPARALLEL: |
| 207 | |