| OLD | NEW |
| 1 # The following variables will likely need to be modified, depending on where | |
| 2 # and how you built LLVM & Clang. They can be overridden in a command-line | |
| 3 # invocation of make, like: | |
| 4 # | |
| 5 # make LLVM_SRC_PATH=<path> LLVM_BIN_PATH=<path> ... | |
| 6 # | |
| 7 | 1 |
| 8 # LLVM_SRC_PATH is the path to the root of the checked out source code. This | 2 ifndef SUBZERO_LEVEL |
| 9 # directory should contain the configure script, the include/ and lib/ | 3 # Top-level, not included from a subdir |
| 10 # directories of LLVM, Clang in tools/clang/, etc. | 4 SUBZERO_LEVEL := . |
| 11 # Alternatively, if you're building vs. a binary download of LLVM, then | 5 DIRS := src |
| 12 # LLVM_SRC_PATH can point to the main untarred directory. | 6 PARALLEL_DIRS := |
| 13 LLVM_SRC_PATH ?= ../llvm | 7 endif |
| 14 | 8 |
| 15 # LLVM_BIN_PATH is the directory where binaries are placed by the LLVM build | 9 # Set LLVM source root level. |
| 16 # process. It should contain the tools like opt, llc and clang. The default | 10 LEVEL := $(SUBZERO_LEVEL)/../.. |
| 17 # reflects a debug build with autotools (configure & make). | |
| 18 LLVM_BIN_PATH ?= $(shell readlink -e \ | |
| 19 » ../../out/llvm_i686_linux_work/Release+Asserts/bin) | |
| 20 | 11 |
| 21 $(info -----------------------------------------------) | 12 # Include LLVM common makefile. |
| 22 $(info Using LLVM_SRC_PATH = $(LLVM_SRC_PATH)) | 13 include $(LEVEL)/Makefile.common |
| 23 $(info Using LLVM_BIN_PATH = $(LLVM_BIN_PATH)) | |
| 24 $(info -----------------------------------------------) | |
| 25 | 14 |
| 26 LLVM_CXXFLAGS := `$(LLVM_BIN_PATH)/llvm-config --cxxflags` | |
| 27 LLVM_LDFLAGS := `$(LLVM_BIN_PATH)/llvm-config --ldflags --libs` | |
| 28 | |
| 29 # It's recommended that CXX matches the compiler you used to build LLVM itself. | |
| 30 OPTLEVEL := -O0 | |
| 31 CXX := g++ | |
| 32 CXXFLAGS := -Wall -Werror -fno-rtti -fno-exceptions \ | |
| 33 $(OPTLEVEL) -g $(LLVM_CXXFLAGS) -m32 | |
| 34 LDFLAGS := -m32 | |
| 35 | |
| 36 SRCS= \ | |
| 37 IceCfg.cpp \ | |
| 38 IceCfgNode.cpp \ | |
| 39 IceGlobalContext.cpp \ | |
| 40 IceInst.cpp \ | |
| 41 IceOperand.cpp \ | |
| 42 IceTypes.cpp \ | |
| 43 llvm2ice.cpp | |
| 44 | |
| 45 OBJS=$(patsubst %.cpp, build/%.o, $(SRCS)) | |
| 46 | |
| 47 # Keep all the first target so it's the default. | |
| 48 all: llvm2ice | |
| 49 | |
| 50 .PHONY: all | |
| 51 | |
| 52 llvm2ice: $(OBJS) | |
| 53 $(CXX) $(LDFLAGS) -o $@ $^ $(LLVM_LDFLAGS) -ldl | |
| 54 | |
| 55 # TODO: Be more precise than "*.h" here and elsewhere. | |
| 56 $(OBJS): build/%.o: src/%.cpp src/*.h src/*.def | |
| 57 $(CXX) -c $(CXXFLAGS) $< -o $@ | |
| 58 | |
| 59 $(OBJS): | build | |
| 60 | |
| 61 build: | |
| 62 @mkdir -p $@ | |
| 63 | |
| 64 check: llvm2ice | |
| 65 LLVM_BIN_PATH=$(LLVM_BIN_PATH) \ | |
| 66 $(LLVM_SRC_PATH)/utils/lit/lit.py -sv tests_lit | |
| 67 | |
| 68 # TODO: Fix the use of wildcards. | |
| 69 format: | |
| 70 $(LLVM_BIN_PATH)/clang-format -style=LLVM -i \ | |
| 71 src/Ice*.h src/Ice*.cpp src/llvm2ice.cpp | |
| 72 | |
| 73 clean: | |
| 74 rm -rf llvm2ice *.o build/ | |
| OLD | NEW |