当前位置: 首页 > news >正文

在WSL下使用makefile运行modelsim进行混合编译

modelsim的图像界面加载缓慢,实际上modelsim可以在纯命令行环境下仿真,使用-c参数:vsim -c。可以在WSL下用makefile运行Windows下的modelsim:

HDL_CODE      += .
HDL_CODE      += ../../rtl/
MODELSIM_ROOT := /mnt/e/exe/modeltech64_10.4/win64
TB := $(wildcard *tb*)
TB := $(basename $(TB))MODELSIM :=$(MODELSIM_ROOT)/modelsim.exe
MVLIB := $(MODELSIM_ROOT)/vlib.exe
MVCOM := $(MODELSIM_ROOT)/vcom.exe
MVLOG := $(MODELSIM_ROOT)/vlog.exe
MVSIM := $(MODELSIM_ROOT)/vsim.exe
VHDL_CODE:=$(addsuffix /*.vhd , $(HDL_CODE))
VHDL_CODE:=$(wildcard $(VHDL_CODE))
VERILOG_CODE:=$(addsuffix /*.v , $(HDL_CODE))
VERILOG_CODE:=$(wildcard $(VERILOG_CODE))simc:makework vhdl verilog$(MVSIM) -c -L work -voptargs=+acc $(TB) -do 'run -all' -do 'exit'simg:makework vhdl verilog$(MVSIM) -L work -voptargs=+acc $(TB) -do 'add wave $(TB)/*' -do 'run -all'vhdl:$(VHDL_CODE)$(MVCOM) -2008 -explicit $(VHDL_CODE)verilog:$(VERILOG_CODE)$(MVLOG) $(VERILOG_CODE)makework:$(MVLIB) workclr:rm -rf vsim* transcript work/.PONY: clr clean

使用make simc在纯命令行下仿真,如果需要同时导出波形文件,请在verilog TB中添加:

initial begin$dumpfile("wave.vcd");     // 波形文件名$dumpvars(0,tbv.u_module); // 抓取层级
end

使用make simg在图形界面仿真并显示波形,好处是可以看到实时波形。make simg和在图形界面运行.do文件进行编译无异。其中add wave $(TB)/*指定要看的层级。

vsim -civerilog的流程相似,都需要生成.vcd文件,再用gtkwave查看波形,比较繁琐,但对于小工程而言很方便。

http://www.lryc.cn/news/155880.html

相关文章:

  • idea 常用插件和常用快捷键 - 记录
  • IDEA报错:Plugin ‘org.springframework.boot:spring-boot-maven-plugin:‘ not found
  • C++——Vector:push_back和emplace_back的区别,测试写入1GB大数据时的性能差距
  • C/C++/QT/Python/MATLAB获取文件行数的示例
  • mysql的binlog參數詳解
  • 【SpringSecurity】九、Base64与JWT
  • Python的io模块
  • CSS---flex布局
  • java线程和go协程
  • JAVA 时间戳
  • 层次分析法(matlab实现)
  • python selenium 自动化登录页面
  • 【Linux】高级IO --- 多路转接,select,poll,epoll
  • anaconda navigator打不开,一直在loading画面
  • 【Java基础】深入理解反射、反射的应用(工厂模式、代理模式)
  • VUE 项目 nginx部署
  • Hashtable和HashMap、ConcurrentHashMap 之间的区别
  • 包管理工具--》npm的配置及使用(二)
  • 【Linux】多线程2——线程互斥与同步/多线程应用
  • Python中的函数式编程是什么?
  • 8月《中国数据库行业分析报告》已发布,聚焦数据仓库、首发【全球数据仓库产业图谱】
  • TikTok Shop|如何成为定邀卖家?
  • C++二级题目6
  • 南方科技大学博士研究生奖助学金,深圳大学
  • QT 使用信号与槽实现界面跳转
  • Burp插件HaE与Authz用法
  • element+vue table表格全部数据和已选数据联动
  • vue 防抖与节流用法
  • IntelliJ IDEA创建Web项目并使用Web服务器----Tomcat
  • rk3399 linux 5.10 usb 2.0设备上电概率性注册失败