事件触发控制_SystemVerilog线程控制与通信

01

线程控制

1.概述

线程,即独立运行的程序;

线程需要被触发执行,可以结束或者不结束;

  • 在module中的initial和always,都可以看作独立的线程,他们在仿真0时刻开始,而选择结束或者不结束;

  • 在硬件模块中都是always语句块,所以可以看成是独立运行的线程,而且会一直占用仿真资源,因为他们不会结束;

验证环境需要initial语句块,在仿真过程中,验证环境中的对象可以创建和销毁,故验证环境的资源是动态的;

  • 验证环境中的initial语句块有两种方式:begin……end或者fork……join;

Begin……end中语句顺序执行,而fork……join中语句并发执行;

与fork……join类似的并行语句有fork……join_any、fork……join_none;

  • 线程的执行轨迹是呈树状结构,即任何线程都应该有父线程;

  • 父线程可以开辟若干子线程,父线程可以暂停或者终止子线程;

  • 当子线程终止时,父线程可以继续执行;

  • 当父线程终止时,其子线程都终止执行;

2.并行线程

fork……join需要所有并行线程都结束才会继续执行;

fork……join_any其中任意一个线程结束就继续执行;

fork……join_none不等待子线程,直接继续执行;

  • 注意:

Fork……join_any和fork……join_none继续执行后,其一些未完成的子线程仍将继续在后台执行;

如果要等待或者停止这些子线程,可使用wait fork 或者disable fork;

task do_test;    fork        ……    join_any    fork        ……    join_none    wait fork;//等待所有子线程结束endtask
task get_first(output ubt adr);    fork        ……    join_any    disable fork;endtask

3.时序控制

  • SV可以通过延迟控制或者事件(event)等待来完成时序控制;

延迟控制即通过#来完成;

#100 clk2=clk1;

事件(event)控制即通过@来完成;

@a clk1=clk2;  //等待事件

@(posedge clk)a=b;//边沿触发

Wait语句可以与事件或者表达式结合使用;

Real AOR[];  

Initial wait(AOR,size()>0)  //wait语句完成电平触发

02

线程同步

1.概述

测试平台所有线程都需要同步并进行交换数据;

一个线程等待另一个线程;

2.事件event

  • 通过event声明一个event变量,并且触发;

  • event变量可以由一端去触发,再由另一端完成阻塞式的等待,即可以用来控制多个线程之间的同步;

  • 通过->来触发事件;

  • 其他等待该事件的线程可以通过@操作符或者wait()来检查事件触发状态来完成等待事件;

event done,blast;  //声明两个独立的事件event done_too=done;   //事件done赋值给done_tootask trigger(event ev);    ->ev;   //触发ev事件endtask……fork     @done_too;  //等待done_too    #1 trigger(done);  //触发done事件joinfork    ->blast;  //触发blast事件    wait(blast.triggered);  //电平触发等待join
  • wait_order() 可使得线程保持等待,直到在参数列表中的事件event按照顺序从左往右依次完成;

wait_order(a,b,c);

3.旗语(semaphore)

旗语是一个互斥体,使用旗语可以实现对同一资源的访问控制;

在创建旗语时,会为其分配固定的钥匙数量;

使用旗语的进程必须先获得钥匙,才可访问资源;

旗语的钥匙数量可以有多个,等待旗语的进程也可以有多个;

旗语的等待队列是先进先出(FIFO),即先排队等待旗语的将优先得到钥匙;

旗语操作

创建旗语

semaphore sm;//创建一个旗语

sm=new(1); //分配一个钥匙

创建一个固定钥匙数量的旗语:new

从旗语获取一个或多个钥匙(阻塞型):get

返回一个或多个钥匙:put

获取一个或多个钥匙而不被阻塞:try_get

task send;    sem.get(1)  ///获取钥匙        ……        sem.put(1);  //处理完成时把钥匙返回endtask

03

线程通信

1.信箱

用于收发信息,SV中信箱可以存放任何数据类型,也可以从信箱中读取这些数据,

创建信箱:new()

将信息写入信箱:put()

写入信箱但不会阻塞:try_put()

获取信息:get() 获取信息并取出数据:

                  peek()获取信息不会取出数据

从信箱获取数据但不会阻塞:try_get()/try_peek()

获取信箱信息数目:num()

