X-Git-Url: http://plrg.eecs.uci.edu/git/?a=blobdiff_plain;f=tools%2FMakefile;h=4b8923a58d33a94abe9f46026cd3a86e22c1ff74;hb=eaa221a23e1326a5fcf5fde57b4e932b6040e8a3;hp=d1491af5bfc2e6ac08ed6f5affd2403187e9065d;hpb=ac67b7ea8fcd530995d7aefd2ad0f04543789855;p=oota-llvm.git diff --git a/tools/Makefile b/tools/Makefile index d1491af5bfc..4b8923a58d3 100644 --- a/tools/Makefile +++ b/tools/Makefile @@ -1,32 +1,81 @@ ##===- tools/Makefile --------------------------------------*- Makefile -*-===## -# +# # The LLVM Compiler Infrastructure # # This file is distributed under the University of Illinois Open Source # License. See LICENSE.TXT for details. -# +# ##===----------------------------------------------------------------------===## LEVEL := .. -# NOTE: The tools are organized into five groups of four consisting of one -# large and three small executables. This is done to minimize memory load + +include $(LEVEL)/Makefile.config + +# Build clang if present. + +ifneq ($(CLANG_SRC_ROOT),) + OPTIONAL_PARALLEL_DIRS := $(CLANG_SRC_ROOT) +else + OPTIONAL_PARALLEL_DIRS := clang +endif + +# Build LLD and LLDB if present. Note LLDB must be built last as it depends on +# the wider LLVM infrastructure (including Clang). +OPTIONAL_PARALLEL_DIRS += lld +OPTIONAL_DIRS := lldb + +# NOTE: The tools are organized into five groups of four consisting of one +# large and three small executables. This is done to minimize memory load # in parallel builds. Please retain this ordering. -PARALLEL_DIRS := llvm-config \ - opt llvm-as llvm-dis llvm-upgrade \ - llc llvm-ranlib llvm-ar llvm-nm \ - llvm-ld llvmc llvm-prof llvm-link \ - lli gccas gccld llvm-extract llvm-db llvm2cpp \ - bugpoint llvm-bcanalyzer llvm-stub llvmc2 +DIRS := llvm-config +PARALLEL_DIRS := opt llvm-as llvm-dis llc llvm-ar llvm-nm llvm-link \ + lli llvm-extract llvm-mc bugpoint llvm-bcanalyzer llvm-diff \ + macho-dump llvm-objdump llvm-readobj llvm-rtdyld \ + llvm-dwarfdump llvm-cov llvm-size llvm-stress llvm-mcmarkup \ + llvm-profdata llvm-symbolizer obj2yaml yaml2obj llvm-c-test \ + llvm-vtabledump verify-uselistorder +# If Intel JIT Events support is configured, build an extra tool to test it. +ifeq ($(USE_INTEL_JITEVENTS), 1) + PARALLEL_DIRS += llvm-jitlistener +endif -include $(LEVEL)/Makefile.config +# Let users override the set of tools to build from the command line. +ifdef ONLY_TOOLS + OPTIONAL_PARALLEL_DIRS := + OPTIONAL_DIRS := $(findstring lldb,$(ONLY_TOOLS)) + PARALLEL_DIRS := $(filter-out lldb,$(ONLY_TOOLS)) +endif + +# These libraries build as dynamic libraries (.dylib /.so), they can only be +# built if ENABLE_PIC is set. +ifndef ONLY_TOOLS +ifeq ($(ENABLE_PIC),1) + # gold only builds if binutils is around. It requires "lto" to build before + # it so it is added to DIRS. llvm-lto also requires lto + DIRS += lto llvm-lto + ifdef BINUTILS_INCDIR + DIRS += gold + endif + + PARALLEL_DIRS += bugpoint-passes +endif -# Disable liblto as it is going away -#PARALLEL_DIRS += lto +ifdef LLVM_HAS_POLLY + PARALLEL_DIRS += polly +endif +endif + +# On Win32, loadable modules can be built with ENABLE_SHARED. +ifneq ($(ENABLE_SHARED),1) + ifneq (,$(filter $(HOST_OS), Cygwin MingW)) + PARALLEL_DIRS := $(filter-out bugpoint-passes, \ + $(PARALLEL_DIRS)) + endif +endif -# only build new lto project on Darwin for now -ifeq ($(OS),Darwin) -PARALLEL_DIRS += lto2 +ifneq (,$(filter go,$(BINDINGS_TO_BUILD))) + PARALLEL_DIRS += llvm-go endif include $(LEVEL)/Makefile.common