[PM/AA] Run clang-format over the SCEV-AA code to normalize the
[oota-llvm.git] / tools / Makefile
1 ##===- tools/Makefile --------------------------------------*- Makefile -*-===##
2 #
3 #                     The LLVM Compiler Infrastructure
4 #
5 # This file is distributed under the University of Illinois Open Source
6 # License. See LICENSE.TXT for details.
7 #
8 ##===----------------------------------------------------------------------===##
9
10 LEVEL := ..
11
12 include $(LEVEL)/Makefile.config
13
14 # Build clang if present.
15
16 ifneq ($(CLANG_SRC_ROOT),)
17   OPTIONAL_PARALLEL_DIRS := $(CLANG_SRC_ROOT)
18 else
19   OPTIONAL_PARALLEL_DIRS := clang
20 endif
21
22 # Build LLDB if present. Note LLDB must be built last as it depends on
23 # the wider LLVM infrastructure (including Clang).
24 OPTIONAL_DIRS := lldb
25
26 # NOTE: The tools are organized into five groups of four consisting of one
27 # large and three small executables. This is done to minimize memory load
28 # in parallel builds.  Please retain this ordering.
29 DIRS := llvm-config
30 PARALLEL_DIRS := opt llvm-as llvm-dis llc llvm-ar llvm-nm llvm-link \
31                  lli llvm-extract llvm-mc bugpoint llvm-bcanalyzer llvm-diff \
32                  macho-dump llvm-objdump llvm-readobj llvm-rtdyld \
33                  llvm-dwarfdump llvm-cov llvm-size llvm-stress llvm-mcmarkup \
34                  llvm-profdata llvm-symbolizer obj2yaml yaml2obj llvm-c-test \
35                  llvm-cxxdump verify-uselistorder dsymutil llvm-pdbdump
36
37 # If Intel JIT Events support is configured, build an extra tool to test it.
38 ifeq ($(USE_INTEL_JITEVENTS), 1)
39   PARALLEL_DIRS += llvm-jitlistener
40 endif
41
42 # Let users override the set of tools to build from the command line.
43 ifdef ONLY_TOOLS
44   OPTIONAL_PARALLEL_DIRS :=
45   OPTIONAL_DIRS := $(findstring lldb,$(ONLY_TOOLS))
46   PARALLEL_DIRS := $(filter-out lldb,$(ONLY_TOOLS))
47 endif
48
49 # These libraries build as dynamic libraries (.dylib /.so), they can only be
50 # built if ENABLE_PIC is set.
51 ifndef ONLY_TOOLS
52 ifeq ($(ENABLE_PIC),1)
53   # gold only builds if binutils is around.  It requires "lto" to build before
54   # it so it is added to DIRS. llvm-lto also requires lto
55   DIRS += lto llvm-lto
56   ifdef BINUTILS_INCDIR
57     DIRS += gold
58   endif
59
60   PARALLEL_DIRS += bugpoint-passes
61 endif
62
63 ifdef LLVM_HAS_POLLY
64   PARALLEL_DIRS += polly
65 endif
66 endif
67
68 # On Win32, loadable modules can be built with ENABLE_SHARED.
69 ifneq ($(ENABLE_SHARED),1)
70   ifneq (,$(filter $(HOST_OS), Cygwin MingW))
71     PARALLEL_DIRS := $(filter-out bugpoint-passes, \
72                         $(PARALLEL_DIRS))
73   endif
74 endif
75
76 ifneq (,$(filter go,$(BINDINGS_TO_BUILD)))
77   PARALLEL_DIRS += llvm-go
78 endif
79
80 include $(LEVEL)/Makefile.common