X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=tools%2FMakefile;h=278546bc1625b7e02c7d6bcf44a1d2da0712422f;hb=1ad92131abbed3d2992d5996969274a8e1ae9a6b;hp=b2b47504dbcf48d4f2cbd856939405211552da6d;hpb=9141f033226230f0822bb62dfdb67e48ae753245;p=oota-llvm.git diff --git a/tools/Makefile b/tools/Makefile index b2b47504dbc..278546bc162 100644 --- a/tools/Makefile +++ b/tools/Makefile @@ -1,26 +1,82 @@ ##===- tools/Makefile --------------------------------------*- Makefile -*-===## -# +# # The LLVM Compiler Infrastructure # -# This file was developed by the LLVM research group and is distributed under -# the University of Illinois Open Source License. See LICENSE.TXT for details. -# +# This file is distributed under the University of Illinois Open Source +# License. See LICENSE.TXT for details. +# ##===----------------------------------------------------------------------===## LEVEL := .. -PARALLEL_DIRS := llvm-as llvm-dis opt gccas llc llvm-link lli gccld llvm-stub \ - analyze extract llvm-nm llvm-prof llvm-ar llvm-ranlib \ - llvm-bcanalyzer llvmc llvm-ld llvm-db bugpoint include $(LEVEL)/Makefile.config -# The bugpoint and llvm-db tools are not portable to Win32 because they depend -# on fork(2) behavior that Win32 doesn't have. At some point they'll be -# rewritten to not depend on fork at which time they should be added back to -# the list above. +# Build clang if present. + +ifneq ($(CLANG_SRC_ROOT),) + OPTIONAL_PARALLEL_DIRS := $(CLANG_SRC_ROOT) +else + OPTIONAL_PARALLEL_DIRS := clang +endif + +# Build LLDB if present. Note LLDB must be built last as it depends on the +# wider LLVM infrastructure (including Clang). +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. +DIRS := llvm-config +PARALLEL_DIRS := opt llvm-as llvm-dis \ + llc llvm-ranlib llvm-ar llvm-nm \ + llvm-ld llvm-prof llvm-link \ + lli llvm-extract llvm-mc \ + bugpoint llvm-bcanalyzer llvm-stub \ + llvm-diff macho-dump llvm-objdump \ + llvm-rtdyld llvm-dwarfdump llvm-cov \ + llvm-size llvm-config-2 + +# 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. + ifdef BINUTILS_INCDIR + DIRS += lto gold + else + PARALLEL_DIRS += lto + endif + + PARALLEL_DIRS += bugpoint-passes + + # The edis library is only supported if ARM and/or X86 are enabled, and if + # LLVM is being built PIC on platforms that support dylibs. + ifneq ($(DISABLE_EDIS),1) + ifneq ($(filter $(TARGETS_TO_BUILD), X86 ARM),) + PARALLEL_DIRS += edis + endif + endif +endif + +ifdef LLVM_HAS_POLLY + PARALLEL_DIRS += polly +endif +endif -ifeq ($(OS),Win32) -PARALLEL_DIRS := $(filter-out bugpoint llvm-db,$(PARALLEL_DIRS)) +# 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 -include $(BUILD_SRC_ROOT)/Makefile.rules +include $(LEVEL)/Makefile.common