| ##===- 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 = |
| |
| SAMPLES = fibonacci hello prime |
| |
| LLC_EXEC = $(BUILD_OBJ_ROOT)/tools/$(CONFIGURATION)/llc |
| OPT_EXEC = $(BUILD_OBJ_ROOT)/tools/$(CONFIGURATION)/opt |
| STKRC_EXEC = $(BUILD_OBJ_ROOT)/tools/$(CONFIGURATION)/stkrc |
| LLVMDIS_EXEC = $(BUILD_OBJ_ROOT)/tools/$(CONFIGURATION)/llvm-dis |
| |
| all :: $(SAMPLES) |
| |
| ifdef OPTIMIZE |
| %.bc : %.st |
| @$(ECHO) "Compiling and Optimizing $< to $*.bc" |
| $(VERB)$(STKRC_EXEC) -e -o - $< | opt -stats -q -f -o $*.bc \ |
| -aa-eval -adce -branch-combine -cee -constmerge -constprop -dce -die -ds-aa \ |
| -ds-opt -gcse -globaldce -indvars -inline -instcombine \ |
| -ipconstprop -licm -loopsimplify -mem2reg -pre -sccp -simplifycfg \ |
| -tailcallelim -verify |
| else |
| %.bc : %.st |
| @$(ECHO) "Compiling $< to $*.bc" |
| $(VERB)$(STKRC_EXEC) -e -f -o $*.bc $< |
| endif |
| |
| %.s : %.bc |
| @$(ECHO) "Compiling $< to $*.s" |
| $(VERB)$(LLC_EXEC) -f -o $*.s $< |
| |
| % : %.s |
| @$(ECHO) "Compiling and Linking $< to $*" |
| $(VERB)gcc -g -L$(BUILD_OBJ_ROOT)/lib/$(CONFIGURATION) -lstkr_runtime -o $* $*.s |
| |
| %.ll : %.bc |
| @$(ECHO) "Disassembling $< to $*.ll" |
| $(VERB)$(LLVMDIS_EXEC) -f -o $*.ll $< |
| |
| %.bc : $(STKRC_EXEC) |
| |
| .PRECIOUS: %.bc %.s %.ll %.st |
| |
| SAMPLES_LL = $(SAMPLES:%=%.ll) |
| SAMPLES_BC = $(SAMPLES:%=%.bc) |
| SAMPLES_S = $(SAMPLES:%=%.s) |
| |
| clean :: |
| $(VERB)rm -f gmon.out $(SAMPLES_LL) $(SAMPLES_BC) $(SAMPLES_S) $(SAMPLES) |
| # |
| # Include the Master Makefile that knows how to build all. |
| # |
| include $(LEVEL)/Makefile.common |