FPGA设计中可综合的语法子集

来源:本站
导读:目前正在解读《FPGA设计中可综合的语法子集》的相关信息,《FPGA设计中可综合的语法子集》是由用户自行发布的知识型内容!下面请观看由(电工技术网 - www.9ddd.net)用户发布《FPGA设计中可综合的语法子集》的详细说明。
简介:可综合的语法是verilog可用语法里很小的一个子集,硬件设计的精髓就是力求用最简单的语句描述最复杂的硬件,这也正是硬件描述语言的本质。对于做RTL级设计来说,掌握好这些基本语法是很重要。

(1) 多语句定义:begin…end。

通俗的说,它就是C语言里的 “{ }”,用于单个语法的多个语句定义。其使用示例如下:

//含有命名的begin语句

begin : <块名>

// 可选申明部分

// 具体逻辑

end

// 基本的begin语句

begin

// 可选申明部分

// 具体逻辑

end

(2)比较判断:if…else, case…default…endcase。

判断语法if…else及case语句是最常用的功能语法,其基本的使用示例如下:

// if判断语句

if(<判断条件>)

begin

// 具体逻辑

end

// if…else判断语句

if(<判断条件>)

begin

// 具体逻辑1

end

else

begin

// 具体逻辑2

end

// if…else if…else判断语句

if(<判断条件1>)

begin

// 具体逻辑1

end

else if(<判断条件2>)

begin

// 具体逻辑2

end

else

begin

// 具体逻辑3

end

// case语句

case(<判断变量>)

<取值1>: <具体逻辑1>

<取值2>: <具体逻辑2>

<取值3>: <具体逻辑3>

default: <具体逻辑4>

endcase

(3)循环语句:for。

用的也比较少,但也会在一些特定的设计中使用它。其示例如下:

// for语句

for(<变量名> = <初值>; <判断表达式>; <变量名> = <新值>)

begin

// 具体逻辑

end

(4)任务定义:task…endtask。

Task更像是C语言中的子函数,task中可以有input、output和inout端口作为出入口参数,它可以用于实现一个时序控制。task没有返回值,因此不可以用在表达式中。其基本用法如下:

task<task命名>;< task命名<="" p="">

// 可选申明部分,如本地变量申明

begin

// 具体逻辑

end

endtask

(5)连续赋值:assign,问号表达式(?:)

Assign用于直接互联不同的信号或直接给wire变量赋值。其基本用法如下:

assign<wire< span="">变量名> = <变量或常量>;

“?:”表达式就是简单的if…else语句,但更多的用在组合逻辑中。其基本用法如下:

(判断条件) ? (判断条件为真时的逻辑处理) : (判断条件为假时的逻辑处理)

(6)always模块:(敏感表可以为电平、沿信号posedge/negedge;通常和@连用)

always有多种用法,在组合逻辑中,其用法如下:

always@(*)

begin

//具体逻辑

end

always后若有沿信号(上升沿posedge,下降沿negedge)申明,则多为时序逻辑,其基本用法如下:

//单个沿触发的时序逻辑

always@(<沿变化>)

begin

//具体逻辑

End

//多个沿触发的时序逻辑

always@(<沿变化1> or <沿变化2>)

begin

//具体逻辑

End

(7)运算操作符:各种逻辑操作符、移位操作符、算术操作符大多是可综合的。

Verilog中绝大多数运算操作符都是可综合的,其列表如下:

+// 加

- // 减

! // 逻辑非

~ // 取反

& // 与

~& // 与非

| // 或

~| // 或非

^ // 异或

^~ // 同或

~^ // 同或

* // 乘,是否可综合看综合工具

/ // 除,是否可综合看综合工具

% // 取模

<< // 逻辑左移

>> // 逻辑右移

< // 小于

<= // 小等于

> // 大于

>= // 大等于

== // 逻辑相等

!= // 逻辑不等于

&& // 逻辑与

|| // 逻辑或

(8)赋值符号:=和<=

阻塞和非阻塞赋值,在具体设计中是很有讲究的,我们会在具体实例中掌握他们的不同用法。(特权同学,版权所有)

提醒:《FPGA设计中可综合的语法子集》最后刷新时间 2024-03-14 01:08:52,本站为公益型个人网站,仅供个人学习和记录信息,不进行任何商业性质的盈利。如果内容、图片资源失效或内容涉及侵权,请反馈至,我们会及时处理。本站只保证内容的可读性,无法保证真实性,《FPGA设计中可综合的语法子集》该内容的真实性请自行鉴别。