aboutsummaryrefslogtreecommitdiffstats
path: root/fpga/usrp3/tools
diff options
context:
space:
mode:
authorWade Fife <wade.fife@ettus.com>2020-03-20 16:17:52 -0500
committerWade Fife <wade.fife@ettus.com>2020-03-23 18:01:53 -0500
commit974b9d6140fe6d35ef6698d437e12beaf071ba63 (patch)
tree75b861713d37d9286826d94d69d6b988e442c380 /fpga/usrp3/tools
parent0ac85e4d0186cb63cb98da90363f34947675b3e5 (diff)
downloaduhd-974b9d6140fe6d35ef6698d437e12beaf071ba63.tar.gz
uhd-974b9d6140fe6d35ef6698d437e12beaf071ba63.tar.bz2
uhd-974b9d6140fe6d35ef6698d437e12beaf071ba63.zip
fixup! fpga: tools: Add modelsim to make sim targets
Diffstat (limited to 'fpga/usrp3/tools')
-rw-r--r--fpga/usrp3/tools/make/viv_simulator.mak52
1 files changed, 25 insertions, 27 deletions
diff --git a/fpga/usrp3/tools/make/viv_simulator.mak b/fpga/usrp3/tools/make/viv_simulator.mak
index 3ee4a727c..2d91d5209 100644
--- a/fpga/usrp3/tools/make/viv_simulator.mak
+++ b/fpga/usrp3/tools/make/viv_simulator.mak
@@ -52,7 +52,7 @@ NOQ_SV := $(NOQ_DESIGN_SV) $(NOQ_SIM_SV)
NOQ_PKG_SV := $(filter %.sv,$(NOQ_INC_SRCS))
# Seperate out Verilog
-NOQ_INC_DIRS := $(sort $(dir $(NOQ_INC_SRCS)))
+NOQ_INC_DIRS := $(sort $(dir $(NOQ_DESIGN_SRCS) $(NOQ_SIM_SRCS) $(NOQ_INC_SRCS)))
NOQ_DESIGN_VERILOG := $(filter %.v,$(NOQ_DESIGN_SRCS))
NOQ_SIM_VERILOG := $(filter %.v,$(NOQ_SIM_SRCS))
NOQ_VERILOG := $(NOQ_DESIGN_VERILOG) $(NOQ_SIM_VERILOG)
@@ -61,21 +61,19 @@ NOQ_VERILOG := $(NOQ_DESIGN_VERILOG) $(NOQ_SIM_VERILOG)
MODELSIM_LIBS += unisims_ver
# Arguments for various simulators
-MODELSIM_ARGS += -quiet
-SVLOG_ARGS += -quiet
-SVLOG_ARGS += +define+WORKING_DIR="\"${CURDIR}\""
-VLOG_ARGS += -quiet
-VLOG_ARGS += +define+WORKING_DIR="\"${CURDIR}\""
-VHDL_ARGS += -quiet
+MODELSIM_ARGS_L += $(MODELSIM_ARGS) -quiet
+SVLOG_ARGS_L += $(SVLOG_ARGS) -quiet +define+WORKING_DIR="\"${CURDIR}\""
+VLOG_ARGS_L += $(VLOG_ARGS) -quiet +define+WORKING_DIR="\"${CURDIR}\""
+VHDL_ARGS_L += $(VHDL_ARGS) -quiet
# Working directory for standalone ModelSim execution
MODELSIM_PROJ_DIR ?= modelsim_proj
# Check if we want to load the ModelSim GUI
ifeq ($(GUI), 1)
- MODELSIM_ARGS += -do "run -all"
+ MODELSIM_ARGS_L +=
else
- MODELSIM_ARGS += -c -do "run -all; quit -f"
+ MODELSIM_ARGS_L += -c -do "run -all; quit -f"
endif
SETUP_AND_LAUNCH_SIMULATION = \
@@ -117,7 +115,7 @@ vsim: .check_tool $(COMPLIBDIR) $(DESIGN_SRCS) $(SIM_SRCS) $(INC_SRCS)
##modelsim: Run the simulation using Modelsim (natively)
modelsim: .check_tool vlint
- cd $(MODELSIM_PROJ_DIR) && vsim $(MODELSIM_ARGS) $(foreach lib,$(MODELSIM_LIBS),-L $(lib)) $(SIM_TOP)
+ cd $(MODELSIM_PROJ_DIR) && vsim $(MODELSIM_ARGS_L) $(foreach lib,$(MODELSIM_LIBS),-L $(lib)) $(SIM_TOP)
# NOTE: VHDL files require a correct compile order. This script compiles files
@@ -125,36 +123,36 @@ modelsim: .check_tool vlint
##vlint: Run ModelSim compiler to lint files.
vlint: .check_tool $(COMPLIBDIR) $(DESIGN_SRCS) $(SIM_SRCS) $(INC_SRCS)
- $(shell mkdir -p ./modelsim_proj)
- $(file >modelsim_proj/svlogarglist.txt,/* Auto generated argument file for vlog -sv */)
- $(file >>modelsim_proj/svlogarglist.txt,-sv)
- $(foreach dir,$(NOQ_INC_DIRS), $(file >>modelsim_proj/svlogarglist.txt,+incdir+$(dir)))
- $(foreach src,$(NOQ_PKG_SV), $(file >>modelsim_proj/svlogarglist.txt,$(src)))
- $(foreach src,$(NOQ_SV), $(file >>modelsim_proj/svlogarglist.txt,$(src)))
- $(file >modelsim_proj/vlogarglist.txt,/* Auto generated argument file for vlog */)
- $(file >>modelsim_proj/vlogarglist.txt,-vlog01compat)
- $(foreach dir,$(NOQ_INC_DIRS), $(file >>modelsim_proj/vlogarglist.txt,+incdir+$(dir)))
- $(foreach src,$(NOQ_VERILOG), $(file >>modelsim_proj/vlogarglist.txt,$(src)))
- $(file >modelsim_proj/vcomarglist.txt,/* Auto generated argument file for vcom */)
- $(file >>modelsim_proj/vcomarglist.txt,-2008)
- $(foreach src,$(NOQ_VHDL),$(file >>modelsim_proj/vcomarglist.txt,$(src)))
+ $(shell mkdir -p ./$(MODELSIM_PROJ_DIR))
+ $(file >$(MODELSIM_PROJ_DIR)/svlogarglist.txt,/* Auto generated argument file for vlog -sv */)
+ $(file >>$(MODELSIM_PROJ_DIR)/svlogarglist.txt,-sv)
+ $(foreach dir,$(NOQ_INC_DIRS), $(file >>$(MODELSIM_PROJ_DIR)/svlogarglist.txt,+incdir+$(dir)))
+ $(foreach src,$(NOQ_PKG_SV), $(file >>$(MODELSIM_PROJ_DIR)/svlogarglist.txt,$(src)))
+ $(foreach src,$(NOQ_SV), $(file >>$(MODELSIM_PROJ_DIR)/svlogarglist.txt,$(src)))
+ $(file >$(MODELSIM_PROJ_DIR)/vlogarglist.txt,/* Auto generated argument file for vlog */)
+ $(file >>$(MODELSIM_PROJ_DIR)/vlogarglist.txt,-vlog01compat)
+ $(foreach dir,$(NOQ_INC_DIRS), $(file >>$(MODELSIM_PROJ_DIR)/vlogarglist.txt,+incdir+$(dir)))
+ $(foreach src,$(NOQ_VERILOG), $(file >>$(MODELSIM_PROJ_DIR)/vlogarglist.txt,$(src)))
+ $(file >$(MODELSIM_PROJ_DIR)/vcomarglist.txt,/* Auto generated argument file for vcom */)
+ $(file >>$(MODELSIM_PROJ_DIR)/vcomarglist.txt,-2008)
+ $(foreach src,$(NOQ_VHDL),$(file >>$(MODELSIM_PROJ_DIR)/vcomarglist.txt,$(src)))
ifneq ($(strip $(NOQ_SV)),)
@echo "*** COMPILING SYSTEM VERILOG ***"
- cd $(MODELSIM_PROJ_DIR) && vlog $(SVLOG_ARGS) -f svlogarglist.txt
+ cd $(MODELSIM_PROJ_DIR) && vlog $(SVLOG_ARGS_L) -f svlogarglist.txt
endif
ifneq ($(strip $(NOQ_VERILOG)),)
@echo "*** COMPILING VERILOG ***"
- cd $(MODELSIM_PROJ_DIR) && vlog $(VLOG_ARGS) -f vlogarglist.txt
+ cd $(MODELSIM_PROJ_DIR) && vlog $(VLOG_ARGS_L) -f vlogarglist.txt
endif
ifneq ($(strip $(NOQ_VHDL)),)
@echo "*** COMPILING VHDL ***"
- cd $(MODELSIM_PROJ_DIR) && vcom $(VHDL_ARGS) -f vcomarglist.txt
+ cd $(MODELSIM_PROJ_DIR) && vcom $(VHDL_ARGS_L) -f vcomarglist.txt
endif
##vclean: Cleanup ModelSim intermediate files
vclean:
@rm -f modelsim*.log
- @rm -rf modelsim_proj
+ @rm -rf $(MODELSIM_PROJ_DIR)
@rm -f vivado_pid*.str
# Use clean with :: to support allow "make clean" to work with multiple makefiles