2.信箱和队列区别

  • 信箱必须通过new()例化,队列只需要声明

  • 信箱的存取方法put()和get()是阻塞方法,不一定会立即返回;队列的存取方法push_back和pop_front()是非阻塞方法,会立即返回;

  • 传递形式参数时,如果是input方向,则信箱类型传递的是句柄,队列类型完成的是队列内容的拷贝;

3.总结

  • event:最小信息量的触发,即单一的通知单元,用来做事件的触发,也可多个事件组合起来作线程之间的同步;

  • semaphore:共享资源安全,用于多线程间需要对某一公共资源做访问;

  • mailbpx:SV类似FIFO,在线程之间做数据通信或者内部数据缓存;

END

往期相关(?猛戳可查看)

  • SystemVerilog

  • SystemVerilog两态数据类型

  • SystemVerilog自定义、枚举、结构体类型

  • SystemVerilog数组操作

  • SystemVerilog数组类型

  • SystemVerilog函数和任务

  • SystemVerilog覆盖率

ef7fa2254149413a22da1be6a97703a9.png

$display("点个在看吧!")3df2f8af92c375993e18f9f09dac5589.gif

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

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

相关文章

java writablesheet_jxl加边框,jxl合并单元格,单元格的设置,单元格居中

jxl加边框WritableWorkbook wwb Workbook.createWorkbook(os);WritableSheet ws wwb.createSheet( "TestSheet1 ", 0);WritableFont wf newWritableFont(WritableFont.TIMES, 18, WritableFont.BOLD, true);WritableCellFormat wcf new WritableCellFormat(wf);w…

java必读书籍_最佳5本Java性能调优书籍–精选,必读

java必读书籍为什么Java开发人员应该阅读有关性能调优的书? 当我很久以前第一次面对这个问题时,我以为以后会做,但是我很长一段时间都没有回过头来。 仅当我在用Java编写的任务关键型服务器端财务应用程序中遇到严重的性能和可伸缩性问题时&a…

python为什么装不了pip_python自带pip用不了怎么办

可以通过以下命令来判断是否已安装:pip --version如果你还未安装,则可以使用以下方法来安装:$ curl https://bootstrap.pypa.io/get-pip.py -o get-pip.py # 下载安装脚本$ sudo python get-pip.py # 运行安装脚本注意:用哪个…

成为Java流大师–第4部分:数据库流

SQL一直是一种声明性语言,而Java长期以来势在必行。 Java流改变了游戏规则。 通过本动手文章编写您的方式,并学习如何使用Java流对RDBMS数据库执行声明性查询,而无需编写任何SQL代码。 您会发现,Java流和SQL命令的动词之间有着惊人…

unsafehelper java_Java 9中将移除 Sun.misc.Unsafe

灾难将至,Java 9中将移除 Sun.misc.UnsafeOracle 正在计划在Java 9中去掉 sun.misc.Unsafe API。 这绝对将是一场灾难,有可能会彻底破坏整个 java 生态圈。 几乎每个使用 java开发的工具、软件基础设施、高性能开发库都在底层使用了 sun.misc.Unsafe。 下…

python 代码格式规范脚本_Python编码规范

Python自动化测试代码编码规范一、适用范围:本规则基础为Python标准PEP8,在此基础上加了我司测试部编码规范,适用于测试部所有Python脚本编写是采用的规则.二、编码:所有的 Python 脚本文件都应在文件头标上 # -*- coding:utf-8 -…

java 根据类名示例化类_如何使用示例从Java中的类路径加载资源

java 根据类名示例化类Java中的类路径不仅用于加载.class文件,而且还可以用于加载资源,例如属性文件,图像,图标,缩略图或任何二进制内容。 Java提供了API来将这些资源读取为InputStream或URL。 假设您在项目的config文…

java课程设计进程管理_Java课设总结(个人版)

使用物理引擎JBox2D完成游戏关卡的各个物理状态模拟根据物理引擎设计Bird,Pig,Brick等游戏中出现的可运动刚体类建立JBox2d的工具类以实现###本人对这次课设的看法与吐槽 1.课设内容的脑洞是我在看完17级学长的游戏课设之后想出的 当时还没学java网络编程的内容,误以…

二叉树层次遍历c语言_[LeetCode] 107. 二叉树的层次遍历 II

