blob: 1629de39d4ee124eb7a1613f1cb448ea263aa0c9 [file] [log] [blame]
Reid Spencer39dcf0e2004-09-04 20:13:54 +00001##===- projects/Stacker/test/Makefile ----------------------*- Makefile -*-===##
Chris Lattnere44f1db2003-11-23 18:12:22 +00002#
Reid Spencer39dcf0e2004-09-04 20:13:54 +00003# This is the makefile that tests the various facilities of the Stacker language
Chris Lattnere44f1db2003-11-23 18:12:22 +00004#
5##===----------------------------------------------------------------------===##
6
7#
8# Indicates our relative path to the top of the project's root directory.
9#
Reid Spencer39dcf0e2004-09-04 20:13:54 +000010LEVEL = ../
Chris Lattnere44f1db2003-11-23 18:12:22 +000011
12#
Reid Spencer39dcf0e2004-09-04 20:13:54 +000013# Directories that need to be built.
Chris Lattnere44f1db2003-11-23 18:12:22 +000014#
15DIRS =
16
17#
18# Include the Master Makefile that knows how to build all.
19#
20include $(LEVEL)/Makefile.common
21
22LOGIC_TESTS = eq ne le ge gt lt false true
23BITWISE_TESTS = shl shr xor or and
24ARITHMETIC_TESTS = abs neg add sub mul div mod star_slash incr decr min max
25STACK_TESTS = drop drop2 nip nip2 dup dup2 swap swap2 over over2 rot rot2 \
26 rrot rrot2 tuck tuck2 roll pick select
27MEMORY_TESTS = memory
28CONTROL_TESTS = while return
29IO_TESTS = space tab out_chr out_num out_str
30
31TESTS = $(LOGIC_TESTS) $(ARITHMETIC_TESTS) $(BITWISE_TESTS) $(STACK_TESTS) \
32 $(MEMORY_TESTS) $(CONTROL_TESTS) $(IO_TESTS)
33
Chris Lattner0c82ee72003-12-08 07:08:00 +000034STKRC_EXEC = $(BUILD_OBJ_ROOT)/tools/$(CONFIGURATION)/stkrc
Chris Lattner0c82ee72003-12-08 07:08:00 +000035
Chris Lattnere44f1db2003-11-23 18:12:22 +000036all :: test_each
37
38test_each: $(TESTS)
Reid Spencer3abd4972004-10-30 09:25:27 +000039 $(Echo) "Running Tests..."
40 $(Verb) LD_LIBRARY_PATH=$(BUILD_OBJ_ROOT)/lib/$(CONFIGURATION) $(BUILD_SRC_DIR)/runtests $(BUILD_OBJ_DIR) $(TESTS)
Chris Lattnere44f1db2003-11-23 18:12:22 +000041
Reid Spencer39dcf0e2004-09-04 20:13:54 +000042%.bc : %.st Makefile
Reid Spencer3abd4972004-10-30 09:25:27 +000043 $(Echo) "Compiling And Optimizing $< to $*.bc"
44 $(Verb)$(STKRC_EXEC) -f -O4 -s 2048 -o $*.bc $(BUILD_SRC_DIR)/$*.st
Chris Lattnere44f1db2003-11-23 18:12:22 +000045
Reid Spencer1694eec2004-09-11 04:15:09 +000046%.s : %.bc testing.bc
Reid Spencer3abd4972004-10-30 09:25:27 +000047 $(Echo) "Assembling $< to $*.s"
48 $(Verb)$(LLINK) $*.bc testing.bc -o $*.bcl
49 $(Verb)$(LLC) -f -o $*.s $*.bcl
Chris Lattnere44f1db2003-11-23 18:12:22 +000050
Reid Spencer1694eec2004-09-11 04:15:09 +000051% : %.s
Reid Spencer3abd4972004-10-30 09:25:27 +000052 $(Echo) "Linking $*"
53 $(Verb)$(CC) -ggdb -L$(BUILD_OBJ_ROOT)/lib/$(CONFIGURATION) -lstkr_runtime -o $* $*.s
Chris Lattnere44f1db2003-11-23 18:12:22 +000054
55%.ll : %.bc
Reid Spencer3abd4972004-10-30 09:25:27 +000056 $(Echo) "Disassembling $< to $*.ll"
57 $(Verb)$(LDIS) -dis -o $*.ll $<
Brian Gaeke3e4a2712003-11-24 02:57:25 +000058
59TESTS_LL = $(TESTS:%=%.ll)
60TESTS_BC = $(TESTS:%=%.bc)
61TESTS_S = $(TESTS:%=%.s)
Chris Lattnere44f1db2003-11-23 18:12:22 +000062
63clean ::
Reid Spencer3abd4972004-10-30 09:25:27 +000064 $(Verb)rm -f gmon.out $(TESTS_LL) $(TESTS_BC) $(TESTS_S) $(TESTS) testing.bc testing.s testing.ll
Chris Lattnere44f1db2003-11-23 18:12:22 +000065
Brian Gaeke3e4a2712003-11-24 02:57:25 +000066.SUFFIXES: .st .s .ll .bc
Chris Lattnere44f1db2003-11-23 18:12:22 +000067.PRECIOUS: %.s %.ll %.bc %.st
Brian Gaeke3e4a2712003-11-24 02:57:25 +000068.PHONY: test_each