Makefile 1.93 KB
Newer Older
1
2
3
4
5
MQNICMOD := $(abspath ../images/mqnic/mqnic.ko)

GUESTS := \
    qemu-pair-client \
    qemu-pair-server \
6
7
8
    gem5-pair-client \
    gem5-pair-server-cp \
    gem5-pair-client-cp \
Jialin Li's avatar
Jialin Li committed
9
10
11
12
	qemu-nopaxos-replica-0 \
	qemu-nopaxos-replica-1 \
	qemu-nopaxos-replica-2 \
	qemu-nopaxos-client \
13
14
15
16
17
	gem5-nopaxos-client \
	gem5-nopaxos-replica-0-cp \
	gem5-nopaxos-replica-1-cp \
	gem5-nopaxos-replica-2-cp \
	gem5-nopaxos-client-cp \
18
19
20
21
22
23
24
25
26
	qemu-vr-replica-0 \
	qemu-vr-replica-1 \
	qemu-vr-replica-2 \
	qemu-vr-client \
	gem5-vr-replica-0-cp \
	gem5-vr-replica-1-cp \
	gem5-vr-replica-2-cp \
	gem5-vr-client-cp \

27
28
29
30

EXPERIMENTS := \
    qemu-corundum-bm-pair \
    qemu-corundum-verilator-pair \
31
32
    gem5-kvm-corundum-bm-pair \
    gem5-timing-corundum-verilator-pair \
33
    qemu-ns3-bridge-pair \
34
    qemu-ns3-dumbbell-pair \
35
    gem5-kvm-ns3-dumbbell-pair \
36

37
38
REPLICATION ?= 1

39
40
41
42
BUILDDIR := build
OUTDIR := out

GUESTS_TARS := $(addprefix $(BUILDDIR)/,$(addsuffix .tar, $(GUESTS)))
43
EXPERIMENTS_READY := $(addprefix $(OUTDIR)/,$(addsuffix /ready,$(EXPERIMENTS)))
44

45
all: $(GUESTS_TARS) $(EXPERIMENTS_READY)
46
47
48
49
50
51
52

clean:
	rm -rf $(BUILDDIR) $(OUTDIR)

#######################################
# Running experiments

53
54
55
56
57
58
59
60
61
62
63
define run_experiment_repl
$(OUTDIR)/%/$(1)/ready: experiments/%.sh $(GUESTS_TARS)
	bash $$< $(1)
	touch $$@
endef

REPLIDS := $(shell seq $(REPLICATION))

$(foreach i,$(REPLIDS), $(eval $(call run_experiment_repl,$(i))))

$(OUTDIR)/%/ready: experiments/%.sh $(addprefix $(OUTDIR)/%/,$(addsuffix /ready,$(REPLIDS)))
64
	touch $@
65
66
67
68

#######################################
# Guest Tars

69
70
guest-tars: $(GUESTS_TARS)

71
72
73
74
75
76
77
78
79
80
81
82
define build_guest
$(1)_OBJS := $(wildcard guests/$(1)/*)
$(BUILDDIR)/$(1).tar: $$($(1)_OBJS)
	rm -rf $(BUILDDIR)/$(1)
	mkdir -p $(BUILDDIR)/$(1)/guest
	cp $(MQNICMOD) $(BUILDDIR)/$(1)/guest/
	cp $$($(1)_OBJS) $(BUILDDIR)/$(1)/guest/
	cd $(BUILDDIR)/$(1) && tar cf $$(abspath $$@) guest/
	rm -rf $(BUILDDIR)/$(1)
endef

$(foreach guest,$(GUESTS), $(eval $(call build_guest,$(guest))))