X-Git-Url: http://plrg.eecs.uci.edu/git/?a=blobdiff_plain;f=tools%2FMakefile;h=8205568c2f5828beca3e4321021f144037efb036;hb=22ff748712b348300e51248339b6e8cf9b59e2c6;hp=badd6659b50b4f5784d1cb787ad958afdea30b11;hpb=c679d7e88f1a124b820f9451905bf614f24e0e0d;p=oota-llvm.git diff --git a/tools/Makefile b/tools/Makefile index badd6659b50..8205568c2f5 100644 --- a/tools/Makefile +++ b/tools/Makefile @@ -1,6 +1,61 @@ +##===- 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 := .. -PARALLEL_DIRS := llvm-as llvm-dis opt gccas llc llvm-link lli gccld \ - analyze extract bugpoint llvm-ar -include $(LEVEL)/Makefile.common +# Build clang if present. +OPTIONAL_PARALLEL_DIRS := clang + +# 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 \ + bugpoint llvm-bcanalyzer llvm-stub \ + llvm-mc llvmc + +# Let users override the set of tools to build from the command line. +ifdef ONLY_TOOLS + OPTIONAL_PARALLEL_DIRS := + PARALLEL_DIRS := $(ONLY_TOOLS) +endif + +include $(LEVEL)/Makefile.config +# These libraries build as dynamic libraries (.dylib /.so), they can only be +# built if ENABLE_PIC is set. +ifeq ($(ENABLE_PIC),1) + # No support for dynamic libraries on windows targets. + ifneq ($(TARGET_OS), $(filter $(TARGET_OS), Cygwin MingW)) + DIRS += edis + + # 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 + endif +endif + +# Only build edis if X86 target support is enabled. +ifeq ($(filter $(TARGETS_TO_BUILD), X86),) + PARALLEL_DIRS := $(filter-out edis, $(PARALLEL_DIRS)) +endif + +# Don't build edis if we explicitly disabled it. +ifeq ($(DISABLE_EDIS),1) + PARALLEL_DIRS := $(filter-out edis, $(PARALLEL_DIRS)) +endif + +include $(LEVEL)/Makefile.common