0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

FPGA中复位电路产生亚稳态概述与理论分析

电子工程师 来源:FPGA设计论坛 作者:FPGA设计论坛 2020-10-25 09:50 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

亚稳态概述

01亚稳态发生原因

FPGA 系统中,如果数据传输中不满足触发器的 Tsu 和 Th 不满足,或者复位过程中复位信号的释放相对于有效时钟沿的恢复时间(recovery time)不满足,就可能产生亚稳态,此时触发器输出端 Q 在有效时钟沿之后比较长的一段时间处于不确定的状态,在这段时间里 Q 端在 0 和 1 之间处于振荡状态,而不是等于数据输入端 D 的值。这段时间称为决断时间(resolution time)。经过 resolution time 之后 Q 端将稳定到 0 或 1 上,但是稳定到 0 或者 1,是随机的,与输入没有必然的关系。

02 亚稳态发生场合

只要系统中有异步元件,亚稳态就是无法避免的,亚稳态主要发生在异步信号检测、跨时钟域信号传输以及复位电路等常用设计中。

03 亚稳态危害

由于产生亚稳态后,寄存器Q 端输出在稳定下来之前可能是毛刺、振荡、固定的某一电压值。在信号传输中产生亚稳态就会导致与其相连其他数字部件将其作出不同的判断,有的判断到“1”有的判断到“0”,有的也进入了亚稳态,数字部件就会逻辑混乱。在复位电路中产生亚稳态可能会导致复位失败。怎么降低亚稳态发生的概率成了FPGA设计需要重视的一个注意事项。

理论分析

01 信号传输中的亚稳态

在同步系统中,输入信号总是系统时钟同步,能够达到寄存器的时序要求,所以亚稳态不会发生。亚稳态问题通常发生在一些跨时钟域信号传输以及异步信号采集上。

它们发生的原因如下:

在跨时钟域信号传输时,由于源寄存器时钟和目的寄存器时钟相移未知,所以源寄存器数据发出数据,数据可能在任何时间到达异步时钟域的目的寄存器,所以无法保证满足目的寄存器 Tsu 和 Th 的要求;

在异步信号采集中,由于异步信号可以在任意时间点到达目的寄存器,所以也无法保证满足目的寄存器 Tsu 和 Th 的要求;

当数据在目的寄存器 Tsu-Th 时间窗口发生变化,也即当数据的建立时间或者保持时间不满足时,就可能发生亚稳态现象。如图 3.1 所示。

图 3.1 亚稳态产生示意图

由图可知,当产生亚稳态后 Tco 时间后会有 Tmet(决断时间)的振荡时间段,当振荡结束回到稳定状态时为“0”或者“1”,这个是随机的。因此,会对后续电路判断造成影响。

02 复位电路的亚稳态

(1)异步复位电路

在复位电路设计中,复位信号基本都是异步的,常用异步复位电路 Verilog 描述如下:

always @(posedge clk or negedge rst_n)
begin
if(!rst_n) a <= 1’b0;
else a <= b;
end

综合出来复位电路模型如图 3.2 所示:

图 3.2 异步复位电路模型

如图 3.3 所示,为复位电路复位时序图。如果异步复位信号的撤销时间在 Trecovery(恢复时间)和 Tremoval(移除时间)之内,那势必造成亚稳态的产生,输出在时钟边沿的 Tco 后会产生振荡,振荡时间为 Tmet(决断时间),最终稳定到“0”或者“1”,就会可能造成复位失败。

图 3.3 异步复位时序

(2)同步复位电路

在复位电路中,由于复位信号是异步的,因此,有些设计采用同步复位电路进行复位,并且绝大多数资料对于同步复位电路都认为不会发生亚稳态,其实不然,同步电路也会发生亚稳态,只是几率小于异步复位电路。

如下面 verilog 代码对同步复位电路的描述:

always @(posedge clk)
begin
if(!rst_n) a <= 1’b0;
else a <= b;
end


综合出硬件电路如图 3.4 所示。

图 3.4 同步复位电路

在此,我们不讨论同步复位的消耗资源问题,只讨论同步复位的亚稳态产生情况。

