$monitor和$strobe都看的是啥

news2024/11/16 13:49:42


注:本文来自硅芯思见


在编写测试平时,经常会用到$monitor和$strobe监测某些信号,并且使用格式上与$display比较类似,但是它们之间还是存在差异的,它们在当前仿真时间槽(time-slot)中被执行的区间是不同的。$display发生在Active区,而$monitor和$strobe发生在当前仿真的最后时刻,即post-pone区,并且一个time-slot是存在很多区域的,因此,它们在观测具体信号值时是存在一定差异的。

【示例】 

图片

【仿真结果】 

图片

出现示例中的结果,是因为非阻塞赋值的LHS更新发生在Non-Active区,而此时的$display已经执行完毕,所以$display观测不到sig更新后的值,但是$monitor发生在Post-pone区,晚于Non-Active区执行,所以可以观测到sig更新后的值。因此,$display和$monitor观测到sig的值不同。在实际使用过程中,具体使用哪一种监测方式则根据两种监测执行的区间特点自行选择,$strobe与$monitor在本例中监测到的结果是一样都发生在Post-pone区,执行类似,在此不赘述。那么既然$strobe和$monitor执行效果一样,都发生在Post-pone区,那么为什么还要同时存在呢?两者之间有些什么差异呢?下面我们就两者之间的一些差异进行示例说明。

1 $strobe的执行

$strobe只有在被调用时才会对其中的参数进行监测,此时的参数所具有的值可以认为是其所在当前时间槽(time-slot)中的最终值。另外,$strobe在设计中可以多次被调用,且多次调用相互之间不产生任何影响。

【示例】 

图片

【仿真结果】 

图片

示例中,在always过程块中,当敏感时间列表中的信号发生一次变化,always过程块中的$strobe就会执行一次,并且输出此次执行时对应参数的稳定值。在initial过程块中,等待4个时间单位后$strobe执行,并且输出此时对应参数的稳定值,而在sig变化的其他时刻,该语句并未执行(因为initial块只执行了一次,并且完成了他的历史使命)。可见$strobe的执行取决于对其的调用,它的执行并不取决于其中参数的变化,同时可见该语句在代码中可以被多次调用,并且多次调用之间不会产生相互影响。

2 $monitor的执行

$monitor和$strobe虽然它们监测的参数都是当前时间槽该参数最后的稳定值,但两者在具体执行上还是有一定差别的,下面通过示例说明$monitor的用法。

【示例】 

图片

【仿真结果】 

图片

示例中,$monitor位于过程块中,sig从0时刻开始,每发生一次变化,$monitor就会执行一次,可见$monitor会持续监测其中参数的变化,只要其中参数发生变化,$monitor就会执行。那么是不是其中的任何参数的变化都会触发$monitor的执行,例如,可不可以使用$monitor监测时间的变化呢?

【示例】 

图片

【仿真结果】 

图片

示例中,随着仿真时间的推进,$monitor仅执行了一次。这主要是因为在$monitor中,如果监测的参数是$time、$stime和$realtime这些系统函数的返回值,$monitor对这些时间参数的变化并不敏感。

另外,当$monitor中具有多个参数同时发生变化时,这是因为这些参数在当前时间槽中调用$monitor时都已经处于稳定状态了,所以此时$monitor只调用一次,如下所示。

【示例】 

图片

【仿真结果】 

图片

那么,我们可不可以使用多个$monitor监测信号的变化呢?此时$monitor会如何执行呢?我们看看下面的示例。

【示例】 

图片

【仿真结果】 

图片

示例中,使用了两个$monitor分别检测sig1和sig2信号的变化,但是仿真结果仅有一个$monitor执行。这主要是因为$monitor执行上的一个特点,在任意仿真时刻,只有一个$monitor系统任务处于激活执行状态,至于多个$monitor执行的顺序,一般则取决于哪一个$monitor最近一次被调用。除此之外,$nonitor还提供了其他的配置系统任务,可以通过这些系统任务实现对于$monitor执行的控制。

【示例】 

图片

【仿真结果】 

图片

