首页 > 其他分享 >VCS 仿真脚本makefile样例

VCS 仿真脚本makefile样例

时间:2023-07-05 15:14:03浏览次数:66  
标签:rkv full64 vcs makefile 样例 VCS UVM test i2c

详细的参数介绍参考下面的博客

https://www.cnblogs.com/csjt/p/15581396.html

自己的makefile,注意 

SEED = `date +%N`  //随机种子的定义 取时间
SIM_COV = -cm line+cond+fsm+tgl+branch //代码覆盖率采样的定义

 

TESTLIST = ahb_mst_burst  ahb_mst_single_read32 ahb_mst_single_write32_apb_slv_nrdy \
ahb_mst_burst_apb_slv_slverr ahb_mst_tight_transfer // 定义 测试用例list,将写的测试用例名复制过来 并定义为变量 TESTLIST

 

vcs:
	vcs +v2k \
	-full64 \
	-sverilog -debug_acc+all  +ntb_random_seed=${SEED} \
	+define+FSDB -fsdb -lca -kdb  +DUMP_VPD ${UVM_HOME}/src/dpi/uvm_dpi.cc -CFLAGS -DVCS -timescale=1ns/1ns  -f filelist.f 
//VCS 编译命令 这里是编译 还不涉及到运行SIMV二进制文件

  