当输入端 Din 为高电平,而且复位信号的撤销时间在 clk 的 Tsu 和 Th 内时候,亚稳态就随之产生了。如图 3.5 时序所示,当复位撤销时间在 clk 的 Tsu 和 Th 内,输入数据为“1”,通过和输入数据相与后的数据也在 clk 的 Tsu 和 Th 内,因此,势必会造成类似异步信号采集的亚稳态情况。

图 3.5 同步复位电路时序图

03 亚稳态产生概率以及串扰概率

在实际的FPGA电路设计中,常常人们想的是怎么减少亚稳态对系统的影响,很少有人考虑怎么才能减少亚稳态发生几率,以及亚稳态串扰的概率问题。

(1)亚稳态发生概率

由上面分析得知,系统亚稳态发生的都是由于 clk 的 Tsu 和 Th 不满足,又或者是复位信号的移除和恢复时间不满足。常用 FPGA 器件的 Tsu+Th 约等于 1ns,复位移除和恢复时间相加约等于 1ns。

当异步信号不是一组数据,或者信号量较少,那就需要对异步信号进行同步处理,例如对一个异步脉冲信号进行采集,只要脉冲信号变化发生在时钟 Tsu 和 Th 窗口内,那就很可能会产生亚稳态,亚稳态产生的概率大概为:

概率=(建立时间+保持时间)/ 采集时钟周期

(公式 3-1)

由公式 3-1 可以看出,随着 clk 频率的增加,亚稳态发生的几率是增加的。

例如,为系统采用 100M 时钟对一个外部信号进行采集,采集时钟周期为 10ns,那采集产生亚稳态的概率为:1ns/10ns=10%

同理采用 300M 时钟对一个外部信号进行采集,那产生亚稳态的概率为:1ns/3.3ns=30%

如果采用三相相位差为 120°的时钟对一个外部信号进行采集,那产生亚稳态的概率接近 90%

所以在异步信号采集过程中,要想减少亚稳态发生的概率:

降低系统工作时钟,增大系统周期,亚稳态概率就会减小;

采用工艺更好的 FPGA,也就是 Tsu 和 Th 时间较小的 FPGA 器件、

(2)亚稳态的串扰概率

使用异步信号进行使用的时候,好的设计都会对异步信号进行同步处理,同步一般采用多级 D 触发器级联处理,如图 3.6 所示,采用三级 D 触发器对异步信号进行同步处理。

图 3.6 三级寄存器同步

这种模型大部分资料都说的是第一级寄存器产生亚稳态后,第二级寄存器稳定输出概率为 90%,第三极寄存器稳定输出的概率为 99%,如果亚稳态跟随电路一直传递下去,那就会另自我修护能力较弱的系统直接崩溃。接下来我们分析这种串扰的概率问题。

如图 3.7 所示为一个正常第一级寄存器发生了亚稳态,第二级、第三极寄存器消除亚稳态时序模型。

图 3.7 三级寄存器消除亚稳态

由上图可以看出,当第一个寄存器发生亚稳态后,经过 Tmet 的振荡稳定后,第二级寄存器能采集到一个稳定的值。但是为什么第二级寄存器还是可能会产生亚稳态呢?

由于振荡时间 Tmet 是受到很多因素影响的,所以 Tmet 时间又长有短,所以当 Tmet 时间长到大于一个采集周期后,那第二级寄存器就会采集到亚稳态。如图 3.8 所示。

图 3.8 二级寄存器亚稳态

由上图可知,第二级也是一个亚稳态,所以在这种情况下,亚稳态产生了串扰,从第一级寄存器传到了第二级寄存器,同样也可能从第二级寄存器串扰到第三级寄存器。这样会让设计逻辑判断出错,产生亚稳态传输,可能导致系统死机奔溃。

(3)亚稳态振荡时间 Tmet

亚稳态震荡时间 Tmet 关系到后级寄存器的采集稳定问题,Tmet 影响因素包括:器件的生产工艺、温度、环境以及寄存器采集到亚稳态离稳定态的时刻等。甚至某些特定条件,如干扰、辐射等都会造成 Tmet 增长。

消除亚稳态的办法

有亚稳态产生,我们就要对亚稳态进行消除,常用对亚稳态消除有三种方式:

对异步信号进行同步处理;

采用 FIFO 对跨时钟域数据通信进行缓冲设计;

对复位电路采用异步复位、同步释放方式处理。

01 对异步信号进行同步提取边沿

