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

 找回密码
 注册

手机号码,快捷登录

手机号码,快捷登录

搜帖子
查看: 2269|回复: 3

[求助] 对组合逻辑 assign 和 always 有什么不同吗?

[复制链接]
发表于 2023-3-20 09:21:45 | 显示全部楼层 |阅读模式

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

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

×
如题。想要实现 c = a + b的功能,不用时序电路,只用组合逻辑。我看别人用了方法一,我用了方法二,想问下各位大佬,有什么区别吗?


方法一


   

        

                
  1. module addr(
  2. input [3:0] a,
  3. input [3:0] b,
  4. output reg [4:0] c;
  5. )

  6. always @(*)
  7. begin
  8.         c = a + b;
  9. end
  10. endmodule
            

   

    复制代码
方法二


   

        

                
  1. module addr(
  2. input [3:0] a,
  3. input [3:0] b,
  4. output [4:0] c;
  5. )
  6. assign c = a + b;

  7. endmodule
            

   

    复制代码



发表于 2023-3-20 11:27:43 | 显示全部楼层
尝试综合了一下,无论synplify还是Vivado电路都是一样的。
个人理解为:加法逻辑是一样的,唯一区别是assign输出是wire型,always输出是reg型。但是虽然声明为reg型,但是输出并不会综合成FF,网上说只有仿真的时候输出才会视为FF
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-3-20 21:32:13 | 显示全部楼层


   
zx7504081 发表于 2023-3-20 11:27
尝试综合了一下,无论synplify还是Vivado电路都是一样的。
个人理解为:加法逻辑是一样的,唯一区别是assig ...


和其他人讨论也是类似的结论。两种写法应该是习惯问题。还有用reg可以避免一大堆 ? : 而使用  if-else可能会写的清楚一点。
回复 支持 反对

使用道具 举报

发表于 2023-3-21 15:12:08 | 显示全部楼层
a啊。。
回复 支持 反对

使用道具 举报

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

本版积分规则

关闭

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

X

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

GMT+8, 2025-7-9 13:46 , Processed in 0.083723 second(s), 8 queries , Gzip On, MemCached On.

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