-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMakefile
executable file
·155 lines (117 loc) · 4.04 KB
/
Makefile
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
# Project: RISC-V SoC Microarchitecture Design & Optimization
# GNU Makefile
# Author: Yichao Yuan, Li Shi
# Date: 2021/07/02
#
##### README:
# The simulation testbench can be selected by option
# SIM_TARGET
# e.g. SIM_TARGET=sim_main2 activate the spike-like simulatior
# SIMULATOR_PROG controls the program to run, form sim_main2,
# the program has to be elf. The default is spike-software/
# sobel.elf
#
# To start a spike-like simulation for verilated model, run
# make SIM_TARGET=sim_main2 SIMULATOR_PROG=spike-software/sobel.elf
#
# The reset PC should be set to 0x1000, see my note on
# src/frontend/inst_fetch.sv
#####
ifneq ($(words $(CURDIR)),1)
$(error Unsupported: GNU Make cannot build in directories containing spaces, build elsewhere: '$(CURDIR)')
endif
SOFTWARE_SUBDIR := software
SOFTWARE_TARGET := c_example c_hello
SOFTWARE_TARGET_PATH := $(addprefix $(SOFTWARE_SUBDIR)/, $(SOFTWARE_TARGET))
ifeq ($(VERILATOR_ROOT),)
VERILATOR = verilator
VERILATOR_COVERAGE = verilator_coverage
else
export VERILATOR_ROOT
VERILATOR = $(VERILATOR_ROOT)/bin/verilator
VERILATOR_COVERAGE = $(VERILATOR_ROOT)/bin/verilator_coverage
endif
VERILATOR_FLAGS += --top-module top
# Generate C++ in executable form
VERILATOR_FLAGS += -cc -exe
# suppress all warnings
VERILATOR_FLAGS += -Wno-UNOPTFLAT
VERILATOR_FLAGS += -Wno-WIDTH
VERILATOR_FLAGS += -Wno-PINMISSING
# Optimize
# VERILATOR_FLAGS += -Os -x-assign 0
# Warn abount lint issues; may not want this on less solid designs
# VERILATOR_FLAGS += -Wall
# Make waveforms
VERILATOR_FLAGS += --trace-fst
# Check SystemVerilog assertions
VERILATOR_FLAGS += --assert
VERILATOR_FLAGS += --unroll-count 128
VERILOG_ROOT := src
# Input files for Verilator
VERILOG_SRC = $(wildcard src/common/*.svh src/external/fifo/*.v src/external/*.sv src/frontend/*.sv src/backend/*.sv src/*.sv)
# [use this to change testbench]
# a spike-like environment is sim_main2, not tested yet, the entry point of the CPU should be default to 0x80000000
SIM_TARGET = sim_main2
SIM_TARGET_SRC = $(SIM_TARGET).cc
include sim/fesvr450.mk.in
SIM_SRC := $(addprefix sim/, $(fesvr450_srcs) $(SIM_TARGET_SRC))
VERILATOR_OPTIONS := input.vc
# Input files for Verilator
VERILATOR_INPUT = -f $(VERILATOR_OPTIONS) $(VERILOG_SRC) $(SIM_SRC)
# the program to run
#
# SIMULATOR_PROG = prog/bin/c_example.bin
SIMULATOR_PROG = spike-software/insertionSort.elf
#SIMULATOR_PROG = myfile
# the dmem init
#SIMULATOR_DATA_INIT = software/c_example/c_example.bin
default: run
verilate:
@echo
@echo "-- VERILATE ----------------"
@echo "Inputs: "
@echo $(VERILATOR_INPUT)
$(VERILATOR) $(VERILATOR_FLAGS) $(VERILATOR_INPUT)
@echo
build: verilate
$(MAKE) -j -C obj_dir -f ../Makefile_obj
@echo
run: build
@rm -rf logs
@mkdir -p logs
obj_dir/Vtop ${SIMULATOR_PROG} +trace
@echo "-- DONE --------------------"
@echo "To see waveforms, open vlt_dump.fst in a waveform viewer"
@echo
view-wave: run make-spike
gtkwave obj_dir/vlt_dump.fst
######################################################################
# Other targets
.PHONY: build-soft $(SOFTWARE_TARGET_PATH) install-soft sim-spike
build-soft: $(SOFTWARE_TARGET_PATH)
export SOFTWARE_TARGET
$(SOFTWARE_TARGET_PATH):
$(MAKE) -C $@
SOFTWARE_ELF := $(foreach target, ${SOFTWARE_TARGET}, $(addsuffix .elf, $(addprefix $(SOFTWARE_SUBDIR)/$(target)/, $(target))))
SOFTWARE_BIN := $(foreach target, ${SOFTWARE_TARGET}, $(addsuffix .bin, $(addprefix $(SOFTWARE_SUBDIR)/$(target)/, $(target))))
install-soft: build-soft
cp ${SOFTWARE_ELF} prog/elf
cp ${SOFTWARE_BIN} prog/bin
show-config:
$(VERILATOR) -V
####### spike software, will be merged to the verilator flow when everthing is done ########
SPIKE_BIN := bin/spike
SPIKE_PROG_DIR := spike-software
SPIKE_OPT := --isa=rv32i --priv=mu -l
sim-spike: make-spike
$(SPIKE_BIN) $(SPIKE_OPT) $(SIMULATOR_PROG)
make-spike:
$(MAKE) -C $(SPIKE_PROG_DIR)
maintainer-copy::
clean mostlyclean distclean maintainer-clean::
-rm -rf obj_dir logs *.log *.dmp *.vpd coverage.dat core
WAVEFORM_VIEWER := gtkwave
.PHONY: view-waveform
view-waveform:
$(WAVEFORM_VIEWER) logs/vlt_dump.fst