GC := cdgc O := build/$(GC) DC := dmd LD := dmd LN := ln GNUPLOT := gnuplot override DFLAGS ?= -release -inline -O -gc LDFLAGS := -defaultlib=tango-$(GC) -debuglib=tango-$(GC) LIBTANGO := ../lib/libtango-$(GC).a ifndef V P = @ P_DC = @printf ' DC %- 40s <- %s\n' '$@' '$(if \ $(subst 1,,$(words $^)),$< ... $(lastword $^),$<)'; P_PLOT = @printf ' PLOT %- 40s <- %s\n' '$@' '$(filter %.csv,$^)'; P_AWK = @printf ' AWK %- 40s <- %s\n' '$@' '$<'; P_RUN = @printf ' RUN $< $(args)\n'; P_MAKE = @printf ' MAKE $@\n'; P_RM = @printf ' RM $^\n'; P_LN = @printf ' LN %- 40s <- %s\n' '$@' '$<'; endif # create build directories if they don't already exist dummy_mkdir := $(shell mkdir -p $O $O/bin $O/time $O/stats) .PHONY: all all: cdgc basic .PHONY: cdgc basic cdgc basic: $(P_MAKE) $(MAKE) --no-print-directory micro-time dil-build GC=$@ # micro ######## micro-src := $(wildcard micro/*.d) .PHONY: micro-build micro-build: $(patsubst micro/%.d,$O/bin/%,$(wildcard micro/*.d)) .PRECIOUS: $O/bin/% $O/bin/%: $O/micro/%.o $(P_DC) $(DC) $(LDFLAGS) -of$@ $^ .PHONY: micro-time micro-time: $O/time/stats.csv .PHONY: micro-stats micro-stats: $(patsubst micro/%.d,$O/stats/%.eps,$(wildcard micro/*.d)) # special command line arguments for 'shootout_binarytrees' micro benchmark $O/time/shootout_binarytrees.t.csv $O/time/shootout_binarytrees.s.csv \ $O/stats/shootout_binarytrees.c.csv \ $O/stats/shootout_binarytrees.a.csv: \ override args := 16 # special command line arguments for 'split' micro benchmark $O/time/split.t.csv $O/time/split.s.csv \ $O/stats/split.c.csv $O/stats/split.a.csv: \ override args := micro/bible.txt # special command line arguments for 'voronoi' micro benchmark $O/time/voronoi.t.csv $O/time/voronoi.s.csv \ $O/stats/voronoi.c.csv $O/voronoi/split.a.csv: \ override args := -n 30000 # dil ###### DIL_SRC = $(wildcard dil/src/*.d dil/src/cmd/*.d dil/src/util/*.d \ dil/src/dil/*.d dil/src/dil/*/*.d) .PHONY: dil-nop-stats dil-nop-stats: $O/stats/dil-nop.eps .PHONY: dil-build dil-build: $O/bin/dil $O/bin/dil: override DFLAGS += -Idil/src $O/bin/dil: $(patsubst %.d,$O/%.o,$(DIL_SRC)) $(LIBTANGO) $(P_DC) $(DC) $(LDFLAGS) -L-lmpfr -L-lgmp -of$@ $^ $O/bin/dil-nop: $O/bin/dil @$(P_LN) $(LN) -sf $( $@ ($I)' $P echo -n > $@ $P for i in `seq $I`; do \ echo -n " $$i"; \ time -f%e -a -o $@ ./$< $(args); \ done; echo .PRECIOUS: $O/time/stats.csv $O/time/stats.csv: $(patsubst micro/%.d,$O/time/%.t.csv,$(micro-src)) $P echo -n > $@ $P for t in $^; do \ (echo -n `basename $$t`,; ./stats.py < $$t) >> $@; \ echo " STATS `tail -n1 $@` >> $@"; \ done .PRECIOUS: $O/stats/%.c.csv $O/stats/%.a.csv $O/stats/%.c.csv $O/stats/%.a.csv: $O/bin/% $(P_RUN) D_GC_STATS=1 ./$< $(args) $P mv gc-collections.csv $O/stats/$*.c.csv $P mv gc-mallocs.csv $O/stats/$*.a.csv .PRECIOUS: $O/stats/%.h.csv $O/stats/%.h.csv: $O/stats/%.a.csv hist.awk $(P_AWK) awk -F, -f $(lastword $^) $< > $@ .PRECIOUS: $O/stats/%.tics $O/stats/%.tics: $O/stats/%.h.csv tics.awk $(P_AWK) awk -F, -f $(lastword $^) $< > $@ $O/stats/%.eps: $O/stats/%.c.csv $O/stats/%.a.csv $O/stats/%.h.csv \ $O/stats/%.tics plot.gpi $(P_PLOT) sed "s|@@PRG@@|$(*F)|g; s|@@COL@@|$(GC)|g; \ s|@@INC@@|$(word 1,$^)|g; s|@@INA@@|$(word 2,$^)|g; \ s|@@INH@@|$(word 3,$^)|g; s|@@OUT@@|$@|g; \ s|@@TICS@@|$(shell cat $(word 4,$^))|g" $(word 5,$^) \ | $(GNUPLOT) .PHONY: clean clean: $O/ $(P_RM) $(RM) -r $^ .PHONY: clean-all clean-all: clean-cdgc clean-basic clean-cdgc: $(P_MAKE) $(MAKE) --no-print-directory clean GC=cdgc clean-basic: $(P_MAKE) $(MAKE) --no-print-directory clean GC=basic