示例中,$monitoroff和$monitoron之间sig的变化并没有触发$monitor系统任务的执行。这主要是因为$monitoroff会不使能当前所有激活的$monitor任务对于其中参数的监测,所以在$monitoroff之后,$monitor监测的参数如果发生变化,将不会触发$monitor的执行。$monitoron的效果与$monitoroff刚好相反,主要用于再次启动激活$monitor任务,在$monitoron执行后,如果$monitor监测的参数发生变化,则会触发$monitor的执行。

综上所述,$strobe和$monitor执行的主要特定如下:

Ø$strobe和$monitor监测的相关变量的值,都是这些变量在当前时间槽中的最终稳定值;

Ø$strobe只有在被调用时才会对其中的参数进行监测,而$monitor只要监测的参数发生变化,$monitor就会执行;

Ø代码中可以存在多个$strobe,并且多个$strobe的调用相互之间不影响;

Ø在$strobe和$monitorr中,如果监测的参数是$time、$stime和$realtime这些系统函数的返回值,$strobe和$monitor对这些时间参数的变化并不敏感

Ø在任意仿真时刻,只有一个$monitor系统任务处于激活执行状态,至于多个$monitor执行的顺序,一般则取决于哪一个$monitor最近一次被调用;

Ø可以通过$monitoroff和$monitoron对$monitor的执行进行监测;

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

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

相关文章

网络安全03---Nginx 解析漏洞复现

目录 一、准备环境 二、实验开始 2.1上传压缩包并解压 2.2进入目录,开始制作镜像 2.3可能会受之前环境影响,删除即可 ​编辑 2.4制作成功结果 2.5我们的环境一个nginx一个php 2.6访问漏洞 2.7漏洞触发结果 2.8上传代码不存在漏洞 2.9补充&#…

中断控制器

1. 中断的理解 1.1 什么是中断 中断: 通常指 某种事件(中断源) 触发了 需要打断CPU , 让CPU暂停当前处理的(保存现场) 任务(usr模式下) 打断(irq异常) 转而去处理 这个事件(在irq模式中) ,事件处理结束后 需要回到(恢复现场) 打断处继续向后执行 1.2 中断控制器的作…

程序员如何应对中年危机

中年危机是一个普遍存在的问题,不仅仅局限于程序员这个职业。不过,对于程序员来说,由于技术更新迅速,中年危机可能更加明显。以下是一些应对中年危机的建议: 持续学习新技术和工具:计算机技术发展迅速&…

特殊类的设计(含单例模式)

文章目录 一、设计一个不能被拷贝的类二、设计一个只能在堆上创建的类三、设计一个只能在栈上创建的类四、设计一个不能被继承的类五、单例模式1.懒汉模式2.饿汉模式 一、设计一个不能被拷贝的类 拷贝只会放生在两个场景中:拷贝构造函数以及赋值运算符重载&#xf…

MySQL介绍、安装和卸载

MySQL介绍、安装和卸载 1. 数据库基本概念2. 数据库类型和常见的关系型数据库2.1 数据库类型2.2 常见的关系型数据库 3. MySQL介绍4. MySQL8的安装和卸载 1. 数据库基本概念 1. 数据 所谓数据(Data)是指对客观事物进行描述并可以鉴别的符号,…

(四)流程控制ifelse

