forked from ucb-bar/riscv-sodor
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile.in
159 lines (115 loc) · 5.67 KB
/
Makefile.in
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
#=======================================================================
# UCB Chisel C++ Simulator Generator: Makefile
#-----------------------------------------------------------------------
# Christopher Celio ([email protected])
#
# This makefile will generate a processor emulator from chisel code.
#
# Many different processors are provided. To switch between which processor(s)
# you would like to build, simply set the $(targets) variable as appropriate.
all_targets := rv32_1stage rv32_2stage rv32_3stage rv32_5stage rv32_ucode
targets := $(all_targets)
# To switch between which processor the Makefile would like to build, it will
# change the bash environment variable $MK_TARGET_PROC as follows:
# "export MK_TARGET_PROC=rv32_1stage"
# "export MK_TARGET_PROC=rv32_2stage"
# "export MK_TARGET_PROC=rv32_5stage"
# "export MK_TARGET_PROC=rv32_ucode"
include @top_builddir@/prefix.mk
MK_TARGET_PROC?=rv32_1stage
prerequisites := $(if $(chiseldir),chisel-timestamp)
all: $(prerequisites) $(patsubst %,emulator/%/emulator,$(targets))
install: all
install -d $(RISCV)/bin
$(if $(findstring rv32_1stage,$(targets)),install -s -p -m 755 emulator/rv32_1stage/emulator $(RISCV)/bin/rv32_1stage-emulator)
$(if $(findstring rv32_2stage,$(targets)),install -s -p -m 755 emulator/rv32_2stage/emulator $(RISCV)/bin/rv32_2stage-emulator)
$(if $(findstring rv32_3stage,$(targets)),install -s -p -m 755 emulator/rv32_3stage/emulator $(RISCV)/bin/rv32_3stage-emulator)
$(if $(findstring rv32_5stage,$(targets)),install -s -p -m 755 emulator/rv32_5stage/emulator $(RISCV)/bin/rv32_5stage-emulator)
$(if $(findstring rv32_ucode,$(targets)),install -s -p -m 755 emulator/rv32_ucode/emulator $(RISCV)/bin/rv32_ucode-emulator)
dist-src:
cd $(srcDir) && git archive --prefix=sodor/ -o $(buildDir)/sodor-`git rev-parse --short HEAD`.tar.gz HEAD
compile:
$(SBT) "project ${MK_TARGET_PROC}" compile
shell:
$(SBT) "project ${MK_TARGET_PROC}" shell
debug:
$(SBT) "project ${MK_TARGET_PROC}" "last run"
console:
$(SBT) "project ${MK_TARGET_PROC}" console
timestamps := $(foreach x,$(targets),emulator/$(x)/generated-src/timestamp)
timestamps_debug := $(foreach x,$(targets),emulator/$(x)/generated-src-debug/timestamp)
run-emulator: $(timestamps)
run-emulator-debug: $(timestamps_debug)
clean-tests:
for d in $(addprefix emulator/,$(all_targets)) ; do \
$(MAKE) -C "$${d}" clean-tests ; \
done
$(RM) $(timestamps) $(timestamps_debug)
clean:
-find sbt -type d -name target -exec rm -rf {} \+
for d in $(addprefix emulator/,$(all_targets)) ; do \
$(MAKE) -C "$${d}" clean ; \
done
$(RM) $(timestamps) $(timestamps_debug)
$(RM) test-results.xml
reports: test-results.xml report-cpi report-bp report-stats
report-cpi: $(patsubst %,%-report-cpi,$(targets))
report-bp: $(patsubst %,%-report-bp,$(targets))
report-stats: $(patsubst %,%-report-stats,$(targets))
chisel-timestamp: $(wildcard $(chiseldir)/src/main/scala/*.scala)
cd $(chiseldir) && $(SBT) publish-local
date > $@
test-results.xml: $(wildcard $(patsubst %,emulator/%/output/*.out,$(targets)))
$(srcDir)/project/check $^ > test-results.xml
%-report-cpi:
-grep CPI emulator/$(patsubst %-report-cpi,%,$@)/output/*.out
%-report-bp:
-grep Acc emulator/$(patsubst %-report-bp,%,$@)/output/*.out
%-report-stats:
-grep "#" emulator/$(patsubst %-report-stats,%,$@)/output/*.out
emulator/%/generated-src/timestamp: emulator/%/emulator
@echo
@echo running basedir/Makefile: make run-emulator
@echo
$(MAKE) -C $(dir $<) run
install -d $(dir $@)
date > $@
emulator/%/generated-src-debug/timestamp: emulator/%/emulator-debug
@echo
@echo running basedir/Makefile: make run-emulator-debug
@echo
$(MAKE) -C $(dir $<) run-debug
install -d $(dir $@)
date > $@
emulator/%/emulator: $(prerequisites)
$(MAKE) -C $(dir $@)
emulator/%/emulator-debug: $(prerequisites)
$(MAKE) -C $(dir $@) emulator-debug
.PHONY: all install dist-src compile shell debug console
.PHONY: run-emulator run-emulator-debug target clean clean-tests
.PHONY: reports report-cpi report-bp report-stats
# Because we are using recursive makefiles and emulator is an actual file.
emulator/rv32_1stage/emulator: $(wildcard $(srcDir)/src/common/*.scala) \
$(wildcard $(srcDir)/src/rv32_1stage/*.scala)
emulator/rv32_2stage/emulator: $(wildcard $(srcDir)/src/common/*.scala) \
$(wildcard $(srcDir)/src/rv32_2stage/*.scala)
emulator/rv32_3stage/emulator: $(wildcard $(srcDir)/src/common/*.scala) \
$(wildcard $(srcDir)/src/rv32_3stage/*.scala)
emulator/rv32_5stage/emulator: $(wildcard $(srcDir)/src/common/*.scala) \
$(wildcard $(srcDir)/src/rv32_5stage/*.scala)
emulator/rv32_ucode/emulator: $(wildcard $(srcDir)/src/common/*.scala) \
$(wildcard $(srcDir)/src/rv32_ucode/*.scala)
emulator/rv32_1stage/emulator-debug: $(wildcard $(srcDir)/src/common/*.scala) \
$(wildcard $(srcDir)/src/rv32_1stage/*.scala)
emulator/rv32_2stage/emulator-debug: $(wildcard $(srcDir)/src/common/*.scala) \
$(wildcard $(srcDir)/src/rv32_2stage/*.scala)
emulator/rv32_3stage/emulator-debug: $(wildcard $(srcDir)/src/common/*.scala) \
$(wildcard $(srcDir)/src/rv32_3stage/*.scala)
emulator/rv32_5stage/emulator-debug: $(wildcard $(srcDir)/src/common/*.scala) \
$(wildcard $(srcDir)/src/rv32_5stage/*.scala)
emulator/rv32_ucode/emulator-debug: $(wildcard $(srcDir)/src/common/*.scala) \
$(wildcard $(srcDir)/src/rv32_ucode/*.scala)
.PHONY: jenkins-build
jenkins-build:
$(MAKE) clean run-emulator
$(MAKE) reports