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

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

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 3944|回复: 3

信号变量是在过程块中被赋值的必须把它声明为寄存器类型变量

[复制链接]
发表于 2008-6-6 18:09:22 | 显示全部楼层 |阅读模式

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

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

x
在看veriloghdl语法遇到如下想法:

如果信号变量是在过程块 (initial块 或 always块)中被赋值的,必须把它声明为寄存器类型变量。

为什么会有这个要求呢?
如果always中实现的是个组合逻辑,那他的输出也要用寄存器寄存吗?在仿真的时候感觉输出波形是组合逻辑运算后直接输出的,没有寄存器延时。

       那这个寄存器类型在综合的时候是什么样子呢?特性像线网,是寄存器类型,但是没有clk驱动。感觉困惑!估计是我想偏了,望各位DX指正!
发表于 2008-6-7 10:49:57 | 显示全部楼层
每当声明一个always块的时候,都相当于声明了一个寄存器。
发表于 2008-6-7 10:50:07 | 显示全部楼层
过程块中的信号变量,确实比需要声明为reg型。
但是综合的时候不一定综合成reg型。
对于沿触发的就是reg型,对于电平触发的可以是wire型,但是此时还要注意latch生成。
always可以描述时序逻辑也可以描述组合逻辑。
 楼主| 发表于 2008-6-8 15:55:03 | 显示全部楼层
谢谢,我明白了。不一定综合生成寄存器。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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

×

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

GMT+8, 2024-5-6 07:17 , Processed in 0.027243 second(s), 9 queries , Gzip On, Redis On.

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