We need this to work for our chip, and it's not been tested in a long time in upstream -- it didn't even used to build since the Nasti conversion. This makes a few changes: * Rather than calling the backup memory port parameters MEM_*, it calls them MIF_* (to match the MIT* paramater objects). A new name was necessary because the Nasti stuff is now dumped as MEM_*, which has similar names but incompatible values. * p(MIFDataBits) was changed back to 128, as otherwise the backup memory port doesn't work (it only send half a TileLink transaction). 64 also causes readmemh to bail out, but changing the elf2hex parameters works around that. * A configuration was added that enabled the backup memory port in the tester. While this is kind of an awkward way to do it, I want to make sure I can start testing this regularly and this makes it easy to integrate.
		
			
				
	
	
		
			77 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			77 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
#--------------------------------------------------------------------
 | 
						|
# Sources
 | 
						|
#--------------------------------------------------------------------
 | 
						|
 | 
						|
# Verilog sources
 | 
						|
 | 
						|
sim_vsrcs = \
 | 
						|
	$(generated_dir)/$(MODEL).$(CONFIG).v \
 | 
						|
	$(generated_dir)/consts.$(CONFIG).vh \
 | 
						|
	$(generated_dir)/memdessertMemDessert.$(CONFIG).v \
 | 
						|
	$(base_dir)/vsrc/$(TB).v \
 | 
						|
	$(base_dir)/vsrc/backup_mem.v \
 | 
						|
 | 
						|
# C sources
 | 
						|
 | 
						|
sim_csrcs = \
 | 
						|
	$(base_dir)/csrc/vcs_main.$(TB).cc \
 | 
						|
	$(base_dir)/csrc/mm.cc \
 | 
						|
	$(base_dir)/csrc/mm_dramsim2.cc \
 | 
						|
 | 
						|
#--------------------------------------------------------------------
 | 
						|
# Build Verilog
 | 
						|
#--------------------------------------------------------------------
 | 
						|
 | 
						|
verilog: $(sim_vsrcs)
 | 
						|
 | 
						|
.PHONY: verilog
 | 
						|
 | 
						|
#--------------------------------------------------------------------
 | 
						|
# Build rules
 | 
						|
#--------------------------------------------------------------------
 | 
						|
 | 
						|
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 "-I$(realpath $(base_dir))/dramsim2" \
 | 
						|
	-CC "-std=c++11" \
 | 
						|
	-CC "-Wl,-rpath,$(RISCV)/lib" \
 | 
						|
	-CC "-include $(consts_header)" \
 | 
						|
	-CC "-include $(scr_header)" \
 | 
						|
	-e vcs_main \
 | 
						|
	$(RISCV)/lib/libfesvr.so \
 | 
						|
	$(sim_dir)/libdramsim.a \
 | 
						|
	+incdir+$(generated_dir) \
 | 
						|
	+define+CLOCK_PERIOD=0.5 $(sim_vsrcs) $(sim_csrcs) \
 | 
						|
	+define+PRINTF_COND=$(TB).verbose \
 | 
						|
	+libext+.v \
 | 
						|
 | 
						|
#--------------------------------------------------------------------
 | 
						|
# Build the simulator
 | 
						|
#--------------------------------------------------------------------
 | 
						|
 | 
						|
simv = $(sim_dir)/simv-$(MODEL)-$(CONFIG)
 | 
						|
$(simv) : $(sim_vsrcs) $(sim_csrcs) $(sim_dir)/libdramsim.a $(consts_header)
 | 
						|
	cd $(sim_dir) && \
 | 
						|
	rm -rf csrc && \
 | 
						|
	$(VCS) $(VCS_OPTS) -o $(simv) \
 | 
						|
	-debug_pp \
 | 
						|
 | 
						|
simv_debug = $(sim_dir)/simv-$(MODEL)-$(CONFIG)-debug
 | 
						|
$(simv_debug) : $(sim_vsrcs) $(sim_csrcs) $(sim_dir)/libdramsim.a $(consts_header)
 | 
						|
	cd $(sim_dir) && \
 | 
						|
	rm -rf csrc && \
 | 
						|
	$(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
 |