* bump rocket-chip to enable large memory spaces * Tests pass with write mask bug fix * fix verisim build * Update to point to rocket-chip on master * bump rocket-chip and barstools This fixes the analog chisel bug and incorporates the firrtl MDF support (h/t John Wright)
84 lines
2.3 KiB
Makefile
84 lines
2.3 KiB
Makefile
base_dir=$(abspath ..)
|
|
sim_dir=$(abspath .)
|
|
|
|
PROJECT ?= example
|
|
MODEL ?= TestHarness
|
|
CONFIG ?= DefaultExampleConfig
|
|
CFG_PROJECT ?= $(PROJECT)
|
|
TB ?= TestDriver
|
|
TOP ?= ExampleTop
|
|
|
|
sim_name = vcs
|
|
|
|
simv = $(sim_dir)/simv-$(PROJECT)-$(CONFIG)
|
|
simv_debug = $(sim_dir)/simv-$(PROJECT)-$(CONFIG)-debug
|
|
|
|
default: $(simv)
|
|
|
|
debug: $(simv_debug)
|
|
|
|
include $(base_dir)/Makefrag
|
|
ifneq ($(filter run% %.run %.out %.vpd %.vcd,$(MAKECMDGOALS)),)
|
|
-include $(build_dir)/$(long_name).d
|
|
endif
|
|
|
|
|
|
rocketchip_vsrc_dir = $(ROCKETCHIP_DIR)/src/main/resources/vsrc
|
|
|
|
sim_vsrcs = \
|
|
$(VERILOG_FILE) \
|
|
$(HARNESS_FILE) \
|
|
$(HARNESS_SMEMS_FILE) \
|
|
$(SMEMS_FILE)
|
|
|
|
VCS = vcs -full64
|
|
|
|
VCS_OPTS = -notice -line +lint=all,noVCDE,noONGS,noUI -error=PCWM-L -timescale=1ns/10ps -quiet \
|
|
+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" \
|
|
-f $(sim_top_blackboxes) -f $(sim_harness_blackboxes) -f $(sim_dotf) \
|
|
$(RISCV)/lib/libfesvr.so \
|
|
-sverilog \
|
|
+incdir+$(generated_dir) \
|
|
+define+CLOCK_PERIOD=1.0 $(sim_vsrcs) \
|
|
+define+PRINTF_COND=$(TB).printf_cond \
|
|
+define+STOP_COND=!$(TB).reset \
|
|
+define+RANDOMIZE_MEM_INIT \
|
|
+define+RANDOMIZE_REG_INIT \
|
|
+define+RANDOMIZE_GARBAGE_ASSIGN \
|
|
+define+RANDOMIZE_INVALID_ASSIGN \
|
|
+libext+.v \
|
|
|
|
verilog: $(sim_vsrcs)
|
|
|
|
$(simv): $(sim_vsrcs) $(sim_dotf)
|
|
rm -rf csrc && $(VCS) $(VCS_OPTS) -o $@ \
|
|
-debug_pp
|
|
|
|
$(simv_debug) : $(sim_vsrcs) $(sim_dotf)
|
|
rm -rf csrc && $(VCS) $(VCS_OPTS) -o $@ \
|
|
+define+DEBUG -debug_pp
|
|
|
|
$(output_dir)/%.out: $(output_dir)/% $(simv)
|
|
$(simv) +permissive -q +ntb_random_seed_automatic +verbose +max-cycles=1000000 +permissive-off $< 3>&1 1>&2 2>&3 | spike-dasm > $@
|
|
|
|
$(output_dir)/%.run: $(output_dir)/% $(simv)
|
|
$(simv) +permissive -q +ntb_random_seed_automatic +max-cycles=1000000 +permissive-off $< && touch $@
|
|
|
|
$(output_dir)/%.vpd: $(output_dir)/% $(simv_debug)
|
|
$(simv_debug) +permissive -q +ntb_random_seed_automatic +vcdplusfile=$@ +max-cycles=1000000 +permissive-off $<
|
|
|
|
run-regression-tests: $(addprefix $(output_dir)/,$(addsuffix .out,$(regression-tests)))
|
|
|
|
run-regression-tests-fast: $(addprefix $(output_dir)/,$(addsuffix .run,$(regression-tests)))
|
|
|
|
run-regression-tests-debug: $(addprefix $(output_dir)/,$(addsuffix .vpd,$(regression-tests)))
|
|
|
|
clean:
|
|
rm -rf generated-src csrc simv-* ucli.key vc_hdrs.h
|
|
|
|
.PHONY: clean
|