题目链接 : https://leetcode-cn.com/problems/binary-tree-level-order-traversal-ii/题目描述:给定一个二叉树,返回其节点值自底向上的层次遍历。 (即按从叶子节点所在层到根节点所在的层,逐层从左向右遍历)例如: 给…

使用测微计收集应用程序指标

什么是千分尺? 千分尺是一个简单的外观,用于以供应商中立的方式收集Java应用程序中的指标。 您可以考虑使用SLF4J作为指标。 Micrometer内置了对许多不同指标后端的支持,包括Atlas,Datadog,Elastic,JMX等。…

java鼠标左键按下后拖动实现多选_鼠标拖拽多选功能

鼠标拖拽多选功能*{box-sizing:border-box;}ul{width:500px;height:auto;margin:0;padding:20px;font-size: 0;/*需设置定位*/position:relative;}li{width:70px;height:70px;margin:10px;padding:0;display:inline-block;vertical-align: top;font-size: 13px;border:1px soli…

python epoll多路复用技术_python IO 多路复用 epoll简单模型

IO多路复用就是我们说的select poll epoll通过一种机制使一个进程能同时等待多个文件描述符,而这些文件描述符(套接字描述符)其中的任意一个进入读就绪状态,epoll()函数就可以返回。所以,IO多路复用,本质上不会有并发的功能&#…

python3多线程协程_python3-----多进程、多线程、多协程

目前计算机程序一般会遇到两类I/O:硬盘I/O和网络I/O。我就针对网络I/O的场景分析下python3下进程、线程、协程效率的对比。进程采用multiprocessing.Pool进程池,线程是自己封装的进程池,协程采用gevent的库。用python3自带的urlllib.request和…

Apache CXF 3.0:CDI 1.1支持替代Spring

几周前刚刚发布了Apache CXF 3.0 ,该项目又迈出了满足JAX-RS 2.0规范要求的又一个重要步骤:与CDI 1.1集成。 在此博客文章中,我们将看几个有关Apache CXF 3.0和Apache CXF 3.0如何协同工作的示例。 从3.0版开始, Apache CXF包含一…

java varbinary_SQL 中存放 varbinary型数据

使用带有 BULK 选项的 OPENROWSET以下 Transact-SQL 增强功能支持 OPENROWSET(BULK...)函数:与 SELECT 一起使用的 FROM 子句可以调用 OPENROWSET(BULK...)而非表名,同时可以实现完整的 SELECT 功能。带有 BULK 选项的 OPENROWSET 在 FROM 子句中需要有一…

python矩阵左除_matlab学习笔记

Matlab学习笔记运算:1. 算术运算(在矩阵意义下进行):要求矩阵同型,对应元素相加减,如果用标量和矩阵相加减,不同型就凉凉提示错误,那就将矩阵每个元素和数字相加减-:同上*:A*B要求左行右列,…

只读副本和Spring Data第1部分:配置数据库

这是有关我们为利用只读副本来提高应用程序性能而寻求的一系列博客文章。 对于这个项目,我们的目标是建立我们的spring数据应用程序,并使用read仓库进行写操作,并基于read副本进行读操作。 为了模拟这种环境,我们将通过Docker使…

java结构体系_java io结构体系

Java IO体系结构看似庞大复杂,其实有规律可循,要弄清楚其结构,需要明白两点:1. 其对称性质:InputStream 与 OutputStream, Reader 与 Writer,他们分别是一套字节输入-输出,字符输入-输出体系2. 原始处理器(适配器)与链接流处理器(装饰器)其结构图如下:Reader-Writer体系1. 基类…

python turtle应用实例_turtle库应用实例2-六芒星的绘制

‪‬‪‬‪‬‪‬‪‬‮‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‭‬‫‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‪‬‪‬‪‬‪‬‪‬‪‬‮‬‫‬‭‬‪‬‪‬‪‬‪‬‪‬‮‬‪‬‭‬描述使用turtle库绘制一个六角形,效果如下:‪…

java按钮改变窗口大小_布局似乎有问题,JButton在调整窗口大小时显示出意外的行为。...

很好的例子的问题可能与平台有关,但我可以提供一些观察:您没有添加或删除组件,所以您不需要revalidate().由于背景色是按钮的绑定属性,因此不需要后续调用repaint().你,你们做需要repaint()在你的习惯里DrawingArea&am…