文章目录 if else用法示例1演示1示例2演示2示例3演示3示例4演示4 逻辑与或非示例1演示1示例2演示2示例3演示3 if elseif else示例1演示1示例2演示2 if else 用法 if(条件表达式成立或为真){ //执行里面 }else{ //否则执行这里面 } 这里:条件表达式成立或为真,数值…

《WebKit 技术内幕》学习之十五(6):Web前端的未来

6 Chromium OS和Chrome的Web应用 6.1 基本原理 HTML5技术已经不仅仅用来编写网页了,也可以用来实现Web应用。传统的操作系统支持本地应用,那么是否可以有专门的操作系统来支持Web应用呢?当然,现在已经有众多基于Web的操作系统&…

环形链表的检测与返回

环形链表 王赫辰/c语言 - Gitee.com 快慢指针的差距可以为除一以外的数吗?不可以如果差奇数则无法发现偶数环,是偶数无法发现奇数环,本题思路为指针相遇则为环,而以上两种情况会稳定差一,导致指针永不相遇 最终返回…

<蓝桥杯软件赛>零基础备赛20周--第19周--最短路

报名明年4月蓝桥杯软件赛的同学们,如果你是大一零基础,目前懵懂中,不知该怎么办,可以看看本博客系列:备赛20周合集 20周的完整安排请点击:20周计划 每周发1个博客,共20周。 在QQ群上交流答疑&am…

单片机学习笔记---独立按键控制LED亮灭

直接进入正题! 今天开始我们要学习一个新的模块:独立按键! 先说独立按键的内部结构: 它相当于一种电子开关,按下时开关接通,松开时开关断开,实现原理是通过轻触按键内部的金属弹片受力弹动来实…

深度学习知识

context阶段和generation阶段的不同 context阶段(又称 Encoder)主要对输入编码,产生 CacheKV(CacheKV 实际上记录的是 Transformer 中 Attention 模块中 Key 和 Value 的值),在计算完 logits 之后会接一个Sampling 采…

CC++内存管理【非常详细,对新手友好】

文章目录 一、程序内存划分1.基础知识2. 堆栈的区别3. 题目练手 二、C语言中动态内存管理方式三、C中动态内存管理方式1. new/delete操作内置类型2. new/delete操作自定义类型 四、operator new和operator delete函数1. 汇编查看编译器底层调用2. 透过源码分析两个全局函数 五、…

GD32移植FreeRTOS+CLI过程记录

背景 之前我只在STM32F0上基于HAL库和CubeMX移植FreeRTOS,但最近发现国产化替代热潮正盛,许多项目都有国产化器件指标,而且国产单片机确实比意法的便宜,所以也买了块兆易创新的GD32F303开发板,试一试它的优劣。虽然GD…

【开源】基于JAVA的班级考勤管理系统

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 系统基础支持模块2.2 班级学生教师支持模块2.3 考勤签到管理2.4 学生请假管理 三、系统设计3.1 功能设计3.1.1 系统基础支持模块3.1.2 班级学生教师档案模块3.1.3 考勤签到管理模块3.1.4 学生请假管理模块 3.2 数据库设…

【系统备份/迁移】解决克隆win10系统分区后,进系统黑屏、有鼠标指针(无需修改注册表)

【解法】简单来说就是,在PE系统中修复引导,修复成功后再进入系统就正常了。 1、问题 笔者通过DiskGenius克隆系统分区来备份自己的win10系统。克隆完成后,进入新系统里,发现是黑屏,移动鼠标时可以看到鼠标指针&#x…

通过铭文赛道的深度链接,XDIN3 与 opBNB 的双向奔赴

​进入到 2024 年以来,随着铭文市场基建设施的不断完善,铭文正在被赋予捕获价值与流动性的能力,并且铭文投资者们也正在趋于理性,这也意味着铭文赛道正在向价值回归的全新方向发展。 XDIN3 是推动铭文资产捕获价值的重要基建设施&…

第7章 面向对象基础(下)

第7章 面向对象基础(下) 学习目标 会区分静态的类变量和非静态的实例变量 会区分静态的类方法和非静态的实例方法 了解类初始化 认识枚举类型 会使用枚举类型 认识包装类 会使用包装类进行处理字符串 会分析包装类的相关面试题 能够声明抽象类 能够说出…

ZigBee学习——浅析协议栈

✨记录学习过程 文章目录 一、初识OSAL1.1 Z-Stack和Zigbee的OSAL是什么关系?1.2 OSAL可以解决Z-stack在不同厂商的芯片上的使用吗? 二、协议栈运行机制2.1 初始化涉及内容2.2 初始化过程 一、初识OSAL OSAL,全称是操作系统抽象层&#xff0…

【驱动系列】C#获取电脑硬件显卡核心代号信息

欢迎来到《小5讲堂》,大家好,我是全栈小5。 这是《驱动系列》文章,每篇文章将以博主理解的角度展开讲解, 特别是针对知识点的概念进行叙说,大部分文章将会对这些概念进行实际例子验证,以此达到加深对知识点…

代码随想录算法训练营day4 | 链表(2)

一、LeetCode 24 两两交换链表中的节点 题目链接:24.两两交换链表中的节点https://leetcode.cn/problems/swap-nodes-in-pairs/ 思路:设置快慢指针,暂存节点逐对进行交换。 代码优化前: /*** Definition for singly-linked list…