vcs仿真产生fsdb波形的两种方式

目录

方法一: 使用verilog自带的系统函数

方法二: 使用UCLI command 

2.1 需要了解什么是vcs的ucli,怎么使用ucli? 

2.2 使用ucli dump波形的方法


使用vcs仿真产生fsdb波形有两种方式,本文参考《vcs user guide 2021》 page 1960  Dumping FSDB File for Various Flows

方法一: 使用verilog自带的系统函数

使用$fsdbDumpfile指定生成的fsdb的名称 

使用$fsdbDumpvars指定dump的hierarchy和层级,0表示该层次及其以下所有的都dump,1表示只dump该层级,2表示dump该层级及其下面一层。

如果不指定fsdb的名字,默认生成的名字为novas.fsdb 

方法二: 使用UCLI command(推荐使用)

2.1 需要了解什么是vcs的ucli,怎么使用ucli? 

这里参考《vcs user guide 2021》 page 355  Using UCLI 

使用-ucli命令可以实现如下的事情: 

  • Control simulation
  • Dump the FSDB and VPD files
  • Save/Restore the simulation state
  • Force/Release a signal
  • Debug the design using breakpoints, scope/thread information, and built-in macros

使用-ucli的前提是,在vcs编译时,添加-debug_access+r 的选项,当vcs添加编译选项-ucli时,将会进入和vcs的交互界面,

% simv -ucli 
ucli% 

接下来执行ucli命令有三种方式

  • 一行一行输入tcl命令,所有的ucli的cmd都是符合tcl语法的
  • 多行tcl命令可以写在一个文件中执行,source  xxx_cmd.file 
  • 直接在simv命令行加入选项simv -ucli -do xxx_cmd.file 

2.2 使用ucli dump波形的方法

有两种命令方式,这里推荐右边这种方式 

fsdbDumpfile指定波形名字,fsdbDumpvars指定dump层次和层级

我们提前准备一个dump fsdb的tcl文件,如果simple_wave.tcl 

fsdbAutoSwitchDumpfile 20000 debussy.fsdb 10
fsdbDumpvars 2 Mtop
fsdbDumpvars 2 Mtop.u_aaa_top
fsdbDumpvars 0 Mtop.u_aaa_top.u_bbb
fsdbDumpvars 1 Mtop.u_aaa_top.u_bbb.u_ccc.u_ddd

在simv仿真时,使用命令行

simv -ucli -do simple_wave.tcl

既可dump fsdb波形,此外tcl中可以控制dump波形的时间等等,例子之后添加

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/pingmian/83850.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【前端】每日一道面试题6:解释Promise.any和Promise.allSettled的使用场景及区别。

