2003-11-23 18:12:22 +00:00
|
|
|
##===- projects/sample/Makefile ----------------------------*- Makefile -*-===##
|
|
|
|
#
|
|
|
|
# This is a sample Makefile for a project that uses LLVM.
|
|
|
|
#
|
|
|
|
##===----------------------------------------------------------------------===##
|
|
|
|
|
|
|
|
#
|
|
|
|
# Indicates our relative path to the top of the project's root directory.
|
|
|
|
#
|
|
|
|
LEVEL = ../../..
|
|
|
|
|
|
|
|
#
|
|
|
|
# Directories that needs to be built.
|
|
|
|
#
|
|
|
|
DIRS =
|
|
|
|
|
|
|
|
#
|
|
|
|
# Include the Master Makefile that knows how to build all.
|
|
|
|
#
|
|
|
|
include $(LEVEL)/Makefile.common
|
|
|
|
|
|
|
|
LOGIC_TESTS = eq ne le ge gt lt false true
|
|
|
|
BITWISE_TESTS = shl shr xor or and
|
|
|
|
ARITHMETIC_TESTS = abs neg add sub mul div mod star_slash incr decr min max
|
|
|
|
STACK_TESTS = drop drop2 nip nip2 dup dup2 swap swap2 over over2 rot rot2 \
|
|
|
|
rrot rrot2 tuck tuck2 roll pick select
|
|
|
|
MEMORY_TESTS = memory
|
|
|
|
CONTROL_TESTS = while return
|
|
|
|
IO_TESTS = space tab out_chr out_num out_str
|
|
|
|
|
|
|
|
TESTS = $(LOGIC_TESTS) $(ARITHMETIC_TESTS) $(BITWISE_TESTS) $(STACK_TESTS) \
|
|
|
|
$(MEMORY_TESTS) $(CONTROL_TESTS) $(IO_TESTS)
|
|
|
|
|
|
|
|
all :: test_each
|
|
|
|
|
|
|
|
test_each: $(TESTS)
|
2003-11-24 02:57:25 +00:00
|
|
|
@$(ECHO) "Running Tests..."
|
|
|
|
$(VERB)$(BUILD_SRC_DIR)/runtests $(BUILD_OBJ_DIR) $(TESTS)
|
2003-11-23 18:12:22 +00:00
|
|
|
|
|
|
|
% : %.s testing.s
|
2003-11-24 02:57:25 +00:00
|
|
|
@$(ECHO) "Compiling and Linking $< to $*"
|
|
|
|
$(VERB)gcc -ggdb -L$(BUILD_OBJ_ROOT)/lib/Debug testing.s -lstkr_runtime -o $* $*.s
|
2003-11-23 18:12:22 +00:00
|
|
|
|
|
|
|
%.s : %.bc
|
2003-11-24 02:57:25 +00:00
|
|
|
@$(ECHO) "Compiling $< to $*.s"
|
|
|
|
$(VERB)llc -f -o $*.s $<
|
2003-11-23 18:12:22 +00:00
|
|
|
|
|
|
|
ifdef OPTIMIZE
|
|
|
|
%.bc : %.st $(BUILD_OBJ_ROOT)/tools/Debug/stkrc
|
2003-11-24 02:57:25 +00:00
|
|
|
@$(ECHO) "Compiling and Optimizing $< to $*.bc"
|
|
|
|
$(VERB)stkrc -e -o - $< | opt -stats -q -f -o $*.bc -adce -branch-combine -cee -constmerge -constprop -dce -die -gcse -globaldce -instcombine -pre
|
2003-11-23 18:12:22 +00:00
|
|
|
else
|
|
|
|
%.bc : %.st $(BUILD_OBJ_ROOT)/tools/Debug/stkrc
|
2003-11-24 02:57:25 +00:00
|
|
|
@$(ECHO) "Compiling $< to $*.bc"
|
|
|
|
$(VERB)stkrc -e -f -o $*.bc $<
|
2003-11-23 18:12:22 +00:00
|
|
|
endif
|
|
|
|
|
|
|
|
%.ll : %.bc
|
2003-11-24 02:57:25 +00:00
|
|
|
@$(ECHO) "Disassembling $< to $*.ll"
|
|
|
|
$(VERB)llvm-dis -o $*.ll $<
|
|
|
|
|
|
|
|
TESTS_LL = $(TESTS:%=%.ll)
|
|
|
|
TESTS_BC = $(TESTS:%=%.bc)
|
|
|
|
TESTS_S = $(TESTS:%=%.s)
|
2003-11-23 18:12:22 +00:00
|
|
|
|
|
|
|
clean ::
|
2003-11-24 02:57:25 +00:00
|
|
|
$(VERB)rm -f gmon.out $(TESTS_LL) $(TESTS_BC) $(TESTS_S) $(TESTS) testing.bc testing.s testing.ll
|
2003-11-23 18:12:22 +00:00
|
|
|
|
2003-11-24 02:57:25 +00:00
|
|
|
.SUFFIXES: .st .s .ll .bc
|
2003-11-23 18:12:22 +00:00
|
|
|
.PRECIOUS: %.s %.ll %.bc %.st
|
2003-11-24 02:57:25 +00:00
|
|
|
.PHONY: test_each
|