1 noarg: 2 $(MAKE) -C ../ 3 4 TEST_GEN_PROGS := count_instructions l3_bank_test per_event_excludes 5 EXTRA_SOURCES := ../harness.c event.c lib.c ../utils.c 6 7 include ../../lib.mk 8 9 all: $(TEST_GEN_PROGS) ebb 10 11 $(TEST_GEN_PROGS): $(EXTRA_SOURCES) 12 13 # loop.S can only be built 64-bit 14 $(OUTPUT)/count_instructions: loop.S count_instructions.c $(EXTRA_SOURCES) 15 $(CC) $(CFLAGS) -m64 -o $@ $^ 16 17 $(OUTPUT)/per_event_excludes: ../utils.c 18 19 DEFAULT_RUN_TESTS := $(RUN_TESTS) 20 override define RUN_TESTS 21 $(DEFAULT_RUN_TESTS) 22 TARGET=ebb; BUILD_TARGET=$$OUTPUT/$$TARGET; $(MAKE) OUTPUT=$$BUILD_TARGET -C $$TARGET run_tests 23 endef 24 25 DEFAULT_EMIT_TESTS := $(EMIT_TESTS) 26 override define EMIT_TESTS 27 $(DEFAULT_EMIT_TESTS) 28 TARGET=ebb; BUILD_TARGET=$$OUTPUT/$$TARGET; $(MAKE) OUTPUT=$$BUILD_TARGET -s -C $$TARGET emit_tests 29 endef 30 31 DEFAULT_INSTALL_RULE := $(INSTALL_RULE) 32 override define INSTALL_RULE 33 $(DEFAULT_INSTALL_RULE) 34 TARGET=ebb; BUILD_TARGET=$$OUTPUT/$$TARGET; $(MAKE) OUTPUT=$$BUILD_TARGET -C $$TARGET install 35 endef 36 37 clean: 38 $(RM) $(TEST_GEN_PROGS) $(OUTPUT)/loop.o 39 TARGET=ebb; BUILD_TARGET=$$OUTPUT/$$TARGET; $(MAKE) OUTPUT=$$BUILD_TARGET -C $$TARGET clean 40 41 ebb: 42 TARGET=$@; BUILD_TARGET=$$OUTPUT/$$TARGET; mkdir -p $$BUILD_TARGET; $(MAKE) OUTPUT=$$BUILD_TARGET -k -C $$TARGET all 43 44 .PHONY: all run_tests clean ebb 45