FPGA实战演练逻辑篇38:可综合的语法子集3

2015年06月17日 11:37    发布者:rousong1989
可综合的语法子集3本文节选自特权同学的图书《FPGA设计实战演练(逻辑篇)》配套例程下载链接:http://pan.baidu.com/s/1pJ5bCtt (1)    多语句定义:beginend。(特权同学,版权所有)通俗的说,它就是C语言里的“{  }”,用于单个语法的多个语句定义。其使用示例如下:// 含有命名的begin语句begin : <块名>    // 可选申明部分    // 具体逻辑end // 基本的begin语句begin     // 可选申明部分    // 具体逻辑end(2)    比较判断:ifelse, casedefaultendcase。(特权同学,版权所有)判断语法if…else及case语句是最常用的功能语法,其基本的使用示例如下:// if判断语句if(<判断条件>) begin     // 具体逻辑end // if…else判断语句if(<判断条件>)begin     // 具体逻辑1endelse begin    // 具体逻辑2end // if…else if…else判断语句if(<判断条件1>)begin     // 具体逻辑1endelse if(<判断条件2>)begin    // 具体逻辑2endelse begin    // 具体逻辑3end // case语句case(<判断变量>)<取值1>: <具体逻辑1><取值2>: <具体逻辑2><取值3>: <具体逻辑3>default: <具体逻辑4> endcase(3)    循环语句:for。(特权同学,版权所有)用的也比较少,但也会在一些特定的设计中使用它。其示例如下:// for语句for(<变量名> = <初值>; <判断表达式>; <变量名> = <新值>)begin    // 具体逻辑end(4)    任务定义:taskendtask。(特权同学,版权所有)Task更像是C语言中的子函数,task中可以有input、output和inout端口作为出入口参数,它可以用于实现一个时序控制。task没有返回值,因此不可以用在表达式中。其基本用法如下:task ;    // 可选申明部分,如本地变量申明    begin        // 具体逻辑    endendtask(5)    连续赋值:assign,问号表达式(?:)。(特权同学,版权所有)Assign用于直接互联不同的信号或直接给wire变量赋值。其基本用法如下:assign = <变量或常量>;“?:”表达式就是简单的if…else语句,但更多的用在组合逻辑中。其基本用法如下:(判断条件) ? (判断条件为真时的逻辑处理) : (判断条件为假时的逻辑处理)(6)    always模块:(敏感表可以为电平、沿信号posedge/negedge;通常和@连用)。(特权同学,版权所有)always有多种用法,在组合逻辑中,其用法如下:always@(*)begin         // 具体逻辑endalways后若有沿信号(上升沿posedge,下降沿negedge)申明,则多为时序逻辑,其基本用法如下:// 单个沿触发的时序逻辑always@(<沿变化>)begin         //具体逻辑End // 多个沿触发的时序逻辑always@(<沿变化1> or <沿变化2>)begin         //具体逻辑End(7)    运算操作符:各种逻辑操作符、移位操作符、算术操作符大多是可综合的。(特权同学,版权所有)Verilog中绝大多数运算操作符都是可综合的,其列表如下:+            // 加-            // 减!            // 逻辑非~            // 取反&            // 与~&           // 与非|            // 或~|           // 或非^            // 异或^~           // 同或~^           // 同或*            // 乘,是否可综合看综合工具/            // 除,是否可综合看综合工具%            // 取模<<           // 逻辑左移>>           // 逻辑右移<            // 小于<=           // 小等于>            // 大于>=           // 大等于==           // 逻辑相等!=           // 逻辑不等于&&           // 逻辑与||           // 逻辑或(8)    赋值符号:= <=。(特权同学,版权所有)阻塞和非阻塞赋值,在具体设计中是很有讲究的,我们会在具体实例中掌握他们的不同用法。(特权同学,版权所有)可综合的语法是verilog可用语法里很小的一个子集,硬件设计的精髓就是力求用最简单的语句描述最复杂的硬件,这也正是硬件描述语言的本质。对于做RTL级设计来说,掌握好上面这些基本语法是很重要。(特权同学,版权所有)