Promise.any() 和 Promise.allSettled() 是 JavaScript 中用于处理异步操作的两种不同策略的 Promise 组合器,它们的核心区别在于逻辑目标与结果处理方式: 1. Promise.any() 使用场景: 需要获取 首个成功结果(类似竞速成功优先&…

数据链路层__

文章目录 数据链路层基本概念(1)链路管理:面向连接的服务(2)帧同步:成帧1、字符计数法2、字符填充法(带填充的首尾界符法)3、带填充的首位标志法4、物理层编码违例法 (3&…

coze智能体后端接入问题:

是否一定要按照coze官方API文档格式调用? 不一定:以下面代码为例(给了注释) app.route(/compare_models, methods[POST]) def compare_models():print("收到 compare_models 请求!") #begin-这一部分代码作用:从前端接…

如何轻松、安全地管理密码(新手指南)

很多人会为所有账户使用相同、易记的密码,而且常常多年不换。虽然这样方便记忆,但安全性非常低。 您可能听说过一些大型网站的信息泄露事件,同样的风险也可能存在于您的WordPress网站中。如果有不法分子获取了访问权限,您的网站和…

宝塔think PHP8 安装使用FFmpeg 视频上传

宝塔think PHP8 安装使用FFmpeg 一、 安装think PHP8二、安装 FFmpeg1,登录到宝塔面板。2,进入“软件商店”。3,搜索“FFmpeg”。4,选择版本点击安装。5,检查 FFmpeg 是否安装成功6, 在 ThinkPHP 8 中使用 …

Android 轻松实现 增强版灵活的 滑动式表格视图

表格视图组件,支持: 1. 无标题模式:只有数据行也可以正常滑动 2. 两种滑动模式:固定第一列 或 全部滑动 3. 全面的样式自定义能力 4. 智能列宽计算 1. 无标题模式支持 设置无标题:调用 setHeaderData(null) 或 …

【Python进阶】元类编程

目录 🌟 前言🏗️ 技术背景与价值🩹 当前技术痛点🛠️ 解决方案概述👥 目标读者说明 🧠 一、技术原理剖析📊 核心概念图解💡 核心作用讲解🔧 关键技术模块说明⚖️ 技术选…

DeepSeek模型性能优化:从推理加速到资源调度的全栈实践

引言 在生产环境中部署DeepSeek模型时,性能优化直接关系到服务质量和运营成本。本文将深入探讨从芯片级优化到分布式调度的全栈性能提升方案,涵盖计算图优化、内存管理、批处理策略等关键技术,并分享在千万级QPS场景下的实战经验,帮助工程团队突破性能瓶颈,实现成本与效能…

Ctrl+R 运行xxx.exe,发现有如下问题.

CtrlR 运行xxx.exe,发现有如下问题. (1)找不到Qt5Core.all,Qt5Cored.dll,Qt5Gui.dll,Qt5Guid.dll,Qt5Widgets.all,Qt5Widgetsd.dll? (2)之后找不到libwinpthread-1.dll 从这个目录拷贝相应的库到运行xx.exe目录下 方法二:将库路径添加到系统PATH环境变量里: 在Path中添加路…

硅基计划2.0 学习总结 陆 抽象类与接口

文章目录 一、抽象类1. 定义2. 示例代码3. 特性 二、接口初识1. 定义2. 命名与语法3. 示例代码4. 常见特性5. 多接口实现6. 接口的继承 三、Object类初识1. equals方法2. hascode方法 一、抽象类 1. 定义 请你假设这样一个场景,我们定义一个人的类,这个…

Linux命令基础(2)

su和exit命令 可以通过su命令切换到root账户 语法:su [-] 用户名 -符号是可选的,表示是否在切换用户后加载环境变量,建议带上 参数:用户名,表示要切换的用户,用户名可以省略,省略表示切换到ro…

C++算法训练营 Day10 栈与队列(1)

1.用栈实现队列 LeetCode:232.用栈实现队列 请你仅使用两个栈实现先入先出队列。队列应当支持一般队列支持的所有操作(push、pop、peek、empty): 实现 MyQueue 类: void push(int x)将元素x推到队列的末尾 int pop(…

设计模式域——软件设计模式全集

摘要 软件设计模式是软件工程领域中经过验证的、可复用的解决方案,旨在解决常见的软件设计问题。它们是软件开发经验的总结,能够帮助开发人员在设计阶段快速找到合适的解决方案,提高代码的可维护性、可扩展性和可复用性。设计模式主要分为三…

【QT】自定义QWidget标题栏,可拖拽(拖拽时窗体变为normal大小),可最小/大化、关闭(图文详情)

目录 0.背景 1.详细实现 思路简介 .h文件 .cpp文件 0.背景 Qt Linux;项目遇到问题,解决后特此记录 项目需要,个性化的标题栏(是个widget),在传统的三个按钮(最大化、最小化、关闭&#xf…

如何用 pnpm patch 给 element-plus 打补丁修复线上 bug(以 2.4.4 修复 PR#15197 为例)

背景 在实际项目开发中,依赖的三方库(如 element-plus)难免会遇到 bug。有时候官方虽然已经修复,但新版本升级成本高,或者有兼容性风险。这时,给依赖打补丁是最优雅的解决方案之一。 本文以 element-plus…

Spring AI 入门:Java 开发者的生成式 AI 实践之路

一、Spring AI 简介 在人工智能技术快速迭代的今天,Spring AI 作为 Spring 生态系统的新生力量,正在成为 Java 开发者拥抱生成式 AI 的最佳选择。该框架通过模块化设计实现了与主流 AI 服务(如 OpenAI、Anthropic)的无缝对接&…

优化电脑的磁盘和驱动器提高电脑性能和延长硬盘寿命?

磁盘优化 磁盘清理: 使用系统自带的磁盘清理工具(如Windows的“磁盘清理”)删除不必要的文件。清空回收站。删除临时文件和缓存。 磁盘碎片整理(针对机械硬盘): 定期进行磁盘碎片整理,以提高文…

EDA断供危机下的冷思考:中国芯片设计软件的破局之道优雅草卓伊凡

EDA断供危机下的冷思考:中国芯片设计软件的破局之道优雅草卓伊凡 一、EDA是什么?芯片行业的”隐形基石” 1.1 EDA技术解析 EDA(Electronic Design Automation,电子设计自动化)是用于设计和验证集成电路的软件工具链…

Jpackage

简介 jpackage - 用于打包自包含 Java 应用程序的工具,是 JDK 14 引入的一个工具。 该工具将 Java 应用程序和 Java 运行时映像作为输入,并生成包含所有必要依赖项的 Java 应用程序映像。它将能够生成特定于平台的格式的本机包,例如包括打包 …

CRM管理软件的数据可视化功能使用技巧:让数据驱动决策

在当今数据驱动的商业环境中,CRM管理系统的数据可视化功能已成为企业优化客户管理、提升销售效率的核心工具。据企销客研究显示,具备优秀可视化能力的CRM系统,用户决策效率可提升47%。本文将深入解析如何通过数据可视化功能最大化CRM管理软件…