Chris Lattner | 9d014e7 | 2003-11-23 17:55:19 +0000 | [diff] [blame] | 1 | ##===- projects/sample/Makefile ----------------------------*- Makefile -*-===## |
| 2 | # |
| 3 | # This is a sample Makefile for a project that uses LLVM. |
| 4 | # |
| 5 | ##===----------------------------------------------------------------------===## |
| 6 | |
| 7 | # |
| 8 | # Indicates our relative path to the top of the project's root directory. |
| 9 | # |
| 10 | LEVEL = ../../.. |
| 11 | |
| 12 | # |
| 13 | # Directories that needs to be built. |
| 14 | # |
| 15 | DIRS = |
| 16 | |
Brian Gaeke | 3e4a271 | 2003-11-24 02:57:25 +0000 | [diff] [blame] | 17 | SAMPLES = fibonacci hello prime |
Chris Lattner | 9d014e7 | 2003-11-23 17:55:19 +0000 | [diff] [blame] | 18 | |
Chris Lattner | 0c82ee7 | 2003-12-08 07:08:00 +0000 | [diff] [blame] | 19 | LLC_EXEC = $(BUILD_OBJ_ROOT)/tools/$(CONFIGURATION)/llc |
| 20 | OPT_EXEC = $(BUILD_OBJ_ROOT)/tools/$(CONFIGURATION)/opt |
| 21 | STKRC_EXEC = $(BUILD_OBJ_ROOT)/tools/$(CONFIGURATION)/stkrc |
| 22 | LLVMDIS_EXEC = $(BUILD_OBJ_ROOT)/tools/$(CONFIGURATION)/llvm-dis |
| 23 | |
Brian Gaeke | 3e4a271 | 2003-11-24 02:57:25 +0000 | [diff] [blame] | 24 | all :: $(SAMPLES) |
Chris Lattner | 9d014e7 | 2003-11-23 17:55:19 +0000 | [diff] [blame] | 25 | |
| 26 | ifdef OPTIMIZE |
Reid Spencer | 6cb21d4 | 2004-10-27 23:18:45 +0000 | [diff] [blame^] | 27 | % : %.st |
Brian Gaeke | 3e4a271 | 2003-11-24 02:57:25 +0000 | [diff] [blame] | 28 | @$(ECHO) "Compiling and Optimizing $< to $*.bc" |
Chris Lattner | 0c82ee7 | 2003-12-08 07:08:00 +0000 | [diff] [blame] | 29 | $(VERB)$(STKRC_EXEC) -e -o - $< | opt -stats -q -f -o $*.bc \ |
Chris Lattner | 9d014e7 | 2003-11-23 17:55:19 +0000 | [diff] [blame] | 30 | -aa-eval -adce -branch-combine -cee -constmerge -constprop -dce -die -ds-aa \ |
| 31 | -ds-opt -gcse -globaldce -indvars -inline -instcombine \ |
| 32 | -ipconstprop -licm -loopsimplify -mem2reg -pre -sccp -simplifycfg \ |
| 33 | -tailcallelim -verify |
| 34 | else |
| 35 | %.bc : %.st |
Brian Gaeke | 3e4a271 | 2003-11-24 02:57:25 +0000 | [diff] [blame] | 36 | @$(ECHO) "Compiling $< to $*.bc" |
Chris Lattner | 0c82ee7 | 2003-12-08 07:08:00 +0000 | [diff] [blame] | 37 | $(VERB)$(STKRC_EXEC) -e -f -o $*.bc $< |
Chris Lattner | 9d014e7 | 2003-11-23 17:55:19 +0000 | [diff] [blame] | 38 | endif |
| 39 | |
| 40 | %.s : %.bc |
Brian Gaeke | 3e4a271 | 2003-11-24 02:57:25 +0000 | [diff] [blame] | 41 | @$(ECHO) "Compiling $< to $*.s" |
Chris Lattner | 0c82ee7 | 2003-12-08 07:08:00 +0000 | [diff] [blame] | 42 | $(VERB)$(LLC_EXEC) -f -o $*.s $< |
Chris Lattner | 9d014e7 | 2003-11-23 17:55:19 +0000 | [diff] [blame] | 43 | |
| 44 | % : %.s |
Brian Gaeke | 3e4a271 | 2003-11-24 02:57:25 +0000 | [diff] [blame] | 45 | @$(ECHO) "Compiling and Linking $< to $*" |
Chris Lattner | 0c82ee7 | 2003-12-08 07:08:00 +0000 | [diff] [blame] | 46 | $(VERB)gcc -g -L$(BUILD_OBJ_ROOT)/lib/$(CONFIGURATION) -lstkr_runtime -o $* $*.s |
Chris Lattner | 9d014e7 | 2003-11-23 17:55:19 +0000 | [diff] [blame] | 47 | |
| 48 | %.ll : %.bc |
Brian Gaeke | 3e4a271 | 2003-11-24 02:57:25 +0000 | [diff] [blame] | 49 | @$(ECHO) "Disassembling $< to $*.ll" |
Chris Lattner | 0c82ee7 | 2003-12-08 07:08:00 +0000 | [diff] [blame] | 50 | $(VERB)$(LLVMDIS_EXEC) -f -o $*.ll $< |
Chris Lattner | 9d014e7 | 2003-11-23 17:55:19 +0000 | [diff] [blame] | 51 | |
Chris Lattner | 0c82ee7 | 2003-12-08 07:08:00 +0000 | [diff] [blame] | 52 | %.bc : $(STKRC_EXEC) |
Chris Lattner | 9d014e7 | 2003-11-23 17:55:19 +0000 | [diff] [blame] | 53 | |
| 54 | .PRECIOUS: %.bc %.s %.ll %.st |
Brian Gaeke | 3e4a271 | 2003-11-24 02:57:25 +0000 | [diff] [blame] | 55 | |
| 56 | SAMPLES_LL = $(SAMPLES:%=%.ll) |
| 57 | SAMPLES_BC = $(SAMPLES:%=%.bc) |
| 58 | SAMPLES_S = $(SAMPLES:%=%.s) |
| 59 | |
| 60 | clean :: |
| 61 | $(VERB)rm -f gmon.out $(SAMPLES_LL) $(SAMPLES_BC) $(SAMPLES_S) $(SAMPLES) |
Chris Lattner | 9d014e7 | 2003-11-23 17:55:19 +0000 | [diff] [blame] | 62 | # |
| 63 | # Include the Master Makefile that knows how to build all. |
| 64 | # |
| 65 | include $(LEVEL)/Makefile.common |