一、Training1.数据类型a. 两态变量:bit,  byte: 8bit,  shortint: 16bit,  int: 32bit,  longint: 64bit,  shortreal相当于c的float: 占32bit的内存空间,  real相当于c的double: 占64 bit内存空间。其中只有bit是无符号。b.
弄清楚阻塞赋值和非阻塞赋值的区别非常重要,否则我们就没有办法理解verilog里面的for循环的执行结果。 简单来说,阻塞赋值是给变量的现态赋值,非阻塞赋值是给变量的次态赋值。 所谓的现态,就是执行代码时变量的状态,也就是当前状态。次态,就是当前整个always代码块执行完了之后,变量是什么值,也就是下一个状态。注意:在同一分支下,对同一变量不能同时使用非阻塞赋值和阻塞赋值,否则编译不通过。 例如
关于signed、有符号数、算数左移、算数右移、$signed()、$unsigned()的理解。1、signed可以和reg和wire联合使用,用于定义有符号数。在代码中使用负的十进制数赋值给有符号数,在电路中是按该数值的补码形式存储的。如下:wire signed a; assign a = -8'd1;使用display显示a的二进制=11111111,十进制= -1,如下:$display
文章目录一、定宽数组1.1 声明1.2 for 和 foreach 遍历数组1.3 数组的复制与比较1.4 数组内建的方法二、动态数组2.1 创建动态数组2.2 给动态数组赋值三、队列3.1 声明3.2 队列内建的方法四、 关联数组4.1 声明4.2 关联数组内建的方法五、 选择存储类型5.1 使用灵活性5.2 存取速度5.3 排序方式5.4 占用系统的存储空间 ?合并数组与非合并数组可以看:合
转载 2024-04-22 13:58:51
475阅读
   位移位运算符         位移位运算符是将数据看成二进制数,对其进行向左或向右移动若干位的运算。位移位运算符分为左移和右移两种,均为双目运算符。第一运算对象是移位对象,第二个运算对象是所移的二进制位数。   移位时,移出的位数全部丢弃,移出的空位补入的数与左移还是右移花接木有关。如果是左移,则规定补入的数全部是0;如果是右
