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

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

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 1952|回复: 2

[求助] 请帮我看看这段代码有没有问题啊?

[复制链接]
发表于 2012-11-7 10:02:44 | 显示全部楼层 |阅读模式

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

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

x
always @(posedge clk)
  begin : rst_proc
    if (sync_por_n == 0)
    begin
      rst_first    <= 0;  // in first cycle
      old_rst_in_n <= rst_in_n; // save current state
      sync_rst_n   <= rst_in_n; // follow rst_in_n state
    end
    else
    begin
      // check rst_in state in c4:
      if (t_cycle == `c4)
      begin
        if (((old_rst_in_n == 1) && (rst_in_n == 0)) |
            ((old_rst_in_n == 0) && (rst_in_n == 1)))
        begin
          // rst_in goes low or high:
          rst_first <= 1;
        end
        // action only in second cycle:
        if (rst_first == 1)
        begin
          if (rst_in_n == 0)  // still applied ?
          begin
            sync_rst_n <= 0;
            rst_first  <= 0;
          end
          else if (rst_in_n == 1)
          begin
            sync_rst_n <= 1;
            rst_first  <= 0;
          end
        end
        old_rst_in_n <= rst_in_n; // save current state
      end
    end
  end  // rst_proc
感觉不对阿,这里面rst_in_n是芯片外面进来的信号,是异步信号.old_rst_in_n是时钟rst_in_n打了一拍产生的信号,如果rst_in_n的下降沿来得时候刚好和时钟的上升沿对齐 那么old_rst_in_n就可能是亚稳态信号,0,1不确定,rst_first是对old_rst_in_n和rst_in_n异或信号的同步,那么rst_first这时也有可能是亚稳态信号,0,1不确定.那若是old_rst_in_n和rst_first都稳定在0,那sync_rst_n不就检测不到rst_in_n的下降沿了吗?也就是sync_rst_n不就等于不了0了吗?这段代码是权威公司的正规代码,不知道是怎么回事啊?望高手帮我解释一下啊?谢谢?
发表于 2012-11-7 14:14:45 | 显示全部楼层
因为你这只是一段的代码,其实还有代码做这样的处理,那就是消除clk与rst_in_n的亚稳态,你没有看到那部分的代码
发表于 2012-11-7 16:37:42 | 显示全部楼层
从代码来看,应该是像二楼说的一样,还有其它地方有外部复位的同步。
否则即使没有亚稳态问题, “rst_in_n”直接给多个寄存器赋值,也会出现不同步问题(因为延时不同,不同的寄存器在两个时钟内采样到rst_in_n信号的变化)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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


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

GMT+8, 2025-1-1 07:28 , Processed in 0.020799 second(s), 8 queries , Gzip On, Redis On.

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