V0 第 6 节自定义类型

2023-12-10 19:38
文章标签 类型 自定义 v0

本文主要是介绍V0 第 6 节自定义类型,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.自定义类型

  • 通过用户自定义类型,以往Verilog的代码将可以通过更少的代码来表示更多的功能
  • 用户自定义类型使得代码的可读性更好
  • 通过typedef来创建用户自定义类型
  • 通过enum来创建枚举类型
  • 通过struct来创建结构体类型
  • Verilog语言无法提供方便的特性来使得用户扩展变量和线网类型
  • SV则提供了特性使得用户可以构建更高抽象层的数据类型
  • 定义了新的数据类型,就可以利用该类型声明变量

1.1 typedef创建用户自定义类型

例:

typedef unsigned int uint;
uint a,b;//声明2个无符号数变量
  • 为了使代码更容易读和维护,通常我们习惯添加 _t 的后缀用来表示它是一个自定义类型type

1.2 enum创建枚举类型

  • 枚举类型enum可以描述变量的合法值范围,其每一个值都需要提供一个用户自定义的名字
    例:
enum 
{red,green,blue
} RGB;
  • Verilog语言不支持枚举类型,使用宏来定义各个合法值的宏名称
  • 默认的枚举类型是int,即32位的二值逻辑数据类型
  • 为了更准确地描述变量,SV允许指明其数据类型
    例:
enum bit {TRUE, FALSE} Boolean;
enum logic [1:0] {WAITE, LOAD, READY} state;
  • 如果枚举类型变量被赋值,那么所赋的值应在其数值范围
  • Verilog或者SV可以在不同的数据类型之间通过隐性转换 ,进行直接赋值,因此Verilog/SV 的数据类型转换是宽松的

1.3 结构体类型

  • 设计或者验证的数据经常会有逻辑相关的数据信号组,例如一个总线协议的所有控制信号,或者在一个状态控制器中用到的所有的信号,Verilog语言没有方便的特性可以将相关的信号收集整理到一个信号组中
  • SV添加了同C一样的结构体struct,而结构体的成员可以是任何变量类型,包括自定义类型或者其它常量类型
struct 
{int a;int b;	// 32位变量opcode_t opcode;//用户自定义类型logic [23:0] address;//24位变量bit error;//1位变量
}Instruction_Word;
  • 结构体是变量的合集,因此结构体类型的变量也可以用来索引到其内部的变量,索引方式同C语言一致:
<structure_name>.<variable_name>
Instruction_Word.address = 32'hF000001E;
  • 结构体类型默认也是变量类型,用户也可以显式声明其为var或者wire类型
  • 结构体变量可以通过索引其各个成员做依次的成员赋值
  • 也可以通过分号’ 和花括号{}来实现整体赋初值
IW = '{100, 3, 8'hFF, 0};
IW = '{address:0, opcode:8'hFF, a:100,b:5};

这篇关于V0 第 6 节自定义类型的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/478143

相关文章

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

Pydantic中Optional 和Union类型的使用

《Pydantic中Optional和Union类型的使用》本文主要介绍了Pydantic中Optional和Union类型的使用,这两者在处理可选字段和多类型字段时尤为重要,文中通过示例代码介绍的... 目录简介Optional 类型Union 类型Optional 和 Union 的组合总结简介Pyd

Oracle数据库常见字段类型大全以及超详细解析

《Oracle数据库常见字段类型大全以及超详细解析》在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,:本文主要介绍Oracle数据库常见字段类型大全以及超详细解析,文中通过... 目录前言一、字符类型(Character)1、CHAR:定长字符数据类型2、VARCHAR2:变长字符数

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

使用Sentinel自定义返回和实现区分来源方式

《使用Sentinel自定义返回和实现区分来源方式》:本文主要介绍使用Sentinel自定义返回和实现区分来源方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Sentinel自定义返回和实现区分来源1. 自定义错误返回2. 实现区分来源总结Sentinel自定

如何自定义Nginx JSON日志格式配置

《如何自定义NginxJSON日志格式配置》Nginx作为最流行的Web服务器之一,其灵活的日志配置能力允许我们根据需求定制日志格式,本文将详细介绍如何配置Nginx以JSON格式记录访问日志,这种... 目录前言为什么选择jsON格式日志?配置步骤详解1. 安装Nginx服务2. 自定义JSON日志格式各

Android自定义Scrollbar的两种实现方式

《Android自定义Scrollbar的两种实现方式》本文介绍两种实现自定义滚动条的方法,分别通过ItemDecoration方案和独立View方案实现滚动条定制化,文章通过代码示例讲解的非常详细,... 目录方案一:ItemDecoration实现(推荐用于RecyclerView)实现原理完整代码实现

基于Spring实现自定义错误信息返回详解

《基于Spring实现自定义错误信息返回详解》这篇文章主要为大家详细介绍了如何基于Spring实现自定义错误信息返回效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录背景目标实现产出背景Spring 提供了 @RestConChina编程trollerAdvice 用来实现 HTT

Python如何查看数据的类型

《Python如何查看数据的类型》:本文主要介绍Python如何查看数据的类型方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python查看数据的类型1. 使用 type()2. 使用 isinstance()3. 检查对象的 __class__ 属性4.

SpringSecurity 认证、注销、权限控制功能(注销、记住密码、自定义登入页)

《SpringSecurity认证、注销、权限控制功能(注销、记住密码、自定义登入页)》SpringSecurity是一个强大的Java框架,用于保护应用程序的安全性,它提供了一套全面的安全解决方案... 目录简介认识Spring Security“认证”(Authentication)“授权” (Auth