Reid Spencer | 39dcf0e | 2004-09-04 20:13:54 +0000 | [diff] [blame] | 1 | ##===- projects/Stacker/test/Makefile ----------------------*- Makefile -*-===## |
Chris Lattner | e44f1db | 2003-11-23 18:12:22 +0000 | [diff] [blame] | 2 | # |
Reid Spencer | 39dcf0e | 2004-09-04 20:13:54 +0000 | [diff] [blame] | 3 | # This is the makefile that tests the various facilities of the Stacker language |
Chris Lattner | e44f1db | 2003-11-23 18:12:22 +0000 | [diff] [blame] | 4 | # |
| 5 | ##===----------------------------------------------------------------------===## |
| 6 | |
| 7 | # |
| 8 | # Indicates our relative path to the top of the project's root directory. |
| 9 | # |
Reid Spencer | 39dcf0e | 2004-09-04 20:13:54 +0000 | [diff] [blame] | 10 | LEVEL = ../ |
Chris Lattner | e44f1db | 2003-11-23 18:12:22 +0000 | [diff] [blame] | 11 | |
| 12 | # |
Reid Spencer | 39dcf0e | 2004-09-04 20:13:54 +0000 | [diff] [blame] | 13 | # Directories that need to be built. |
Chris Lattner | e44f1db | 2003-11-23 18:12:22 +0000 | [diff] [blame] | 14 | # |
| 15 | DIRS = |
| 16 | |
| 17 | # |
| 18 | # Include the Master Makefile that knows how to build all. |
| 19 | # |
| 20 | include $(LEVEL)/Makefile.common |
| 21 | |
| 22 | LOGIC_TESTS = eq ne le ge gt lt false true |
| 23 | BITWISE_TESTS = shl shr xor or and |
| 24 | ARITHMETIC_TESTS = abs neg add sub mul div mod star_slash incr decr min max |
| 25 | STACK_TESTS = drop drop2 nip nip2 dup dup2 swap swap2 over over2 rot rot2 \ |
| 26 | rrot rrot2 tuck tuck2 roll pick select |
| 27 | MEMORY_TESTS = memory |
| 28 | CONTROL_TESTS = while return |
| 29 | IO_TESTS = space tab out_chr out_num out_str |
| 30 | |
| 31 | TESTS = $(LOGIC_TESTS) $(ARITHMETIC_TESTS) $(BITWISE_TESTS) $(STACK_TESTS) \ |
| 32 | $(MEMORY_TESTS) $(CONTROL_TESTS) $(IO_TESTS) |
| 33 | |
Chris Lattner | 0c82ee7 | 2003-12-08 07:08:00 +0000 | [diff] [blame] | 34 | STKRC_EXEC = $(BUILD_OBJ_ROOT)/tools/$(CONFIGURATION)/stkrc |
Chris Lattner | 0c82ee7 | 2003-12-08 07:08:00 +0000 | [diff] [blame] | 35 | |
Chris Lattner | e44f1db | 2003-11-23 18:12:22 +0000 | [diff] [blame] | 36 | all :: test_each |
| 37 | |
| 38 | test_each: $(TESTS) |
Reid Spencer | 3abd497 | 2004-10-30 09:25:27 +0000 | [diff] [blame^] | 39 | $(Echo) "Running Tests..." |
| 40 | $(Verb) LD_LIBRARY_PATH=$(BUILD_OBJ_ROOT)/lib/$(CONFIGURATION) $(BUILD_SRC_DIR)/runtests $(BUILD_OBJ_DIR) $(TESTS) |
Chris Lattner | e44f1db | 2003-11-23 18:12:22 +0000 | [diff] [blame] | 41 | |
Reid Spencer | 39dcf0e | 2004-09-04 20:13:54 +0000 | [diff] [blame] | 42 | %.bc : %.st Makefile |
Reid Spencer | 3abd497 | 2004-10-30 09:25:27 +0000 | [diff] [blame^] | 43 | $(Echo) "Compiling And Optimizing $< to $*.bc" |
| 44 | $(Verb)$(STKRC_EXEC) -f -O4 -s 2048 -o $*.bc $(BUILD_SRC_DIR)/$*.st |
Chris Lattner | e44f1db | 2003-11-23 18:12:22 +0000 | [diff] [blame] | 45 | |
Reid Spencer | 1694eec | 2004-09-11 04:15:09 +0000 | [diff] [blame] | 46 | %.s : %.bc testing.bc |
Reid Spencer | 3abd497 | 2004-10-30 09:25:27 +0000 | [diff] [blame^] | 47 | $(Echo) "Assembling $< to $*.s" |
| 48 | $(Verb)$(LLINK) $*.bc testing.bc -o $*.bcl |
| 49 | $(Verb)$(LLC) -f -o $*.s $*.bcl |
Chris Lattner | e44f1db | 2003-11-23 18:12:22 +0000 | [diff] [blame] | 50 | |
Reid Spencer | 1694eec | 2004-09-11 04:15:09 +0000 | [diff] [blame] | 51 | % : %.s |
Reid Spencer | 3abd497 | 2004-10-30 09:25:27 +0000 | [diff] [blame^] | 52 | $(Echo) "Linking $*" |
| 53 | $(Verb)$(CC) -ggdb -L$(BUILD_OBJ_ROOT)/lib/$(CONFIGURATION) -lstkr_runtime -o $* $*.s |
Chris Lattner | e44f1db | 2003-11-23 18:12:22 +0000 | [diff] [blame] | 54 | |
| 55 | %.ll : %.bc |
Reid Spencer | 3abd497 | 2004-10-30 09:25:27 +0000 | [diff] [blame^] | 56 | $(Echo) "Disassembling $< to $*.ll" |
| 57 | $(Verb)$(LDIS) -dis -o $*.ll $< |
Brian Gaeke | 3e4a271 | 2003-11-24 02:57:25 +0000 | [diff] [blame] | 58 | |
| 59 | TESTS_LL = $(TESTS:%=%.ll) |
| 60 | TESTS_BC = $(TESTS:%=%.bc) |
| 61 | TESTS_S = $(TESTS:%=%.s) |
Chris Lattner | e44f1db | 2003-11-23 18:12:22 +0000 | [diff] [blame] | 62 | |
| 63 | clean :: |
Reid Spencer | 3abd497 | 2004-10-30 09:25:27 +0000 | [diff] [blame^] | 64 | $(Verb)rm -f gmon.out $(TESTS_LL) $(TESTS_BC) $(TESTS_S) $(TESTS) testing.bc testing.s testing.ll |
Chris Lattner | e44f1db | 2003-11-23 18:12:22 +0000 | [diff] [blame] | 65 | |
Brian Gaeke | 3e4a271 | 2003-11-24 02:57:25 +0000 | [diff] [blame] | 66 | .SUFFIXES: .st .s .ll .bc |
Chris Lattner | e44f1db | 2003-11-23 18:12:22 +0000 | [diff] [blame] | 67 | .PRECIOUS: %.s %.ll %.bc %.st |
Brian Gaeke | 3e4a271 | 2003-11-24 02:57:25 +0000 | [diff] [blame] | 68 | .PHONY: test_each |