zpu: first sign of being able to build a .S file
[llvm/zpu.git] / Makefile
blobae650b7f2d938873675a892e84ae54854099ae68
1 #===- ./Makefile -------------------------------------------*- Makefile -*--===#
3 # The LLVM Compiler Infrastructure
5 # This file is distributed under the University of Illinois Open Source
6 # License. See LICENSE.TXT for details.
8 #===------------------------------------------------------------------------===#
10 LEVEL := .
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.
18 # 6. Build tools, runtime, docs.
20 # When cross-compiling, there are some things (tablegen) that need to
21 # be build for the build system first.
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.
27 ifneq ($(findstring llvmCore, $(RC_ProjectName)),llvmCore) # Normal build (not "Apple-style").
29 ifeq ($(BUILD_DIRS_ONLY),1)
30 DIRS := lib/System lib/Support utils
31 OPTIONAL_DIRS :=
32 else
33 DIRS := lib/System lib/Support utils lib/VMCore lib tools/llvm-shlib \
34 tools/llvm-config tools runtime docs unittests
35 OPTIONAL_DIRS := projects bindings
36 endif
38 ifeq ($(BUILD_EXAMPLES),1)
39 OPTIONAL_DIRS += examples
40 endif
42 EXTRA_DIST := test unittests llvm.spec include win32 Xcode
44 include $(LEVEL)/Makefile.config
46 ifneq ($(ENABLE_SHARED),1)
47 DIRS := $(filter-out tools/llvm-shlib, $(DIRS))
48 endif
50 ifeq ($(MAKECMDGOALS),libs-only)
51 DIRS := $(filter-out tools runtime docs, $(DIRS))
52 OPTIONAL_DIRS :=
53 endif
55 ifeq ($(MAKECMDGOALS),install-libs)
56 DIRS := $(filter-out tools runtime docs, $(DIRS))
57 OPTIONAL_DIRS := $(filter bindings, $(OPTIONAL_DIRS))
58 endif
60 ifeq ($(MAKECMDGOALS),tools-only)
61 DIRS := $(filter-out runtime docs, $(DIRS))
62 OPTIONAL_DIRS :=
63 endif
65 ifeq ($(MAKECMDGOALS),install-clang)
66 DIRS := tools/clang/tools/driver tools/clang/lib/Headers \
67 tools/clang/runtime tools/clang/docs \
68 tools/lto
69 OPTIONAL_DIRS :=
70 NO_INSTALL = 1
71 endif
73 ifeq ($(MAKECMDGOALS),install-clang-c)
74 DIRS := tools/clang/tools/driver tools/clang/lib/Headers \
75 tools/clang/tools/libclang tools/clang/tools/c-index-test \
76 tools/clang/include/clang-c
77 OPTIONAL_DIRS :=
78 NO_INSTALL = 1
79 endif
81 ifeq ($(MAKECMDGOALS),clang-only)
82 DIRS := $(filter-out tools runtime docs unittests, $(DIRS)) \
83 tools/clang tools/lto
84 OPTIONAL_DIRS :=
85 endif
87 ifeq ($(MAKECMDGOALS),unittests)
88 DIRS := $(filter-out tools runtime docs, $(DIRS)) utils unittests
89 OPTIONAL_DIRS :=
90 endif
92 # Use NO_INSTALL define of the Makefile of each directory for deciding
93 # if the directory is installed or not
94 ifeq ($(MAKECMDGOALS),install)
95 OPTIONAL_DIRS := $(filter bindings, $(OPTIONAL_DIRS))
96 endif
98 # If we're cross-compiling, build the build-hosted tools first
99 ifeq ($(LLVM_CROSS_COMPILING),1)
100 all:: cross-compile-build-tools
102 clean::
103 $(Verb) rm -rf BuildTools
105 cross-compile-build-tools:
106 $(Verb) if [ ! -f BuildTools/Makefile ]; then \
107 $(MKDIR) BuildTools; \
108 cd BuildTools ; \
109 unset CFLAGS ; \
110 unset CXXFLAGS ; \
111 $(PROJ_SRC_DIR)/configure --build=$(BUILD_TRIPLE) \
112 --host=$(BUILD_TRIPLE) --target=$(BUILD_TRIPLE); \
113 cd .. ; \
114 fi; \
115 (unset SDKROOT; \
116 $(MAKE) -C BuildTools \
117 BUILD_DIRS_ONLY=1 \
118 UNIVERSAL= \
119 ENABLE_OPTIMIZED=$(ENABLE_OPTIMIZED) \
120 ENABLE_PROFILING=$(ENABLE_PROFILING) \
121 ENABLE_COVERAGE=$(ENABLE_COVERAGE) \
122 DISABLE_ASSERTIONS=$(DISABLE_ASSERTIONS) \
123 ENABLE_EXPENSIVE_CHECKS=$(ENABLE_EXPENSIVE_CHECKS) \
124 CFLAGS= \
125 CXXFLAGS= \
126 ) || exit 1;
127 endif
129 # Include the main makefile machinery.
130 include $(LLVM_SRC_ROOT)/Makefile.rules
132 # Specify options to pass to configure script when we're
133 # running the dist-check target
134 DIST_CHECK_CONFIG_OPTIONS = --with-llvmgccdir=$(LLVMGCCDIR)
136 .PHONY: debug-opt-prof
137 debug-opt-prof:
138 $(Echo) Building Debug Version
139 $(Verb) $(MAKE)
140 $(Echo)
141 $(Echo) Building Optimized Version
142 $(Echo)
143 $(Verb) $(MAKE) ENABLE_OPTIMIZED=1
144 $(Echo)
145 $(Echo) Building Profiling Version
146 $(Echo)
147 $(Verb) $(MAKE) ENABLE_PROFILING=1
149 dist-hook::
150 $(Echo) Eliminating files constructed by configure
151 $(Verb) $(RM) -f \
152 $(TopDistDir)/include/llvm/Config/config.h \
153 $(TopDistDir)/include/llvm/System/DataTypes.h
155 clang-only: all
156 tools-only: all
157 libs-only: all
158 install-clang: install
159 install-clang-c: install
160 install-libs: install
162 #------------------------------------------------------------------------
163 # Make sure the generated headers are up-to-date. This must be kept in
164 # sync with the AC_CONFIG_HEADER invocations in autoconf/configure.ac
165 #------------------------------------------------------------------------
166 FilesToConfig := \
167 include/llvm/Config/config.h \
168 include/llvm/Config/Targets.def \
169 include/llvm/Config/AsmPrinters.def \
170 include/llvm/Config/AsmParsers.def \
171 include/llvm/Config/Disassemblers.def \
172 include/llvm/System/DataTypes.h \
173 tools/llvmc/src/Base.td
174 FilesToConfigPATH := $(addprefix $(LLVM_OBJ_ROOT)/,$(FilesToConfig))
176 all-local:: $(FilesToConfigPATH)
177 $(FilesToConfigPATH) : $(LLVM_OBJ_ROOT)/% : $(LLVM_SRC_ROOT)/%.in
178 $(Echo) Regenerating $*
179 $(Verb) cd $(LLVM_OBJ_ROOT) && $(ConfigStatusScript) $*
180 .PRECIOUS: $(FilesToConfigPATH)
182 # NOTE: This needs to remain as the last target definition in this file so
183 # that it gets executed last.
184 ifneq ($(BUILD_DIRS_ONLY),1)
185 all::
186 $(Echo) '*****' Completed $(BuildMode) Build
187 ifneq ($(ENABLE_OPTIMIZED),1)
188 $(Echo) '*****' Note: Debug build can be 10 times slower than an
189 $(Echo) '*****' optimized build. Use 'make ENABLE_OPTIMIZED=1' to
190 $(Echo) '*****' make an optimized build. Alternatively you can
191 $(Echo) '*****' configure with --enable-optimized.
192 endif
193 endif
195 check-llvm2cpp:
196 $(Verb)$(MAKE) check TESTSUITE=Feature RUNLLVM2CPP=1
198 srpm: $(LLVM_OBJ_ROOT)/llvm.spec
199 rpmbuild -bs $(LLVM_OBJ_ROOT)/llvm.spec
201 rpm: $(LLVM_OBJ_ROOT)/llvm.spec
202 rpmbuild -bb --target $(TARGET_TRIPLE) $(LLVM_OBJ_ROOT)/llvm.spec
204 show-footprint:
205 $(Verb) du -sk $(LibDir)
206 $(Verb) du -sk $(ToolDir)
207 $(Verb) du -sk $(ExmplDir)
208 $(Verb) du -sk $(ObjDir)
210 build-for-llvm-top:
211 $(Verb) if test ! -f ./config.status ; then \
212 ./configure --prefix="$(LLVM_TOP)/install" \
213 --with-llvm-gcc="$(LLVM_TOP)/llvm-gcc" ; \
215 $(Verb) $(MAKE) tools-only
217 SVN = svn
218 SVN-UPDATE-OPTIONS =
219 AWK = awk
220 SUB-SVN-DIRS = $(AWK) '/\?\ \ \ \ \ \ / {print $$2}' \
221 | LC_ALL=C xargs $(SVN) info 2>/dev/null \
222 | $(AWK) '/Path:\ / {print $$2}'
224 update:
225 $(SVN) $(SVN-UPDATE-OPTIONS) update $(LLVM_SRC_ROOT)
226 @ $(SVN) status $(LLVM_SRC_ROOT) | $(SUB-SVN-DIRS) | xargs $(SVN) $(SVN-UPDATE-OPTIONS) update
228 happiness: update all check-all
230 .PHONY: srpm rpm update happiness
232 # declare all targets at this level to be serial:
234 .NOTPARALLEL:
236 else # Building "Apple-style."
237 # In an Apple-style build, once configuration is done, lines marked
238 # "Apple-style" are removed with sed! Please don't remove these!
239 # Look for the string "Apple-style" in utils/buildit/build_llvm.
240 include $(shell find . -name GNUmakefile) # Building "Apple-style."
241 endif # Building "Apple-style."