Verilog HDL基本语法规则[通俗易懂]

Verilog HDL基本语法规则[通俗易懂]词法规定 为对数字电路进行描述,Verilog语言规定了一套完整的语法结构。 1.间隔符 Verilog 的间隔符主要起分隔文本的作用,可以使文本错落有致,便于阅读与修改。间隔符包括空格符(\b)、T

⭐本专栏针对FPGA进行入门学习,从数电中常见的逻辑代数讲起,结合Verilog HDL语言学习与仿真,主要对组合逻辑电路与时序逻辑电路进行分析与设计,对状态机FSM进行剖析与建模。

🔥文章和代码已归档至【Github仓库:hardware-tutorial】,需要的朋友们自取。或者关注公众号【AIShareLab】,回复 FPGA 也可获取。

词法规定

为对数字电路进行描述,Verilog语言规定了一套完整的语法结构。

1.间隔符

Verilog 的间隔符主要起分隔文本的作用,可以使文本错落有致,便于阅读与修改。间隔符包括空格符(\b)、TAB 键(\t)、换行符(\n)及换页符。

2.注释符

注释只是为了改善程序可读性,编译时不起作用。

  • 多行注释符(用于写多行注释): /* — */;
  • 单行注释符 :以//开始到行尾结束为注释文字。

3.标识符和关键词

标识符: 给对象(如模块名、电路的输入与输出端口、变量等)取名所用的字符串。以英文字母或下划线开始 如,clk、counter8、_net、bus_A 。

关键词: 用Verilog语言本身规定的特殊字符串定义语言的结构。例如,module、endmodule、input、output、wire、reg、and等都是关键词。关键词都是小写,关键词不能作为标识符使用 。

逻辑值集合

为了表示数字逻辑电路的逻辑状态,Verilog语言规定了4种基本的逻辑值。

0 逻辑0、逻辑假
1 逻辑1、逻辑真
x或X 不确定的值(未知状态)
z或Z 高阻态

常量及其表示

三种类型的常量

  • 整数型常量
  • 实数型常量
  • 字符串型常量

整数型常量

十进制数形式的表示方法:表示有符号常量。例如:30、-2

带基数形式的表示方法:

格式为:<+/-><位宽>’<基数符号><数值>

例如:3’b101、5’o37、8’he3,8’b1001_0011

实数型常量

十进制记数法 如: 0.1、2.0、5.67

科学记数法 如: 23_5.1e2、5E-4、23510.0、0.0005

字符串常量

字符串是用双撇号括起来的字符序列,它必须包含在同一行中,不能分成多行书写。例如:

    ''this is a string''
    ''hello world!''

符号常量

Verilog 允许用参数定义语句定义一个标识符来代表一个常量,称为符号常量。定义的格式为:

parameter 参数名1=常量表达式1 ,参数名2=常量表达式2 , … 

parameter BIT=1, BYTE=8, PI=3.14;

parameter和localparam区别

Verilog中用parameter或者localparam来定义常量,即用来定义一个标志符代表一个常量,从而提高程序的可读性。其说明格式如下:

parameter/localparam    参数名1=表达式,参数名2=表达式, …;

区别:

  • parameter可用作在顶层模块中例化底层模块时传递参数的接口;
  • localparam的作用域仅仅限于当前module,不能作为参数传递的接口。

3.1.4 数据类型(Data Types)

变量的数据类型

  • 线网型
  • 寄存器型

线网类型:是指输出始终根据输入的变化而更新其值的变量,它一般指的是硬件电路中的各种物理连接.

例:网络型变量L的值由与门的驱动信号A和B所决定,即L=A&B。A、B的值发生变化,线网L的值会立即跟着变化。

Verilog HDL基本语法规则[通俗易懂]

常用的线网类型由关键词wire定义,格式如下:

wire [n-1:0] 变量名1,变量名2,…,变量名n;

线网类型变量及其说明

线网类型 功能说明
wire, tri 用于表示单元(元件)之间的连线,wire为一般连线; tri用于描述由多个信号源驱动的线网,并没有其他特殊 意义,两者的功能完全相同。
wor, trior 具有线或特性的线网,用于一个线网被多个信号驱动的 情况
wand, triand 具有线与特性的线网,用于一个线网被多个信号驱动的 情况
trireg 具有电荷保持特性的线网类型,用于开关级建模
tri1 上拉电阻,用于开关级建模
tri0 下拉电阻,用于开关级建模
supply1 用于对电源建模,高电平1
supply0 用于对地建模,低电平0

关于多重驱动