在异步通信或者跨时钟域通信过程中,最常用的就是对异步信号进行同步提取边沿处理。对一个异步信号进行提取上升沿通常采用程序清单 4.1 所示。

程序清单 4.1 双极寄存器提取边沿


input sig_nsyn;
wire sig_nsyn_p;
reg[1:0] sig_nsyn_r;
always @(posedge clk or negedge rst_n)
begin
if(!rst_n) sig_nsyn_r <= 2’d0;
else sig_nsyn_r <= { sig_nsyn_r [0], sig_nsyn };
end
assign sig_nsyn_p = sig_nsyn_r[0] & ~sig_nsyn_r[1];


这种边沿提取方式对于一个稳定的系统是不合适的,例如:当第一级寄存器采集到亚稳态,那势必造成 sig_nsyn_p 输出亚稳态,这样就会对采用 sig_nsyn_p 的信号进行判断的电路造成影响,甚至判断出错误的值。

根据 3.3.1 小节的亚稳态产生概率,如果在 100M 时种下那第一级寄存器产生亚稳态的概率约为 10%,随着系统采集频率升高,那产生亚稳态的概率也会随之上升。因此,在进行异步信号跨频提取边沿时候,一般采用多进行一级寄存器消除亚稳态,可能在系统稳定性要求高的情况下,采用更多级寄存器来消除亚稳态,如程序清单 4.2 所示,即为采用 4 级寄存器消除亚稳态,相应的边沿信号产生的时间就晚了两个时钟周期。

程序清单 4.2 多级寄存器提取边沿信号


input sig_nsyn;
wire sig_nsyn_p;
reg[3:0] sig_nsyn_r;
always @(posedge clk or negedge rst_n)
begin
if(!rst_n) sig_nsyn_r <= 2’d0;
else sig_nsyn_r <= { sig_nsyn_r [2::0], sig_nsyn };
end
assign sig_nsyn_p = sig_nsyn_r[2] & ~sig_nsyn_r[3];

02FIFO 进行异步跨频数据处理

当数据流从一个时钟域到另一个时钟域的时候,绝大多数情况下都采用 FIFO 来作为中间缓冲,采用双时钟对数据缓冲,就可以避免亚稳态的发生。

03 异步复位,同步释放

对于复位情况下的亚稳态,常常是由于恢复时间和移除时钟不满足造成的,因此,最常用的处理方式是采用异步复位、同步释放。常用电路模型如所示。采用第二级寄存器输出作为全局复位信号输出。

程序清单 4.3 异步复位处理


wire sys_rst_n;
reg [1:0] rst_r;
always @(posedge clk or negedge rst_n)
begin
if(!rst_n) rst_r <= 2’d0;
else rst_r <= {rst_r[0], 1’b1};
end
assign sys_rst_n = rst_r[1];

通过上面三种方式处理异步信号、异步数据、以及异步复位可有效的提高系统的稳定性。减少亚稳态的产生。

责任编辑:xj

原文标题:详解 | FPGA中复位电路产生亚稳态的原因

文章出处:【微信公众号:FPGA设计论坛】欢迎添加关注!文章转载请注明出处。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • FPGA
    +关注

    关注

    1655

    文章

    22282

    浏览量

    630059
  • 亚稳态
    +关注

    关注

    0

    文章

    47

    浏览量

    13649
  • 复位电路
    +关注

    关注

    13

    文章

    331

    浏览量

    45735

原文标题:详解 | FPGA中复位电路产生亚稳态的原因

