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