SystemVerilog硬件设计及建模—第34章-PPT课件.ppt
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《SystemVerilog硬件设计及建模—第34章-PPT课件.ppt》由用户(三亚风情)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- SystemVerilog 硬件 设计 建模 34 PPT 课件
- 资源描述:
-
1、MicroElectronics Center 增强的文本值 改进的define文本替换 时间值 新的变量类型 有符号和无符号类型 静态和动态变量 类型转换 常数第3章 SystemVerilog文本值和数据类型MicroElectronics Center3.1 增强的文本赋值 Verilog中的向量赋值:parameter SIZE=64;reg SIZE 1:0 data;data=0;/将数据各位置0 data=bz;/将数据各位置z data=bx;/将数据各位置x 但如何给data赋全1的值?data=64hFFFFFFFFFFFFFFFF;/不可扩展,如果 /SIZE改为128呢
2、?data=0;/1的补码 data=-1;/2的补码MicroElectronics Center3.1 增强的文本赋值 SystemVerilog在向量赋值的增强:1.可以只指定要赋的值,不用指定进制 2.赋值可以是逻辑1,该语法指定所有位所赋的值 parameter SIZE=64;reg SIZE 1:0 data;data=0;/将数据各位置0 data=1;data=z;/将数据各位置z data=x;/将数据各位置xMicroElectronics Center3.2 define增强 Verilog允许在define宏中使用双引号,但是双引号内的文本变成了文本串,即在veril
3、og中不能采用在字符串中嵌入宏变量的文本替换宏创建字符串 define print(v)$display(“variable v=%h”,v)print(data);/$display(“variable v=%h”,data);SystemVerilog允许字符串内的宏变量替换!define print(v)$display(“variable v=%h”,v)print(data);/$display(“variable data=%h”,data);MicroElectronics Center3.2 define增强 SystemVerilog允许在包含变量替换的宏文本字符串中使用隔离
4、引号,SV中如何通过宏定义实现下面与Verilog相同功能的语句?$display(“variable”data”=%h”,data);define print(v)$display(“variable”v”=%h”,v)print(data);$display(“variable”data”=%h”,data);MicroElectronics Center3.2 define增强 SystemVerilog可以提供了一个不引入空格的方法,通过使用两个连续的重音符号,使两个或多个文本宏连接成一个新名字 bit d00_bit;wand d00_net=d00_bit;bit d01_bit;
5、wand d01_net=d01_bit;.bit d62_bit;wand d62_net=d62_bit;bit d63_bit;wand d63_net=d63_bit;define TWO_STATE_NET(name)bit name_bit;wand name_net=name_bit;TWO_STATE_NET(d00);MicroElectronics Center3.3 SystemVerilog变量 对象类型和数据类型SystemVerilog四态变量SystemVerilog两态变量显式及隐式变量和线网类型综合指导MicroElectronics Center3.3.1
6、对象类型和数据类型 对象类型指明信号是变量还是线网;数据类型指明变量或线网的值系统:两态数据类型或四态数据类型 Verilog数据类型:变量:integer,reg,time线网:wire,wor,wand SystemVerilog数据类型:包含了所有的Verilog数据类型1.增加了一些新数据类型:byte,int,logicMicroElectronics Center3.3.2 SystemVerilog四态变量 SystemVerilog用logic关键字描述通用的针对硬件的数据类型,logic数据类型变量与Verilog中的reg类型是大多数情况下可以互换使用 logic类型变量声
7、明:logic resetN;/一位四态变量 logic 63:0 data;/64位宽变量 logic 0:7 array 0:255;/8位数组变量 显式变量或线网声明:var logic 63:0 addr;/64位宽变量 wire logic 63:0 addr;/64位宽线网Why logic?MicroElectronics Center3.3.3 SystemVerilog两态变量 适合于更高抽象层次建模,如系统级和交易级 bit1位两态整数 byte8位两态整数,与C语言的char类似 shortint16位两态整数,与C语言的short类似 int32位两态整数,与C语言的i
8、nt类似 longint64位两态整数,与C语言的long类似 bit resetN;bit 63:0 data;bit 0:7 array 0:255;var bit 63:0 addr;MicroElectronics Center3.3.3 SystemVerilog两态变量 类似C语言类型优点:类似C语言的两态类型如int和byte,主要用来描述更抽象的总线功能模型,不需要描述硬件细节,如三态总线及可能产生逻辑值X的硬件冲突 易于使用SystemVerilog的直接编程接口(DPI),建立Verilog到C或C+的接口,因为数据类型相同,所以数据在两语言间的传递更简单有效1.for 语
9、句中的循环变量,综合后就消失了,int类型是一个很好的选择MicroElectronics Center3.3.4 显式及隐式变量和线网类型 声明语句中,数据类型前没有显式指定对象类型时,则推断为隐式变量 logic 7:0 busA;bit 31:0 busB;var logic 7:0;var bit 31:0 b;typedef enum bit FALSE,TRUE bool_t;var bool_t c;var 7:0 d;/四态8位变量 wire 31:0 busB;/隐含为四态逻辑数据类型 wire logic 31:0 busC;两态线网问题 wire reg 31:0 bus
10、D;MicroElectronics Center3.4 RTL中使用两态类型 SystemVerilog新增加的两态类型可以用于设计抽象建模,这种情况下很少用到三态值,可能导致不确定值或不可预测值(X)的电路不会出现。SystemVerilog允许给一个两态类型赋四态值,其映射关系如下:四态值转换为0011Z0X0MicroElectronics Center3.4.1 两态类型和四态类型仿真1.两态模式仿真器:软件工具在设计模型不需要使用逻辑Z和X时提供的仿真模式,提高仿真速度2.多数两态模式仿真器通常不能使用两态与四态混合仿真3.不同两态模式仿真器将Z和X映射到两态类型时可能不同,导致仿
11、真结果不同4.两态仿真模式对casez和casex解释不同,从而导致仿真结果不同5.SystemVerilog中标准两态类型为所有软件工具提供相同的行为,同时,四态到两态的映射也是标准化的,因此所有软件工具仿真结果也是一致的MicroElectronics Center3.4.2 case语句中使用两态类型缺省赋值两个优点:其一是综合会将条件选择项的译码逻辑进行优化,不会考虑缺省分支条件表达的值如何译码;其二是缺省X赋值有助于检测RTL模型中的设计错误 case(state)RESET:next=WAIT;WAIT:next=LOAD;LOAD:next=DONE;DONE:next=WAIT
12、;default:next=4bx;/不定态 endcase但如果是两态变量呢?!给两态变量赋一个X值如何?MicroElectronics Center3.5 数据类型规则的放宽 SystemVerilog简化了模型中数据类型的使用,任何数据类型的变量都可以通过下列方式赋值:initial或always过程块中赋值 在单个always_comb,always_ff或always_latch过程块中赋值 通过单个模块或原语的output/inout端口驱动赋值大部分信号可以声明为变量类型!MicroElectronics Center3.5 数据类型规则的放宽 module compare(o
13、utput logic lt,eq,gt,input logic 63:0 a,b);always(a,b)if(a b);/连续赋值 comparator u1(eq,a,b);/模块例化 endmodule module comparator(output logic eq,input logic 63:0 a,b);always(a,b)eq=(a=b);endmoduleMicroElectronics Center3.5 数据类型规则的放宽 对变量使用的限制可以防止设计错误:多个输出端口驱动一个变量;对一个变量进行多次连续赋值;对同一个变量同时进行过程赋值和连续赋值 module a
14、dd_and_increment(output logic 63:0 sum,output logic carry,input logic 63:0 a,b);always(a,b)sum=a+b;/过程赋值 assign sum=sum+1;/error,sum已经被过程赋值一次 look_ahead i1(carry,a,b);/carry被驱动一次 overflow_check i2(carry,a,b);/error,carry再一次被驱动 endmodule module loock_ahead(output wire carry,.endmodule module overflow
15、_check(output wire carry,.endmoduleMicroElectronics Center3.6 有符号和无符号修饰符 integer j;/verilog-2019标准,32位有符号数 reg 63:0 u;/无符号64位数 reg signed 63:0 s;/有符号64位数,verilog-2019标准 SystemVerilog增加了缺省为有符号数的数据类型:byte,shortint,int和longint int s_int;/有符号32位变量 int unsigned u_int;/无符号32位变量与verilog相同,SystemVerilog只能在类
16、型关键字后面指定signed或unsigned关键字,与C语言不同!MicroElectronics Center3.7 静态变量和自动变量 verilog-2019标准中,所有数据类型都是静态的 verilog-2019标准中在任务和函数中添加了自动变量 自动变量特点是其存储区在需要时由软件工具动态分配,不需要时被释放,因此也被称为动态变量。自动变量用途:1.用于描述在测试程序、抽象系统级、交易级或总线功能模型中的验证程序 2.用于编写可重入任务或递归函数 MicroElectronics Center3.7 静态变量和自动变量平衡加法器:把数组的所有元素加在一起,被加的数组元素高、低地址作
17、为函数的输入。function automatic int b_add(int lo,hi);int mid=(lo+hi+1)1;if(lo+1!=hi)return(b_add(lo,(mid 1)+b_add(mid,hi);else return(arraylo+arrayhi);endfunction MicroElectronics Center3.7 静态变量和自动变量 SystemVerilog增加了关键字static,允许任何变量显式被声明为static或automatic,这个声明可以出现在任务、函数、beginend块或forkjoin块中,但在module一级声明的变量
18、不能显式地声明为static或automatic,在module级,所有变量都是静态的!function int count_ones(input 31:0 data);automatic logic 31:0 count=0;automatic logic 31:0 temp=data;for(int j=0;j =1;end return count;endfunction MicroElectronics Center3.7 静态变量和自动变量 检查程序运行总错误数任务:typedef struct packed packet_t;task automatic check_results
19、(input packet_t sent,received,output int total_errors);static int error_count=0;if(sent!=received)error_count+;total_errors=error_count;endtask SystemVerilog缺省存储方式与Verilog兼容,在模块、beginend块、forkjoin块以及非自动任务和函数中,缺省存储方式为静态的,如果一个任务和函数被声明自动的,则缺省存储方式的自动的。MicroElectronics Center3.7.1 静态变量和自动变量的初始化 SystemVer
20、ilog对Verilog进行了扩展,在模块、任务、函数中声明的变量可以有内嵌初始值,静态变量只初始化一次,自动变量每次调用时都初始化 function int count_ones(input 31:0 data);logic 31:0 count=0;logic 31:0 temp=data;for(int k=0;k=31;k+)begin if(temp0)count+;end return count;endfunction 上述程序不能正确工作:第一次调用时,count初始为0,再次调用时,静态变量count保持上次调用时的值,从而导致计数错误 静态变量初始化是不可综合的,动态变量初
21、始化是可综合的!MicroElectronics Center3.7.2 静态变量和自动变量使用原则 在always和initial块中,如果无内嵌初始化则使用静态变量,而需要内嵌初始化则使用自动 变量 如果一个任务或函数是可重入的,则应设成自动的,变量也应是自动的,除非要在两次调用之间保持变量的值 如果一作任务或函数用来描述硬件的独立部分,并且不是可重入的,则应声明为静态的,任务或函数中的变量也应是静态MicroElectronics Center3.8 变量初始化的确定性 Verilog初始化不确定 SystemVerilog内嵌初始化在时间0之前 Verilog内嵌初始化可能引起事件,S
22、ystemVerilog不引起事件 SystemVerilog内嵌初始化是确定的 integer j=5;integer k;/integer k=j;initial k=j;/initial/k=j;logic resetN=0;always(posedge clk,negedge resetN)if(!resetN)count=0;else count=count+1;resetN初始与always过程谁先被仿真器激活,表现的结果是不同的!MicroElectronics Center3.8.1 时序逻辑的异步输入初始化 module counter(input wire clk,rese
23、tN,output logic 15:0 count);always(posedge clk,negedge resetN)if(!resetN)count=0;else count=count+1;endmodule module counter_test;wire 15:0 count;bit clk;bit resetN=1;counter counter_1(clk,resetN,count);always#10 clk=clk;initial begin resetN=0;#2 resetN=1;$display(“n count=%0d(expect 0)n”,count);end
展开阅读全文