blob: 5a39563bccafd98e8f1df649ed372faf0ee87158 [file] [log] [blame]
Chris Lattner6d47bae2004-01-05 05:28:15 +00001##===- tools/Makefile --------------------------------------*- Makefile -*-===##
Mikhail Glushenkov113ec352008-11-25 21:38:12 +00002#
John Criswelle2fab732003-10-20 22:29:16 +00003# The LLVM Compiler Infrastructure
4#
Chris Lattner51167842007-12-29 20:07:17 +00005# This file is distributed under the University of Illinois Open Source
6# License. See LICENSE.TXT for details.
Mikhail Glushenkov113ec352008-11-25 21:38:12 +00007#
John Criswelle2fab732003-10-20 22:29:16 +00008##===----------------------------------------------------------------------===##
Chris Lattner6d47bae2004-01-05 05:28:15 +00009
Chris Lattner698e9ce2002-12-06 03:53:40 +000010LEVEL := ..
Mike Stump0a268912009-01-24 00:00:41 +000011
12# Build clang if present.
13OPTIONAL_PARALLEL_DIRS := clang
14
Mikhail Glushenkov113ec352008-11-25 21:38:12 +000015# NOTE: The tools are organized into five groups of four consisting of one
16# large and three small executables. This is done to minimize memory load
Reid Spencer36a987e2007-02-09 17:02:07 +000017# in parallel builds. Please retain this ordering.
Chris Lattner847da552010-07-20 18:25:19 +000018DIRS := llvm-config
Chris Lattnere744ab22010-07-20 20:55:57 +000019PARALLEL_DIRS := opt llvm-as llvm-dis \
Reid Spencer36a987e2007-02-09 17:02:07 +000020 llc llvm-ranlib llvm-ar llvm-nm \
Chris Lattner8c2ec512008-03-30 18:58:05 +000021 llvm-ld llvm-prof llvm-link \
Chris Lattner847da552010-07-20 18:25:19 +000022 lli llvm-extract llvm-mc \
Rafael Espindola0b5b1022010-08-09 14:05:42 +000023 bugpoint llvm-bcanalyzer llvm-stub \
Daniel Dunbar75373ac2010-11-27 05:58:44 +000024 llvmc llvm-diff macho-dump
Bill Wendling041b3f82007-12-08 23:58:46 +000025
Chris Lattner06942902009-04-25 22:08:52 +000026# Let users override the set of tools to build from the command line.
27ifdef ONLY_TOOLS
28 OPTIONAL_PARALLEL_DIRS :=
29 PARALLEL_DIRS := $(ONLY_TOOLS)
30endif
31
Chris Lattnercf8cb6d2006-09-08 18:33:49 +000032include $(LEVEL)/Makefile.config
Chris Lattner70c35372006-09-08 18:08:50 +000033
Chris Lattner847da552010-07-20 18:25:19 +000034
Chris Lattner23e6d2b2010-03-05 00:59:18 +000035# These libraries build as dynamic libraries (.dylib /.so), they can only be
36# built if ENABLE_PIC is set.
Daniel Dunbarb8810a32010-12-16 15:42:26 +000037ifndef ONLY_TOOLS
Nick Lewyckye9742d22009-03-03 07:45:09 +000038ifeq ($(ENABLE_PIC),1)
NAKAMURA Takumib4b544d2010-11-29 00:20:34 +000039 # gold only builds if binutils is around. It requires "lto" to build before
40 # it so it is added to DIRS.
41 ifdef BINUTILS_INCDIR
42 DIRS += lto gold
43 else
44 PARALLEL_DIRS += lto
45 endif
Chris Lattner847da552010-07-20 18:25:19 +000046
NAKAMURA Takumib4b544d2010-11-29 00:20:34 +000047 PARALLEL_DIRS += bugpoint-passes
Rafael Espindola0b5b1022010-08-09 14:05:42 +000048
NAKAMURA Takumib4b544d2010-11-29 00:20:34 +000049 # The edis library is only supported if ARM and/or X86 are enabled, and if
50 # LLVM is being built PIC on platforms that support dylibs.
51 ifneq ($(DISABLE_EDIS),1)
Chris Lattner847da552010-07-20 18:25:19 +000052 ifneq ($(filter $(TARGETS_TO_BUILD), X86 ARM),)
Chris Lattnere744ab22010-07-20 20:55:57 +000053 PARALLEL_DIRS += edis
Chris Lattner847da552010-07-20 18:25:19 +000054 endif
NAKAMURA Takumib4b544d2010-11-29 00:20:34 +000055 endif
Anton Korobeynikov294492b2006-09-08 18:00:43 +000056endif
Reid Spencerac285882006-05-30 21:20:55 +000057
Tobias Grosserbaaadb22010-10-30 00:54:26 +000058ifdef LLVM_HAS_POLLY
59 PARALLEL_DIRS += polly
60endif
Daniel Dunbarb8810a32010-12-16 15:42:26 +000061endif
Tobias Grosserbaaadb22010-10-30 00:54:26 +000062
NAKAMURA Takumif5f65882010-11-29 00:20:28 +000063# On Win32, loadable modules can be built with ENABLE_SHARED.
64ifneq ($(ENABLE_SHARED),1)
NAKAMURA Takumi0ae59f42010-11-29 08:58:11 +000065 ifneq (,$(filter $(HOST_OS), Cygwin MingW))
NAKAMURA Takumif5f65882010-11-29 00:20:28 +000066 PARALLEL_DIRS := $(filter-out bugpoint-passes, \
67 $(PARALLEL_DIRS))
68 endif
69endif
70
Chris Lattnercf8cb6d2006-09-08 18:33:49 +000071include $(LEVEL)/Makefile.common