2014-09-01 05:26:55 +02:00
|
|
|
#--------------------------------------------------------------------
|
|
|
|
# Sources
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
|
|
|
|
# Verilog sources
|
|
|
|
|
2016-08-19 18:46:43 +02:00
|
|
|
bb_vsrcs = $(base_dir)/vsrc/DebugTransportModuleJtag.v \
|
2016-09-02 03:38:39 +02:00
|
|
|
$(base_dir)/vsrc/jtag_vpi.v \
|
2016-09-09 05:01:03 +02:00
|
|
|
$(base_dir)/vsrc/AsyncMailbox.v \
|
2016-09-14 20:50:28 +02:00
|
|
|
$(base_dir)/vsrc/AsyncResetReg.v \
|
2016-09-16 22:50:09 +02:00
|
|
|
$(base_dir)/vsrc/AsyncSetReg.v \
|
2016-09-14 20:50:28 +02:00
|
|
|
$(base_dir)/vsrc/ClockDivider.v \
|
2016-09-16 22:50:09 +02:00
|
|
|
$(base_dir)/vsrc/ClockToSignal.v \
|
|
|
|
$(base_dir)/vsrc/SignalToClock.v \
|
|
|
|
|
2016-08-19 18:46:43 +02:00
|
|
|
|
2014-09-01 05:26:55 +02:00
|
|
|
sim_vsrcs = \
|
2014-09-12 07:11:58 +02:00
|
|
|
$(generated_dir)/$(MODEL).$(CONFIG).v \
|
2016-09-06 23:48:28 +02:00
|
|
|
$(generated_dir)/$(MODEL).$(CONFIG).behav_srams.v \
|
2014-09-12 07:11:58 +02:00
|
|
|
$(generated_dir)/consts.$(CONFIG).vh \
|
2016-09-02 03:38:39 +02:00
|
|
|
$(base_dir)/vsrc/$(TB).v \
|
2016-08-16 07:03:03 +02:00
|
|
|
$(base_dir)/vsrc/SimDTM.v \
|
2016-08-19 18:46:43 +02:00
|
|
|
$(bb_vsrcs)
|
2014-09-01 05:26:55 +02:00
|
|
|
|
|
|
|
# C sources
|
|
|
|
|
|
|
|
sim_csrcs = \
|
2016-08-16 07:03:03 +02:00
|
|
|
$(base_dir)/csrc/SimDTM.cc \
|
2016-08-19 18:46:43 +02:00
|
|
|
$(base_dir)/csrc/jtag_vpi.c
|
2014-09-01 05:26:55 +02:00
|
|
|
|
2014-09-04 18:49:57 +02:00
|
|
|
#--------------------------------------------------------------------
|
|
|
|
# Build Verilog
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
|
|
|
|
verilog: $(sim_vsrcs)
|
|
|
|
|
|
|
|
.PHONY: verilog
|
|
|
|
|
2014-09-01 05:26:55 +02:00
|
|
|
#--------------------------------------------------------------------
|
|
|
|
# Build rules
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
|
|
|
|
VCS = vcs -full64
|
|
|
|
|
2014-09-25 15:43:03 +02:00
|
|
|
VCS_OPTS = -notice -line +lint=all,noVCDE,noONGS,noUI -error=PCWM-L -timescale=1ns/10ps -quiet \
|
2014-09-01 05:26:55 +02:00
|
|
|
+rad +v2k +vcs+lic+wait \
|
|
|
|
+vc+list -CC "-I$(VCS_HOME)/include" \
|
|
|
|
-CC "-I$(RISCV)/include" \
|
|
|
|
-CC "-std=c++11" \
|
|
|
|
-CC "-Wl,-rpath,$(RISCV)/lib" \
|
2015-11-06 01:42:05 +01:00
|
|
|
-CC "-include $(consts_header)" \
|
2014-09-01 05:26:55 +02:00
|
|
|
$(RISCV)/lib/libfesvr.so \
|
2016-06-24 05:54:07 +02:00
|
|
|
-sverilog \
|
2015-10-31 05:14:33 +01:00
|
|
|
+incdir+$(generated_dir) \
|
2016-08-19 23:44:48 +02:00
|
|
|
+define+CLOCK_PERIOD=1.0 $(sim_vsrcs) $(sim_csrcs) \
|
2016-04-02 01:40:13 +02:00
|
|
|
+define+PRINTF_COND=$(TB).printf_cond \
|
2016-08-16 07:03:03 +02:00
|
|
|
+define+STOP_COND=!$(TB).reset \
|
2016-08-29 21:29:01 +02:00
|
|
|
+define+RANDOMIZE_MEM_INIT \
|
|
|
|
+define+RANDOMIZE_REG_INIT \
|
|
|
|
+define+RANDOMIZE_GARBAGE_ASSIGN \
|
|
|
|
+define+RANDOMIZE_INVALID_ASSIGN \
|
2014-09-01 05:26:55 +02:00
|
|
|
+libext+.v \
|
|
|
|
|
2016-08-19 18:46:43 +02:00
|
|
|
VCS_OPTS += +vpi
|
|
|
|
VCS_OPTS += -P $(base_dir)/vsrc/jtag_vpi.tab
|
|
|
|
VCS_OPTS += -CC "-DVCS_VPI"
|
|
|
|
|
|
|
|
|
2014-09-01 05:26:55 +02:00
|
|
|
#--------------------------------------------------------------------
|
|
|
|
# Build the simulator
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
|
2015-07-28 09:23:31 +02:00
|
|
|
simv = $(sim_dir)/simv-$(MODEL)-$(CONFIG)
|
2016-08-16 07:03:03 +02:00
|
|
|
$(simv) : $(sim_vsrcs) $(sim_csrcs) $(consts_header)
|
2014-09-01 05:26:55 +02:00
|
|
|
cd $(sim_dir) && \
|
2015-11-06 01:42:05 +01:00
|
|
|
rm -rf csrc && \
|
2014-09-01 05:26:55 +02:00
|
|
|
$(VCS) $(VCS_OPTS) -o $(simv) \
|
2015-06-26 08:17:35 +02:00
|
|
|
-debug_pp \
|
2014-09-01 05:26:55 +02:00
|
|
|
|
2015-07-28 09:23:31 +02:00
|
|
|
simv_debug = $(sim_dir)/simv-$(MODEL)-$(CONFIG)-debug
|
2016-08-16 07:03:03 +02:00
|
|
|
$(simv_debug) : $(sim_vsrcs) $(sim_csrcs) $(consts_header)
|
2014-09-01 05:26:55 +02:00
|
|
|
cd $(sim_dir) && \
|
2015-11-06 01:42:05 +01:00
|
|
|
rm -rf csrc && \
|
2014-09-01 05:26:55 +02:00
|
|
|
$(VCS) $(VCS_OPTS) -o $(simv_debug) \
|
|
|
|
+define+DEBUG -debug_pp \
|
|
|
|
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
# Run
|
|
|
|
#--------------------------------------------------------------------
|
|
|
|
|
|
|
|
seed = $(shell date +%s)
|
|
|
|
exec_simv = $(simv) -q +ntb_random_seed_automatic
|
|
|
|
exec_simv_debug = $(simv_debug) -q +ntb_random_seed_automatic
|