System Verilog随笔(1)
测试文件该怎么写?
首先看一个简单代码案例:
`timescale 1ns/10ps //1
module test; //2
intput wire[15:0] a;
output reg[15:0] b;
reg clock;
chip chip(.clock(.clock)); //3
always #5 clock=~clock; //4
initial begin //5
clock=0;
repeat(5) @(nagedge clock);
$display("chip.i = %0d",chip.i);
end
endmodule
1、`timescale 1ns/1ns行
编译指令`timescale包括:时间单位(1ns)和时间精度(10ps),单位表示仿真时间的最小值,精度表示保留到小数点后几位(10ps是后两位)。`timescale的作用范围并不限于指定得模块或文件,再遇到`timescale后,指定的时间单位和精度一直保持到遇到下一条`timescale语句。
System Verilog还可以给时间指定时间单位,可以用下方语句实现:
forever #5ns clock=~clock;
//其中时间值和时间单位之间不能有空格,# 5ns正确,# 5 ns则错误。
在System Verilog中,也允许使用关键字timeunit和timeprecision进一步增强时间单位说明,在使用时要注意必须在其他任何声明或语句之前,紧随模块、接口或程序的声明之后,例子如下:
module adder_tb;
input wire[63:0] a,b;
output reg[63:0] sum;
output reg carry;
timeunit 1ns; //单位1ns
timeprecision 10ps; //精度10ps
...
endmodule
当然,timeunit和timeprecision也可以在编译单元域中使用,使用时要先于其他任何声明,这里就不举例了。
2、module行
module就是一个模块,由描述端口和描述逻辑功能两部分组成。其中描述端口有输出口output,输入口input,输入/输出口inout三种。测试文件中的module作用是相当于顶层文件或对顶层文件添加激励,在module的端口声明中还要包括clock。写法可以如上方2处所示。其中,test是模块的名称,intput为输入端口,output为输出端口,clock为时钟。这里我再对数据的类型简单做一个总结吧。
2.1值的类型
包括:0,1,x,z
2.2线网(net)
包括:wire,wor,wand,tri,triand,trior,trireg等。其中wire最常用,wire和tri在语法和功能上相同,但wire只有一个驱动源,tri可以有多个。trireg用来为能够储存值的电容线性网建立模型,tri0和tri1用来为电源建立模型。
2.3寄存器(var)
包括:reg,integer,time,real等。其中reg最常用,为通用型,默认值x,无符号。integer为整型,用来储存整数,默认位宽为宿主机字的位数。real为实型,存储实数。time为时间寄存器,用来存放仿真时间。
2.4参数
包括:parameter,localparam,defparam。parameter在模块内定义为常数,不能像变量那样赋值,但可在编译阶段被重载。defparam可以改变parameter的参数值。localparam为局部参数,不能被重载也不能通过defparam改变参数值。
其他的如字符串、数组等这里就不介绍了。
3、函数调用和连线
将需要测试的模块导入测试文件,然后进行连线。
4、always语句
always块中,从0时刻开始顺序执行其中的行为语句,当最后一条执行完毕后再次执行第一条语句。通常用来产生时间脉冲。
5、initial块
initial语句内的语句构成了一个initial块,initial块从仿真0时刻开始执行,在整个仿真过程中只执行一次。若测试文件中包括多个initial块,则这些initial块从仿真0时刻开始并发执行,且每个快都各自独立。
clock需要在initial块中初始化。
System Verilog随笔(1)的更多相关文章
- 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 ...
- 【转】uvm 与 system verilog的理解
http://www.cnblogs.com/loves6036/p/5779691.html 数字芯片和FPGA的验证.主要是其中的功能仿真和时序仿真. 验证中通常要搭建一个完整的测试平台和写所需要 ...
- System Verilog基础(一)
学习文本值和基本数据类型的笔记. 1.常量(Literal Value) 1.1.整型常量 例如:8‘b0 32'd0 '0 '1 'x 'z 省略位宽则意味着全位宽都被赋值. 例如: :] sig1 ...
- (转)新手学习System Verilog & UVM指南
从刚接触System Verilog以及后来的VMM,OVM,UVM已经有很多年了,随着电子工业的逐步发展,国内对验证人才的需求也会急剧增加,这从各大招聘网站贴出的职位上也可以看出来,不少朋友可能想尽 ...
- system verilog的一些总结(从其他博客复制来的)
转载自 http://blog.sina.com.cn/s/blog_e7fec2630101f5t9.html SystemVerilog是一种硬件描述和验证语言(HDVL),它基于IEEE 136 ...
- SVA(system verilog assertions)基础
1什么是断言: 断言就是在模拟过程中依据我们事先安排好的逻辑是不是发生了,假设发生断言成功.否则断言失败. 2断言的运行分为:预备(preponed)观察(observed)响应(reactive). ...
- System Verilog基础(二)
这一篇笔记主要记录Procedural,Process,Task and function,Interface和Communication中值得注意的点. 1.Procedural 写testbenc ...
随机推荐
- MySQL 字符类型
字符类型 MySQL提供了多种关于字符存储的类型,但是在大多数情况下我们只使用char和varchar即可 类型 大小 用途 CHAR 0-255字节 定长字符串 VARCHAR 0-65535 字节 ...
- Android开发必有功能,更新版本提示,检测是否有新版本更新。下载完成后进行安装。
作者:程序员小冰,CSDN博客:http://blog.csdn.net/qq_21376985,转载请说明出处. 给大家介绍个东西,MarkDown真的超级超级好用.哈哈.好了, 正题内容如下: 先 ...
- pybind11: C++ 工程如何提供 Python 接口
C/C++ 工程提供 Python 接口,有利于融合进 Python 的生态.现在 Python 在应用层,有其得天独厚的优势.尤其因为人工智能和大数据的推波助澜, Python 现在以及未来,将长期 ...
- leetcode-双指针遍历
编写一个函数,其作用是将输入的字符串反转过来.输入字符串以字符数组 char[] 的形式给出.不要给另外的数组分配额外的空间,你必须原地修改输入数组.使用 O(1) 的额外空间解决这一问题.你可以假设 ...
- 外包公司派遣到网易,上班地点网易大厦,转正后工资8k-10k,13薪,包三餐,值得去吗?
作为一个人,我们必须时时刻刻清醒地看待自己,做到不卑不亢才能坚强地活下去. 请肆无忌惮地点赞吧,微信搜索[沉默王二]关注这个在九朝古都洛阳苟且偷生的程序员.本文 GitHub github.com/i ...
- 使用Built-in formatting来创建log字符串
在一次哦测试中,sonar-qube总是报Use the built-in formatting to contruct this argument, 在网上查了一下,原来它是推荐这样做: log.i ...
- TCP三次握手、四次挥手理解及可能问为什么?
三次握手: TCP3次握手连接:浏览器所在的客户机向服务器发出连接请求报文(SYN标志为1),此时,TCP客户端进程进入了 SYN-SENT(同步已发送状态)状态. 服务器接收报文后,同意建立连接, ...
- leetcode刷题-94二叉树的中序遍历
题目 给定一个二叉树,返回它的中序 遍历. 实现 # def __init__(self, x): # self.val = x # self.left = None # self.right = N ...
- 为商务办公赋能,TOM商务邮箱,塑造职场新形象
转眼已至2020年,互联网的这10年发生了翻天覆地的改变.短视频红利崛起.人脸识别支付.AI智能机器人对话...很多产品从默默无闻到一夜崛起.而对于商务邮箱领域,邮箱已成为一种习惯,却往往忽略了它的点 ...
- 企业网站还是要考虑兼容至少IE10
中国国情,大部分企业还在使用win7,IE浏览器.为了兼容这些,还是少用比较VUE等一些高级的框架,改为使用jquery.用惯了VUE,jquey好多忘得差不多了,其中遇到的问题及解决方案 ajax, ...