SVA(system verilog assertions)基础
1什么是断言:
断言就是在模拟过程中依据我们事先安排好的逻辑是不是发生了,假设发生断言成功。否则断言失败。
2断言的运行分为:预备(preponed)观察(observed)响应(reactive).
3断言的分类:并发断言(基于时钟)和即时断言(基于语义)。
4SVA(system Verilogassertions):块的建立:
序列:
Sequencename_of_sequence;
<test expression>
Endsequence
Property name _of_ property
<test expression>
Or
<sequence>
Endproperty
Assertions _name: assert property (property_name) ortest_expression;
运行块:
Assertion_name:
Assertproperty(property_name)
<success message>
Else
<fail message>
注:保持序列独立于时钟,属性中定义时钟是好的编码风格。
5 SVA检測器的步骤:
建立布尔表达式->建立序列表达式->建立属性->断言属性;
6经常使用语句及函数:
$rose():检測信号上升沿
$fell(): 检測信号下降沿
$stable(); 检測信号是否稳定。
##n:表示延迟N个时钟周期。
##[n1:n2]:延时在n1到n2个时钟周期之内。
##[n1:$]:延时在n1到无穷个时钟周期之内。
not:检測属性不为真的情况(禁止属性)
|->:假设先行算子匹配在同一个时钟周期检測兴许算子
|=>:假设先行算子匹配在下一个时钟周期检測兴许算子
ended: 以序列的结尾作为多个序列的连接点
xx?xx:xx:问号表达式与c同样。
`define true 1:利用true表达式可实现序列延时n个周期。
$past(signal_name, number of clock cycles,[gating signal]):用来检測n个时钟周期之前逻辑表达式的值。
Signalor sequence [*n] 连续反复
Signal[->n]:尾随反复(在其后必须有一个信号使得最后一次反复有效发生在其后逻辑发生之前的时钟周期)。
Signal[=n]:非连续反复,反复次数为n
and: 两个序列必须有同样的起始点。
intersect:两个序列必须在同样时刻開始而且结束于同一时刻。
or:当中一个序列成功就可以。
first_match:and or的序列中指定了时间窗,就可能同一检验具有多个匹配的情况。
first_match确保仅仅是用第一次序列匹配。
throughout:(expression) throughout (sequence definition)保证某些条件在检測过程中一直为真。
within:seq1 within seq2。seq1序列的检測必须包括在seq2的起始点和结束点。
内建系统函数:
$onehot(expression):在随意给定的时钟沿,表达式仅仅有一位为高。
$onehot0(expression):有一位或者没有位为高。
$isunknown(expression):检查表达式的不论什么位是否为x或者z。
$countones(expression):计算向量中为高的位的数量。
disable iff (expression) <property definition>: 当某些条件为真时则不进行检測。
matched: 能够用来检測第一个子序列的结束点。
expect:属性成功的检验
<cover_name>: cover property (property_name):cover会检測序列的:被尝试检測次数。属性成功次数;属性失败次数;属性空成功次数。
7一个样例:
sequences32a;
@(posedgeclk)
((!a&&!b) ##1 (c[->3]) ##1 (a&&b)); //信号a和信号b均为低电平。经过一个时钟的延时后检測信号c是否连续出现三次高电平。且c最后一次为高电平时,经过一个时钟延时信号a和信号b均为高电平。
endsequence
sequences32b;
@(posedgeclk)
$fell(start) ##[5:10] $rose(start); //从start的下降沿開始。经过5-10个时钟周期start出现上升沿。即start保持低电平5-10个时钟周期。
endsequence
sequence s32;
@(posedgeclk)
s32a within s32b; //序列s32a 包括在 s32b中。即序列s32b的起始点和结束点包括s32a的起始点和结束点
endsequence
property p32;
@(posedgeclk)
$fell(start) |-> s32;//在start的下降沿马上检測s32.
endproperty
a32: assert property(p32);
SVA(system verilog assertions)基础的更多相关文章
- (转)新手学习System Verilog & UVM指南
从刚接触System Verilog以及后来的VMM,OVM,UVM已经有很多年了,随着电子工业的逐步发展,国内对验证人才的需求也会急剧增加,这从各大招聘网站贴出的职位上也可以看出来,不少朋友可能想尽 ...
- System Verilog基础(一)
学习文本值和基本数据类型的笔记. 1.常量(Literal Value) 1.1.整型常量 例如:8‘b0 32'd0 '0 '1 'x 'z 省略位宽则意味着全位宽都被赋值. 例如: :] sig1 ...
- 【转】uvm 与 system verilog的理解
http://www.cnblogs.com/loves6036/p/5779691.html 数字芯片和FPGA的验证.主要是其中的功能仿真和时序仿真. 验证中通常要搭建一个完整的测试平台和写所需要 ...
- system verilog中的跳转操作
在verilog中,使用disable声明来从执行流程中的某一点跳转到另一点.特别地,disable声明使执行流程跳转到标注名字的声明组末尾,或者一个任务的末尾. verilog中的disable命令 ...
- system verilog中的类型转换(type casting)、位宽转换(size casting)和符号转换(sign casting)
类型转换 verilog中,任何类型的任何数值都用来给任何类型赋值.verilog使用赋值语句自动将一种类型的数值转换为另一种类型. 例如,当一个wire类型赋值给一个reg类型的变量时,wire类型 ...
- 一段比较有意思的代码——介绍system verilog中的新增幅值语句
system verilog中新加了很多幅值语句,虽然都只适用于阻塞幅值,但是在某些场合中非常实用. 下面是一段有意思的代码,覆盖了一些用法. package definitions; typedef ...
- Verilog语法基础讲解之参数化设计
Verilog语法基础讲解之参数化设计 在Verilog语法中,可以实现参数化设计.所谓参数化设计,就是在一个功能模块中,对于一个常量,其值在不同的应用场合需要设置为不同的置,则将此值在设计时使用 ...
- Verilog HDL基础语法讲解之模块代码基本结构
Verilog HDL基础语法讲解之模块代码基本结构 本章主要讲解Verilog基础语法的内容,文章以一个最简单的例子"二选一多路器"来引入一个最简单的Verilog设计文件的 ...
- System Verilog随笔(1)
测试文件该怎么写? 首先看一个简单代码案例: `timescale 1ns/10ps //1 module test; //2 intput wire[15:0] a; output reg[15 ...
随机推荐
- minidump详细介绍
Effective minidump 简介 在过去几年里,崩溃转储(crash dump)成为了调试工作的一个重要部分.如果软件在客户现场或者测试实验室发生故障,最有价值的解决方式是能够创建一个故障瞬 ...
- Twenty Newsgroups Classification实例任务之TrainNaiveBayesJob(一)
接着上篇blog,继续看log里面的信息如下: + echo 'Training Naive Bayes model' Training Naive Bayes model + ./bin/mahou ...
- MVC之国际化
MVC之国际化 前言 在项目中遇到国际化语言的问题是常有的事情,之前在做关于MVC国际化语言时,刚开始打算全部利用AngularJS来实现,但是渐渐发现对于页面Title难以去控制其语言转换,于是对于 ...
- JDBC增删改数据库的操作
JDBC入门及简单增删改数据库的操作 一.JDBC的引入 1.JDBC的概念 JDBC:Java Database Connection,表示数据库连接(任何数据库都支持JDBC的连接),是一个独立于 ...
- WPF案例 (四) 模拟Windows7桌面任务栏
原文:WPF案例 (四) 模拟Windows7桌面任务栏 这个程序模彷了Windows7的桌面任务栏,当在桌面上双击某个快捷方式时,将打开一个新的子界面,并且在任务栏里创建一个链接到此界面的任务栏图标 ...
- 网页favicon.ico图标设置(转)
随便打开一个网页:比如 http://www.baidu.com/ 可以看到在浏览器的标签头上面显示了一个图标,这个图标是:,也就是我们常说的favicon.ico. 由于这篇文章主要讨论favico ...
- jQuery中的getJSON()
json文件是一种轻量级的数据交互格式.一般在jQuery中使用getJSON()方法读取. $.getJSON(url,[data],[callback]) url:json文件地址 data:可选 ...
- ElasticSearch+Kibana 索引操作
ElasticSearch+Kibana 索引操作 一 前言 ElasticiSearch 简介 ElasticSearch是一个基于Lucene的搜索服务器.它提供了一个分布式多用户能力的全文搜索引 ...
- hotmail邮箱pop3server设置方法
hotmail邮箱 的POP3/SMTP功能仅仅向Hotmail Plus的用户开放,普通用户想要使用这一功能的话,得进行一些特别的设置.如今这一功能总算面向全部的用户开放了,虽然微软官方还没宣布这一 ...
- android "Missing type parameter" 错误
近期在做android应该的时候出现这个问题,分析了一下日志,发现是在gosn解析的时候会出现,并且出现的时候非常诡异.于是去网上找相关资料. 发现这个问题还是比較常见的,原来是公布版本号和非正式公布 ...