文章出处:【微信号:gh_9d70b445f494,微信公众号:FPGA设计论坛】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    ASP4644芯片在雷达FPGA供电系统的适配与性能分析

    本文系统性地分析了国科安芯推出的ASP4644芯片在雷达FPGA供电系统的适配性与性能表现。
    的头像 发表于 10-14 17:09 415次阅读

    GraniStudio零代码平台轴复位算子支持多少个轴同时复位,有哪些回零模式?

    GraniStudio平台在轴复位的功能上未对同时复位的轴数进行硬性限制,理论上支持任意数量轴同步复位,需要考虑的是在做多轴同步复位时要评估
    的头像 发表于 07-07 18:02 482次阅读
    GraniStudio零代码平台轴<b class='flag-5'>复位</b>算子支持多少个轴同时<b class='flag-5'>复位</b>,有哪些回零模式?

    复位电路的核心功能和主要类型

    复位电路(Reset Circuit) 是数字系统的关键功能模块,用于确保设备在上电、电压波动或异常状态下可靠复位至初始状态。其设计直接影响系统的稳定性和抗干扰能力。
    的头像 发表于 06-30 14:24 896次阅读
    <b class='flag-5'>复位</b><b class='flag-5'>电路</b>的核心功能和主要类型

    单片机各种复位电路原理

    复位电路的作用 在上电或复位过程,控制CPU的复位状态:这段时间内让CPU保持复位状态,而不是
    发表于 05-30 16:53

    进群免费领FPGA学习资料!数字信号处理、傅里叶变换与FPGA开发等

    ~ 01、数字信号处理的FPGA实现 旨在讲解前端数字信号处理算法的高效实现。首先概述了当前的FPGA技术、器件以及用于设计最先进DSP系统的工具。阐述了计算机算法的概念、理论、FI
    发表于 04-07 16:41

    射频电路设计——理论与应用

    本资料从低频电路理论到射频、微波电路理论的演化过程出发,讨论以低频电路理论为基础结合高频电压、电
    发表于 04-03 11:41

    复位电路的作用、控制方式和类型

    复位电路也是数字逻辑设计中常用的电路,不管是 FPGA 还是 ASIC 设计,都会涉及到复位,一般 FP
    的头像 发表于 03-12 13:54 3528次阅读
    <b class='flag-5'>复位</b><b class='flag-5'>电路</b>的作用、控制方式和类型

    电子工程师培训教程(经典电路分析)

    本书介绍了正弦稳态电路分析
    发表于 03-07 10:55

    做APPSFPGA的vhdl源码,fpga如何修改pgen送数据到数据总线然后复位

    有人在做 APPSFPGA的 vhdl 源码吗,我刚开始接触 fpga 如何修改 pgen 送数据 到数据总线 然后 复位 ,有大佬可以指点一下吗
    发表于 02-21 06:01

    集成电路设计静态时序分析介绍

    本文介绍了集成电路设计静态时序分析(Static Timing Analysis,STA)的基本原理、概念和作用,并分析了其优势和局限性。   静态时序
    的头像 发表于 02-19 09:46 1295次阅读

    CMOS逻辑IC使用时如何应对电路的危害、亚稳态、锁存以及ESD—东芝半导体带你深入电子设计

    提要 本期课堂,我们将继续深入CMOS逻辑IC的使用注意事项,介绍如何应对电路的危害、亚稳态、锁存以及ESD防护等问题。 Q 危害的问题 如果是由OR(或)、AND(与)和其它门组成的多输入组合
    的头像 发表于 02-07 17:43 1831次阅读
    CMOS逻辑IC使用时如何应对<b class='flag-5'>电路</b><b class='flag-5'>中</b>的危害、<b class='flag-5'>亚稳态</b>、锁存以及ESD—东芝半导体带你深入电子设计

    74HC423-Q100双可复位稳态多谐振荡器规格书

    电子发烧友网站提供《74HC423-Q100双可复位稳态多谐振荡器规格书.pdf》资料免费下载
    发表于 02-07 15:48 1次下载
    74HC423-Q100双可<b class='flag-5'>复位</b>单<b class='flag-5'>稳态</b>多谐振荡器规格书

    电气原理与电路分析 电气原理的欧姆定律

    关系,是电路分析和设计的基础。 二、电气原理概述 电气原理是研究电荷在电场的运动规律以及由此产生的各种电磁现象的学科。在电气原理
    的头像 发表于 02-01 10:29 2354次阅读

    提升开关电源效率的理论分析与实战经验

    在这里有电源技术干货、电源行业发展趋势分析、最新电源产品介绍、众多电源达人与您分享电源技术经验,关注我们,与中国电源行业共成长! 提升开关电源效率的理论分析与实战经验 引言 开关电源设计
    的头像 发表于 01-09 10:04 1792次阅读
    提升开关电源效率的<b class='flag-5'>理论</b><b class='flag-5'>分析</b>与实战经验

    使用DAC38RF84过程中出现复位脚异常现象,怎么解决?

    (理论值为1.8V);在用FPGA控制IO向该复位脚输入1.8V高电平时,用万用表测量复位脚电压,电压值为1.0V(理论值为1.8V)。因
    发表于 12-16 08:41