运算符分类及其应用算术运算符:关系运算符:逻辑运算符:条件运算符:位运算符:移位运算符:连接运算符: Verilog HDL语言的运算符范围很广,其运算符按其功能可分为以下几类:算术运算符(+,-,*,/,%)赋值运算符(=,<=)关系运算符(>,<,>=,<=)逻辑运算符(&&,||,!)条件运算符(?)位运算符(,|,^,&,^)移位运算符
目录一、定宽数组1.1定宽数组的声明和初始化1.2常量数组1.3数组的基本操作——for、foreach1.4数组的比较和复制1.5合并数组二、动态数组SV对数组分为两类:定宽数组和动态数组。定宽数组,一般长度始终固定,且不存在重用性的问题时,可考虑使用。动态数组,用得非常多,所有存在变长的遍历,都可用使用。比如验证平台的组件配置,可用自仿真中根据验证场景的不同动态定义,非常方便。还有网络报文数据
(3)ArraysSV的数组类型: 合并数组,非合并数组,动态数组,联合数组,队列根据数组大小是否固定,可分为固定数组(静态数组)和动态数组1. 合并数组 packed arrays存储方式是连续的,中间没有闲置空间例如,32bit的寄存器,可以看成是4个8bit的数据,或者也可以看成是1个32bit的数据。表示方法: 数组大小和位,必须在变量名前指定,数组大小必须是【msb:lsb】(从大到小)
6.移位运算符 在Verilog HDL中有两种移位运算符。 :(左移位运算符) >>:(右移位运算符) 其使用方法如下: a >> n; a n; a代表要进行移位的操作数,n代表要移几位。这两种移位运算都用0来填补移出的空位。下面举例说明: module shift; reg [3:0] start, result; initial begin start = 1; /
目录 1. 概要2. 动态数组的声明 3. 内存分配和初始化4. 容量扩张5. 动态数组的复制6. 动态数组的删除7. 代码例1. 概要        动态数组(Dynamic array),顾名思义,是一种其大小可以在运行中动态改变的非合并数组(unpacked ar
目录1 定宽数组1.1 一维定宽数组1.2 多维定宽数组1.3 packed合并数组1.4 unpacked非合并数组1.5 混合数组1.6 foreach循环结构2 动态数组3. 关联数组  4.队列queue 5.枚举enum6.字符串string7.结构体struct1 定宽数组1.1 一维定宽数组int b[2:0] ;
一、内部实现数组 数组是一个长度固定的数据类型,用于存储一段具有相同类型的元素的连续块。数组存储的类型可以是内置类型,如整型或者字符串,也可以是某种结构类型。切片 切片是围绕动态数组的概念构建的,可以按需自动增长和缩小 切片是一个很小的对象,对底层数组进行了抽象,并提供了相关的操作方法。切片有3个字段分别是指向底层数组的指针,切片访问的元素个数(即长度)和切片允许增长到的元素个数(即容量) 二、区
Verilog基础(一)——数据类型、运算符1. 数据类型1.1 常量1.2 参数1.3 传参示例1.4 变量1.4.1 Wire型1.4.2 Reg型1.4.3 Memory型2. 运算符2.1 赋值运算符2.1.1 阻塞赋值运算符2.1.2 非阻塞赋值运算符2.2 位拼接运算符2.3 运算符的优先级 本文主要介绍verilog基础模块,主要讲述verilog语言中的数据类型、运算符。1. 数
前言基于《IEEE Standard for SystemVerilog — Unified Hardware Design, Specification, and Verification Language》18章的学习和自己的理解。有不对的地方希望大家补充。 编译工具 Cadence的Xcelium。这是第二篇,完成randomize的学习正文随机控制rand_mode();rand_mode
转载 2024-09-23 14:46:51
168阅读
数据类型Verilog中常用的基本数据类型:wire 、reg、 integer、 parameter常量在程序运行过程中,不被改变的量称为常量:数字 和 参数数字: 整数在程序中是最常用的,整数常量常有以下4种进制表示: 1、二进制(b或B) 2、十进制(d或D) 3、十六进制(h 或 H) 4、八进制(o或 O)数字的表达方式有以下3种: 1、<位宽><进制><数
转载 2024-10-18 11:34:24
178阅读
一、非组合型数组unpacked array1、在verilog中,数组经常会被用来存储数据。reg [15:0] RAM [0:4095];//RAM是数组名,[0:4095]是元素,表示有4096个元素,每个元素有16位。reg是元素的类型2、在SV中,就将上面这种方式声明的数组称之为非组合型数组,它表示数组中的成员之间存储的数据是相互独立的。wire [7:0] table [3:0]; /
引言经过了组合逻辑和时序逻辑的复习,终于到了Verilog部分。这里主要介绍Verilog一些基础内容,包括结构化模型、TestBench编写和仿真、真值表模型。  这部分内容不多,也都十分基础,大家可以看个乐呵,看个意思,但是有一些细节还是需要注意的。Verilog结构化模型 结构化和语言规则  下图以示例的形式分别说明了1995版和2001/2005版Verilog语法下的结构化模型,两者的不
目录语法格式initial块的作用initial块的开始和结束initial块的数量 语法格式initial块可以理解为一个初始化块,在initial的起始位置的语句在0时刻即开始执行,之后如果遇到延时,则延时之后执行接下来的语句。其语法如下:initial [single statement] initial begin [multiple statements] end如果initia
Testbench编写指南是博主新开的一个系列,主要介绍在编写testbench时使用到的技巧,让编写者的水平不再仅仅停留在时钟信号、复位信号等简单信号的设置上,更好的完成对设计的仿真工作。第2篇的题材是文件的读写控制,仿真时经常需要从文件中读取测试激励,还要将仿真结果存取在文件中供其它程序读取调用。读取txt文件数据示例代码如下:integer i; //数组坐标 reg [9:0] sti
Verilog快速入门 本篇文章综合北航计算机组成原理课题组&大黑书&网上一些资料&自己杂七杂八的一些想法整理而成,笔者主要写在这儿做复习用。。。。若有侵权请联系删除。 文章目录 Verilog快速入门 数据类型 常用语句 模块引用 宏定义 数据类型 wire型:属于nets
转载 6月前
37阅读
  • 1
  • 2
  • 3
  • 4
  • 5