Systemverilog for design 笔记(三)
转载请标明出处
用户自定义和枚举数据类型
1. 用户自定义类型(typedef)
局部typedef定义:只用于设计的特定部分时,typedef的定义可在module或interface中
共享typedef定义:当在多个模型中使用时,typedef的定义可在包中进行, module,interface,program block可以通过导入包子项来使用typedef定义
Eg:
package chip_types;
`ifdef TWO_STATE
typedef bit dtype_t; //当宏定义TWO_STATE时定义dtype_t为bit类型
`else
typedef logic dtype_t;
`endif
Endpackage
import chip_types::dtype_t; // import 定义 into $unit
module counter
(output dtype_t [15:0] count,
Input dtype_t clock, resetN);
...
Endmodule
2. 枚举数据类型(enum)
想给数值一个label时,Verilog和SV会采取不同的方法:
Verilog:
用parameter/`define来定义一组常数或者宏名。
Eg:`define FETCH 3'h7 //宏定义
module controller (output reg read...);
parameter LOAD = 0; //常数定义
always @(State) begin
if (State == LOAD && instruction == `FETCH) //使用label
...
Endmodule
SV:
使用枚举enum
Eg: package chip_types;
typedef enum {FETCH, WRITE, ADD, SUB,MULT, DIV, SHIFT, NOP }instr_t;
//用户自定义枚举类型instr_t
Endpackage
import chip_types::*; //import包定义到$unit编译单元域
module controller (input instr_t instruction,...); //input instr_t类型instruction
enum {WAITE, LOAD, STORE} State, NextState; //枚举类型State, NextState,
//他俩的值只能是{}中的label
always_comb begin
if (State == LOAD && instruction == FETCH) //使用label
...
Endmodule
从包中导入enum时,只导入定义名时不会自动导入枚举值标签。所以一般用*导入整个包或者显示导入每个标签。
.2.1. 枚举类型标签序列
|
state |
创建单个标签state |
|
state[N] |
创建标签序列 state0,state1, ... stateN-1 |
|
state[N:M] |
创建标签序列,由stateN开始,到stateM(正反向不存在) |
2.2. 枚举类型标签作用域
enum列表中的label在其作用域内必须是唯一的(label唯一)
这里的作用域包括:$unit, modules, interfaces, programs,
begin...end blocks, fork...join blocks, tasks and functions
.2.3. 枚举类型值
枚举类型值在没有显示指定时,默认int从0自加。且label的值也要唯一(value唯一)
Eg: enum {A=1, B, C, X=24, Y, Z} list; //A=1,B=2,C=3,X=24,Y=25,Z=26
.2.4. 枚举类型的基类
枚举类型的默认基类(base type)是int,也可以对枚举类型的基类进行显示声明
Eg:
enum logic [1:0] {WAITE, LOAD, READY} state; //2位宽的枚举类型,四态基类
注意label数涉及到value的值,要与基类类型匹配。
.2.5. 自定义枚举类型
typedef enum {WAITE, LOAD, READY} states_t; //自定义枚举类型states_t
states_t state, next_state; //声明枚举state,next_state
同类型枚举变量可以互相赋值
2.6. 枚举类型的专用系统任务(system tasks)和方法(method)
方法(method):SV提供了一些能自动处理enum的内置函数
调用方式(类似C++):
<enum_variable_name>.first:返回指定变量枚举列表的第一个成员的值
<enum_variable_name>.last:返回指定变量枚举列表的最后一个成员的值
<enum_variable_name>.next(<N>):从枚举变量的当前位置算起,返回后面第N个 成员的值。如果枚举变量当前值不在枚举变量列表中,则返回列表中第一 个成员的value。<N>可缺省。缺省时返回枚举列表中下一个成员的值。
<enum_variable_name>.prev(<N>):从枚举变量的当前位置算起,返回前面第N个 成员的值。如果枚举变量当前值不在枚举变量列表中,则返回列表中最后 一个成员的value。<N>可缺省。缺省时返回枚举列表中前一个成员的值。
<enum_variable_name>.num:返回变量的枚举列表中元素个数
<enum_variable_name>.name:返回枚举变量中代表这个value的字符串
Systemverilog for design 笔记(三)的更多相关文章
- Systemverilog for design 笔记(六)
转载请标明出处 第一章 有限状态机建模(FSM,finite state machine) 1.1. 使用枚举类型建立状态机模型 l 三过程块建模风格:三个过程块分别实现: a.状态转换(al ...
- Systemverilog for design 笔记(七)
转载请标明出处 第一章 接口(interface) 1.1. 接口的概念 接口允许许多信号合成一组由一个端口表示. 1.2. 接口声明 //接口定义 Interface main_bus ...
- Systemverilog for design 笔记(五)
转载请标明出处 第一章 System Verilog过程块.任务和函数 1.1. verilog通用目的always过程块(procedural block)(可综合) always过程块的综合 ...
- Systemverilog for design 笔记(四)
转载请标明出处 数组.结构体和联合体 1. 结构体(struct) 1.1. 结构体声明 结构体默认是变量,也可以声明为线网 var struct { // 通过var进行结构体变量声明 logic ...
- SystemVerilog for design 笔记(二)
转载请标明出处 1. System Verilog文本值和数据类型 1.1. 增强的文本值赋值 相对于verilog,SV在文本值赋值时可以1.无需指定进制 2.赋值可以是逻辑1 用法: reg ...
- Systemverilog for design 笔记(一)
转载请标明出处 一. System Verilog 声明的位置 1. 包(packages) Verilog要求局部声明: variables, nets, tasks and f ...
- Oracle学习笔记三 SQL命令
SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)
- 《CMake实践》笔记三:构建静态库(.a) 与 动态库(.so) 及 如何使用外部共享库和头文件
<CMake实践>笔记一:PROJECT/MESSAGE/ADD_EXECUTABLE <CMake实践>笔记二:INSTALL/CMAKE_INSTALL_PREFIX &l ...
- Mastering Web Application Development with AngularJS 读书笔记(三)
第一章笔记 (三) 一.Factories factory 方法是创建对象的另一种方式,与service相比更灵活,因为可以注册可任何任意对象创造功能.例如: myMod.factory('notif ...
随机推荐
- iframe多层嵌套时,Jquery获取元素
在项目中,尤其是后台管理项目,会使用到iframe嵌套的网页,说起iframe,真的是个让人头疼的东西,能避开是最好避开.不然要请随身备好氧气瓶哈(因为管理和调试过程中往往会被气缺氧!!!哈哈哈~~~ ...
- 吴裕雄 python 机器学习——数据预处理流水线Pipeline模型
from sklearn.svm import LinearSVC from sklearn.pipeline import Pipeline from sklearn import neighbor ...
- postgresql数据库利用函数返回查询结果集
- 安卓之图像视图ImageView
一.有关属性说明 (1)scaleType:指定图形的拉伸类型,默认是fitCenter:拉伸类型的取值如下: (2)src:指定图形来源,src图形按照scaleType拉伸:背景图不按scaleT ...
- 关注Ionic底部导航按钮tabs在android情况下浮在上面的处理
Ionic是一款流行的移动端开发框架,但是刚入门的同学会发现,Ionic在IOS和android的底部tabs显示不一样.在安卓情况下底部tabs会浮上去. 如下图展示: 网上也有很多此类的解决方案 ...
- 从头学pytorch(四) softmax回归实现
FashionMNIST数据集共70000个样本,60000个train,10000个test.共计10种类别. 通过如下方式下载. mnist_train = torchvision.dataset ...
- 让你的逼格瞬间提升的十个Python语法!
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手.不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了.本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并 ...
- 世界协调时间(UTC)与中国标准时间
整个地球分为二十四时区,每个时区都有自己的本地时间.在国际无线电通信场合,为了统一起见,使用一个统一的时间,称为通用协调时(UTC, Universal Time Coordinated).UTC与格 ...
- 安卓开发:用ImageView放上图片后上下有间隙
想不到在我使用第一个UI控件ImageView时候就遇上了问题,简单使用ImageView如下: <ImageView android:layout_width="match_pare ...
- UIViewController的API
- (instancetype)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil; 返回一个新初始化 ...