FPGA实战演练逻辑篇38:可综合的语法子集3
可综合的语法子集3
本文节选自特权同学的图书《FPGA设计实战演练(逻辑篇)》
配套例程下载链接:http://pan.baidu.com/s/1pJ5bCtt
(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命名>;
// 可选申明部分,如本地变量申明
begin
// 具体逻辑
end
endtask
(5) 连续赋值:assign,问号表达式(?:)。(特权同学,版权所有)
Assign用于直接互联不同的信号或直接给wire变量赋值。其基本用法如下:
assign <wire变量名>= <变量或常量>;
“?:”表达式就是简单的if…else语句,但更多的用在组合逻辑中。其基本用法如下:
(判断条件) ? (判断条件为真时的逻辑处理) : (判断条件为假时的逻辑处理)
(6) always模块:(敏感表可以为电平、沿信号posedge/negedge;通常和@连用)。(特权同学,版权所有)
always有多种用法,在组合逻辑中,其用法如下:
always@(*)
begin
// 具体逻辑
end
always后若有沿信号(上升沿posedge,下降沿negedge)申明,则多为时序逻辑,其基本用法如下:
// 单个沿触发的时序逻辑
always@(<沿变化>)
begin
//具体逻辑
End
// 多个沿触发的时序逻辑
always@(<沿变化1> or <沿变化2>)
begin
//具体逻辑
End
(7) 运算操作符:各种逻辑操作符、移位操作符、算术操作符大多是可综合的。(特权同学,版权所有)
Verilog中绝大多数运算操作符都是可综合的,其列表如下:
+ // 加
- // 减
! // 逻辑非
~ // 取反
& // 与
~& // 与非
| // 或
~| // 或非
^ // 异或
^~ // 同或
~^ // 同或
* // 乘,是否可综合看综合工具
/ // 除,是否可综合看综合工具
- 基于FPGA的片上系统的无线保密通信终端(02-16)
- 基于Virtex-5 FPGA设计Gbps无线通信基站(05-12)
- 基于FPGA的DVI/HDMI接口实现(05-13)
- 基于ARM的嵌入式系统中从串配置FPGA的实现(06-09)
- 采用EEPROM对大容量FPGA芯片数据实现串行加载(03-18)
- 赛灵思:可编程逻辑不仅已是大势所趋,而且势不可挡(07-24)