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

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

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

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

[求助] 边沿触发模块中是否可以到阻塞赋值

[复制链接]
发表于 2017-12-29 12:52:40 | 显示全部楼层 |阅读模式

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

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

x
我在李庆华老师所写的《通信IC设计》299页中,见到这样一段代码:



  1. always @(posedge clk)begin
  2. tempa=ina;tempb=inb;tempc=inc;//输入数据缓存
  3. end


复制代码
但是把这段代码放到nilint中检查时出现Error:BLOCKING assignment should not be used in an edge triggered block。
请问各位大佬,在ASIC设计中是否可以出现书中所写的这种代码风格?如果可以的话,综合出来的电路会是什么样子的呢?
发表于 2017-12-29 13:45:43 | 显示全部楼层
回复 1# 550503091


    你这个倒是可以综合出来三个reg的,但是如果下面这种,就只有tempc这一个reg了;所以还是不要用阻塞赋值;




  1. always @(posedge clk)begin

  2. tempa=ina;tempb=tempa;tempc=tempb;//输入数据缓存

  3. end


复制代码
 楼主| 发表于 2017-12-29 15:12:36 | 显示全部楼层
回复 2# sdlyyuxi




  1. 代码1 :always @(posedge clk)begin
  2. tempa=ina;tempb=inb;tempc=inc;//输入数据缓存
  3. end
  4. 代码2:always @(posedge clk)begin
  5. tempa<=ina;tempb<=inb;tempc<=inc;//输入数据缓存
  6. end


复制代码

我试了一下,代码1和代码2用DC综合出来的电路是一样的,DC综合之后的网表仿真出来的时序也是一样的。为什么有时候用非阻塞"<="赋值会延迟一个周期,而这里非阻塞赋值和阻塞赋值却是一样的效果呢?
发表于 2017-12-29 16:27:24 | 显示全部楼层
回复 3# 550503091


    你试一下我上面说的那种,两者综合出来的肯定不一样。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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


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

GMT+8, 2024-11-22 13:03 , Processed in 0.016873 second(s), 6 queries , Gzip On, Redis On.

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