cov:
	dve -full64 -cov -dir ./SIMV/*.vdb&  //运行查看覆盖率

  

regress10:
	for((i=1; i<=${number};i++)); do \
		for item in $(TESTLIST); do \
		echo $$item; \
		./simv  +ntb_random_seed=${SEED} +ntb_solver_array_size_warn=100000 +DUMP_VPD +VPD_FILENAME=./VPD/$${item}_${SEED}.vpd +UVM_TESTNAME=$${item} -l ./LOG/$${item}_${SEED}.log  -cm_dir ./SIMV/$${item}_${SEED}; \
		done; \
	done
//使用了两层for循环执行仿真,需要注意的是 执行仿真的时候 需要添加随机种子 将VPD波形文件 VDB覆盖率文件 还有log日志文件 保存到对应的目录下

  

merge:
	urg -full64 -dir ./SIMV/*.vdb -dbname merged -parallel -report ./SIMV/urgReport
//将覆盖率文件merge 生成report

  

clean:
	rm -r csrc merged.vdb urgReport  ./LOG/* ./SIMV/* ./VPD/* *.log *.key *.h 

generatedir:
	mkdir ./LOG
	mkdir ./SIMV
	mkdir ./VPD

  

总体的makefile 如下:

TOP       = ../tb/rkv_i2c_tb.sv
TEST     ?= rkv_i2c_quick_reg_access_test
VERDI    ?= 0
GUI      ?= 0
COV      ?= 0
SEED      = `date "+%m%d%H%M%S"`
OUT      ?= out
VERB     ?= UVM_HIGH#{UVM_NONE, UVM_LOW, UVM_MEDIUM, UVM_HIGH}
INCDIR   = +incdir+../../rkv_dw_apb_i2c/src \
					 +incdir+../env \
					 +incdir+../agents/{lvc_apb3,lvc_i2c} \
					 +incdir+../{cfg,cov,reg,env,seq_lib} \
					 +incdir+../seq_lib/{.,elem_seqs,user_elem_seqs,user_virt_seqs} \
					 +incdir+../tests/{.,user_tests}
TESTLIST = rkv_i2c_quick_reg_access_test rkv_i2c_master_directed_write_packet_test rkv_i2c_master_directed_interrupt_test \
				rkv_i2c_master_directed_read_packet_test
#rkv_i2c_directed_tx_test rkv_i2c_directed_rx_test
CM = -cm line+cond+fsm+branch+tgl
VCOMP    = vlogan $(INCDIR) -full64 -sverilog -ntb_opts uvm-1.2 -timescale=1ps/1ps -l $(OUT)/log/comp_$(TB_TOP).log  
ELAB     = vcs -full64 -sverilog -ntb_opts uvm-1.2 -debug_all -l $(OUT)/log/elab_$(TB_TOP).log 
RUN      = ./simv +ntb_random_seed=$(SEED) +UVM_NO_RELNOTES +UVM_VERBOSITY=$(VERB) 
COVOPTS  = -full64 -userdata ../docs/testcase.data -plan ../docs/uart_vplan.hvp -elfile ../docs/elfile.el -dir $(OUT)/cov.vdb 
CM_NAME  = $(TEST)_seed_$(SEED)
number = 10
vcs_run= \
	vcs +v2k \
	-full64 \
	-sverilog -debug_acc+all  \
	+define+FSDB -fsdb -lca -kdb  ${UVM_HOME}/src/dpi/uvm_dpi.cc -CFLAGS -DVCS -timescale=1ns/1ns  -f  filelist.f \
	${CM} +DUMP_VPD -R
ifeq ($(VERDI),1)
	VCOMP  += -kdb
	RUN += -verdi
endif
ifeq ($(GUI),1)
	RUN += -gui
endif

ifeq ($(COV),1)
	ELAB  += -cm line+cond+fsm+tgl+branch+assert -cm_dir $(OUT)/cov.vdb
	RUN += -cm line+cond+fsm+tgl+branch+assert -covg_cont_on_error
endif

all: clean dcomp comp elab 
#sim_all cov
run_all: clean prepare regsim
vcs:
	vcs +v2k \
	-full64 \
	-sverilog -debug_acc+all  \
	+define+FSDB -fsdb -lca -kdb  ${UVM_HOME}/src/dpi/uvm_dpi.cc -CFLAGS -DVCS -timescale=1ns/1ns  -f  filelist.f \
	${CM} +DUMP_VPD
simgui:
	./simv +UVM_TESTNAME=$(TEST) -gui &

regsim:
	for((i=1; i<=${number};i++)); do \
		for item in $(TESTLIST); do \
		echo $$item; \
		$(vcs_run) +VPD_FILENAME=$(OUT)/sim/$${item}_seed_$(SEED).vpd +UVM_TESTNAME=$${item} -l $(OUT)/sim/$${item}_seed_$(SEED).log -o $(OUT)/sim/$${item}_seed_$(SEED)simv; \
		done; \
	done
prepare:
	mkdir -p $(OUT)/work
	mkdir -p $(OUT)/log
	mkdir -p $(OUT)/sim
	mkdir -p $(OUT)/obj
	mkdir -p .shadow
	mkdir -p ${OUT}/cov
	mkdir -p ../docs/nd_docs

dcomp: prepare
	$(VCOMP)  -f rkv_i2c.flist 


comp: .shadow/compile_uvm .shadow/compile_lvc_apb .shadow/compile_lvc_i2c
	$(VCOMP)  ../env/rkv_i2c_pkg.sv 
	$(VCOMP)  ../tb/rkv_i2c_if.sv 
	$(VCOMP)  ../tb/rkv_i2c_tb.sv 

.shadow/compile_uvm:
	${VCOMP} -ntb_opts uvm-1.2
	@touch $@;

.shadow/compile_lvc_apb:
	$(VCOMP) ../agents/lvc_apb3/lvc_apb_if.sv 
	$(VCOMP) ../agents/lvc_apb3/lvc_apb_pkg.sv 
	#@touch $@;

.shadow/compile_lvc_i2c:
	$(VCOMP)  ../agents/lvc_i2c/lvc_i2c_if.sv 
	$(VCOMP)  ../agents/lvc_i2c/lvc_i2c_pkg.sv 
	#@touch $@;

elab: comp
	$(ELAB)  $(TOP)

run: 
	$(RUN) +UVM_TESTNAME=$(TEST) -l $(OUT)/sim/$(CM_NAME).log -cm_dir $(OUT)/cov -cm_name $(CM_NAME)

regr: #$(TESTLIST)
	for t in $(TESTLIST); do \
		$(RUN) +UVM_TESTNAME=$(TESTLIST) -l $(OUT)/sim/$(TESTLIST).log +vpdfile+$(OUT)/sim/$(TESTLIST)_$(SEED)_$(VPDFILE); \
	done

editcov:
	urg -format both $(COVOPTS)
	dve $(COVOPTS)

viewcov:
	urg -format both $(COVOPTS)
	firefox urgReport/dashboard.html

gendoc:
	mono /opt/NaturalDocs/NaturalDocs.exe ../docs/nd_config
  
viewdoc:
	firefox ../docs/nd_docs/index.html &

clean:
	-rm -rf csrc DVEfiles ucli.key uvm_dpi.so vc_hdrs.h  *simv* *.vpd *.log *.sml *.fsdb work.* *.vdb
	-rm -rf AN.DB urgReport novas.conf verdiLog vdCovLog novas.rc $(OUT) .shadow
	-rm -rf transcript vsim_stacktrace.vstf vsim.wlf work
	-rm -rf ../docs/nd_docs/*

  

标签:rkv,full64,vcs,makefile,样例,VCS,UVM,test,i2c
From: https://www.cnblogs.com/1050619969kong/p/17528479.html

相关文章

  • 第009课 gcc和arm-linux-gcc和Makefile
    第001节_gcc编译器1_gcc常用选项__gcc编译过程详解gcc的使用方法gcc[选项]文件名gcc常用选项选项功能-v查看gcc编译器的版本,显示gcc执行时的详细过程-o指定输出文件名为file,这个名称不能跟源文件名同名-E只预处理,不会编译、汇编、链接t-S只编译,不会汇编、链接-c编译和汇编,不会链......
  • 一个简单的makefile文件尝试
      SHARED_CFLAGS=-fPIC-sharedSHARED_SRC=calac_level.cppcalac_level.hBIN_SRC=main.cppSHARED_PATH=-L./-lcalac_levelBIN_CFLAGS=-Wl,-rpath,./-gCC_VERSION=-std=c++11ECHO_RED_COLOR=\033[31mECHO_END=\033[0mLIB_TARGET=libcalac_level.soBIN_TARG......
  • VCSA内置PG数据库信息
    vcsa就是一个suselinux,会内置一个PostgreSQL数据库,那么如何修改数据库用户密码呢?首先通过22端口远程连入suselinuxToescapetolocalshell,pressCtrl+Alt+].VMwarevCenterServer7.0.3.01500Type:vCenterServerwithanembeddedPlatformServicesControllerWARNING!......
  • VCSA内置数据库密码
    vcsa就是一个suselinux,会内置一个PostgreSQL数据库,那么如何修改数据库用户密码呢?首先通过22端口远程连入suselinuxToescapetolocalshell,pressCtrl+Alt+].VMwarevCenterServer7.0.3.01500Type:vCenterServerwithanembeddedPlatformServicesControllerWARNING!T......
  • 用CMake 替换 Makefile
    原文:https://blog.csdn.net/love131452098/article/details/116241448CMake实质上是用于生成Makefile的工具,现在越来越多开源的项目,在项目的编译框架上使用CMake替换Makefile.CMake相对于Makefile规则更加简单,重要的是CMake官方网站提供了较为友好的指南.CMake官方学习资......
  • redis-分布式锁样例
    redisTemplate:stringlockKey="product_101"stringclientID=UUID.randomUUID().toString()boolresult=redisTemplate.opsForValue().setIfAbsent(lockKey,clientID,10,TimeUnit.SECONDS)if(!result){return"error_code"}try{//业务逻辑......
  • 不能使用astyle对Linux的Kconfig和Makefile进行排版,会导致编译错误
    代码排版工具不同人代码的排版习惯不一样。遇到自己不喜欢的格式,看起来比较麻烦。可以使用astyle对代码进行排版。我喜欢以"otbs"格式的排版。命令如下:astyle-s--style=otbs*.castyle-s--style=otbs*.h错误排版一次使用时,不小心对所有文件进行了排版。hankf@XSZGS4......
  • makefile只编译修改过的文件
    本文演示配置makefile,检测修改的代码才编译,提升编译效率。1.测试代码$tree.├──app.c├──lib│├──module2.c│└──module2.h├──makefile├──module1.c└──module1.happ.c#include<stdio.h>#include"app.h"#include"......
  • 信捷触摸屏与两台变频器的通讯样例支持TH.TG.TE系列,一台使用三菱E700变频器,一台使用台
    信捷触摸屏与两台变频器的通讯样例支持TH.TG.TE系列,一台使用三菱E700变频器,一台使用台达vfd-M变频器,可实现正反转,停止控制及指示,频率设定及加减频率,加减速时间设定,以及对输出频率,电流,电压的监控。电脑可以通过在线模拟加usb转485转换头也可以实现。整套的资料。包括程序,变频参数设......
  • Makefile编写模板 & 学习笔记
    一、模板#伪命令.PHONY:cleancompileSocompileExerun:compileExe@./maincompileExe:compileSo@g++main.cpp-Llib-lsoowCapture-lcamapi-lpthread=lImageProc-ljpeg-lhv_static-omaincompileSo:@g++fPIC-sharedsoowCapture.cpp-Iinclu......