在写可综合的Verilog代码时,建议不要对同一个变量进行多次赋值(简称多重驱动),以避免出现多个信号同时驱动一个输出变量的情况。

例如,A、B、C三个内部信号同时接到(驱动)一个输出端L。或者说,输出L同时被三个内部信号所驱动。此时L的逻辑值可无法确定。

Verilog HDL基本语法规则[通俗易懂]

寄存器型变量对应的是具有状态保持作用的电路等元件,如触发器、寄存器。寄存器型变量只能在initial或always内部被赋值。

寄存器变量类型

寄存器变量类型及其说明

寄存器类型 功能说明
reg 常用的寄存器型变量
integer 32位带符号的整数型变量
real/realtime 64位带符号的实数型变量
time 64位无符号的时间变量
reg    clock;            //例:一个1位寄存器变量的声明
reg [3:0]  counter;       //例:一个4位寄存器变量的声明

memory型变量的用法

Verilog通过对reg型变量建立数组来对存储器建模,可以描述RAM型存储器、ROM存储器和reg文件。数组中每个单元通过一个数组索引地址。

其格式定义如下:

reg [n-1:0] 存储器名 [m:0]

注意1:

reg [N-1:0] ram;  //一个N位的寄存器
reg  ram [N-1:0]; //一个由N个1位寄存器组成的存储器组

注意2:

不可以对一个完整的寄存器组赋值,只能指定该寄存器组中的地址赋值。


欢迎关注公众号【AIShareLab】,一起交流更多相关知识,前沿算法,Paper解读,项目源码,面经总结。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/13490.html

(0)

相关推荐

  • 从零之053 网页代码中提取文字(网页代码基础)「建议收藏」

    从零之053 网页代码中提取文字(网页代码基础)「建议收藏」文本处理其实是一个很大的题目,无法用文本处理这个名字来概括,从这里这一章开始,我们直接用子项目名做名称。关键词:html代码下面我们开始一个新的

    2022-12-14
    156
  • webpack打包之后的文件过大的解决方法[亲测有效]

    webpack打包之后的文件过大的解决方法[亲测有效]以前一直使用create-react-app这个脚手架进行react开发,后面因为一些自定义的配置,转而使用webpack搭建一套自己的脚手架。但是在使用webpack打包之后发现,纳尼?怎么文件这么大??? 于是研究了一下如何处理webpack打包之后文件太大的情况,简单记录…

    2023-07-25
    73
  • “票房”英语怎么说?「建议收藏」

    “票房”英语怎么说?「建议收藏」2021年春节档以超78亿元的票房成绩收官,创下影史同期最高纪录。贾玲也凭借电影《你好,李焕英》,成为了中国影史上票房最高的女导演。A scen

    2023-07-05
    88
  • vue3 从入门到实战_笔记整理法

    vue3 从入门到实战_笔记整理法由于我先学了Vue3,并开发了一个开源的小项目,领导让我整理一下给公司其他没有入门的同事讲一下,混个脸熟。本文适合Vue初学者,或者Vue2迁移者,一看就学会,直接上手开发。

    2023-07-30
    77
  • mysql事务的原理_mysql大事务

    mysql事务的原理_mysql大事务事务是逻辑上的一组操作,要么都执行,要么都不执行。事务最经典也经常被拿出来说例子就是转账了。假如小明要给小红转账1000元,这个转账会涉及到两个

    2023-04-03
    110
  • 基于 WebRTC 的 RTSP 视频实时预览「终于解决」

    基于 WebRTC 的 RTSP 视频实时预览「终于解决」目前已存在的基于 FFmpeg 的方案延迟都太高,所以项目最终选择基于此方案。你可以在下载的发布包中的html文件夹中找到 index.html

    2023-06-27
    88
  • Python模块——NumPy:高效处理数组和矩阵运算

    Python模块——NumPy:高效处理数组和矩阵运算NumPy是Python中最重要的第三方库之一,特别是在数据科学和机器学习领域。它是一个开源的Python扩展库,支持高性能的科学计算和数据分析。一般来说,使用Python进行数据分析一定会用到NumPy。其中的ndarray类型,是在Python中进行大规模数值运算的必备类型,它可以提高Python数值运算的效率。

    2024-04-05
    21
  • hbase 内存_hbase性能优化包含哪些选项

    hbase 内存_hbase性能优化包含哪些选项概况: 生产环境HBase集群内存经常处于高位(90%),而且GC之后也是内存依然处于高位,经分析内存全部由集群的regionserver进程所持有,,经常重启之后,大概3-4天就会保持在高位。由上…

    2023-04-04
    108

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注