在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 1939|回复: 0

[原创] 勇敢的芯伴你玩转Altera FPGA连载33:可综合的语法子集4

[复制链接]
发表于 2017-12-19 21:33:15 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
勇敢的芯伴你玩转Altera FPGA连载33:可综合的语法子集4

特权同学,版权所有

配套例程和更多资料下载链接:

http://pan.baidu.com/s/1i5LMUUD

1.jpg


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

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

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

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

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

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

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

always@(*)

begin

         // 具体逻辑

end

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

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

always@(<沿变化>)

begin

         //具体逻辑

End


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

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

begin

         //具体逻辑

End

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

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

+            //

-            //

!            // 逻辑非

~            // 取反

&            //

~&           // 与非

|            //

~|           // 或非

^            // 异或

^~           // 同或

~^           // 同或

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

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

%            // 取模

<<           // 逻辑左移

>>           // 逻辑右移

<            // 小于

<=           // 小等于

>            // 大于

>=           // 大等于

==           // 逻辑相等

!=           // 逻辑不等于

&&           // 逻辑与

||           // 逻辑或

赋值符号:= <=

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

可综合的语法是verilog可用语法里很小的一个子集,硬件设计的精髓就是力求用最简单的语句描述最复杂的硬件,这也正是硬件描述语言的本质。对于做RTL级设计来说,掌握好上面这些基本语法是很重要。







您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /2 下一条

小黑屋| 手机版| 关于我们| 联系我们| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2025-2-23 04:04 , Processed in 0.014006 second(s), 8 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表