verilog学习总结

简介: verilog学习总结

在initial或always外的assign赋值语句称为连续赋值语句一般在描述纯组合电路时使用

在Verilog HDL中,可以使用三种方法来生成组合逻辑电路:使用连续赋值语句,使用不带时钟触发的always语句.和使用函数。


FPGA与CPLD相比。最大的一个特点就是它的寄存器相当丰富,因此.更加适合设计时序逻辑电路

用FPGA描述时序逻辑电路只有一种方法,就是用带时钟触发沿的always语句,

同步复位和异步复位的区别就在于:前者的复位信号不能出现在always语句的敏感信号表中。无论是同步复位还是异步复位,always语句的结构都是if(Reset)⋯else⋯,否则,综合工具将不能正确的综合。


推荐使用异步复位,同步释放的方式,而且复位信号低电平有效。

逻辑资源优化

FPGA内部的逻辑资源是相当宝贵的.用Verilog HDL进行

FPGA设计时.良好的描述风格可以有效的节省程序所耗费的逻辑资源。以下是几个有效的节省硬件资源的方法。


1)资源共享。资源共享通常指的是互斥条件下的运算语句共享同一个算术逻辑单元。实现资源共享通常有两种方法。其一是在综合工具的选项中打开资源共享选项.则综合工具在遇到上面的代码时会自动进行资源共享。其二是用代码显式的描述。

2)提取公共子表达式。很多综合工具无法自动发现代码中公共的子表达式,因此,在用VerilogHDL描述时,将它们显式的提取出来可以有效的节省硬件资源。

3)注意语句出现的位置。在描述组合逻辑电路是,我们经常使用for循环语句,如果在for循环语句中存在这样的语句,它们的值在多次的循环过程中并不发生变化.则这样的语句须

移到for循环外面,否则,会占用大量的硬件资源。


always块中,被赋值的信号都必须定义为reg型,这是由时序逻辑电路的特点所决定
复制代码

的。


对于reg型数据,如果未对它进行赋值,仿真工具会认为它是不定态。

书写规范

用最右边的字符下划线表示低电平有效,高电平有效的信号不得以下划线表示,短暂的引擎信号建议采用高有效。

如: Rst_ ,Trdy_, Irdy_, Idsel


相关文章
|
8月前
|
存储 编译器 索引
Verilog基础【一】
Verilog基础【一】
258 0
|
存储 开发工具 异构计算
第三章 硬件描述语言verilog(二) 功能描述-组合逻辑(下)
第三章 硬件描述语言verilog(二) 功能描述-组合逻辑
983 0
第三章 硬件描述语言verilog(二) 功能描述-组合逻辑(下)
|
6月前
|
算法 异构计算
FPGA入门(2):Verilog HDL基础语法
FPGA入门(2):Verilog HDL基础语法
42 0
|
8月前
|
存储 人工智能 安全
Verilog基础【二】
Verilog基础【二】
256 1
|
8月前
|
C++
Verilog 函数和任务
Verilog 函数和任务
|
算法
|
存储 程序员 开发工具
第三章 硬件描述语言verilog(一)
第三章 硬件描述语言verilog(一)
466 0
第三章 硬件描述语言verilog(一)
|
开发工具 芯片 异构计算
Verilog 设计方法
Verilog 的设计多采用自上而下的设计方法(top-down)。即先定义顶层模块功能,进而分析要构成顶层模块的必要子模块;然后进一步对各个模块进行分解、设计,直到到达无法进一步分解的底层功能块。这样,可以把一个较大的系统,细化成多个小系统,从时间、工作量上分配给更多的人员去设计,从而提高了设计速度,缩短了开发周期。
178 1
|
算法 异构计算
Verilog HDL门级建模
⭐本专栏针对FPGA进行入门学习,从数电中常见的逻辑代数讲起,结合Verilog HDL语言学习与仿真,主要对组合逻辑电路与时序逻辑电路进行分析与设计,对状态机FSM进行剖析与建模。
150 0
Verilog HDL门级建模
|
人工智能 BI
Verilog 的连续赋值
连续赋值语句是 Verilog 数据流建模的基本语句,用于对 wire 型变量进行赋值。:
184 0