竞争(Race):一个门的输入有两个及以上的变量发生变化时,由于各个输入的组合路径的延时不同,使得在门级输入的状态改变非同时。

冒险或险象(Hazard):竞争的结果,如毛刺Glitch。

相邻信号间的串扰也可能产生毛刺Glitch。

组合逻辑的冒险是过渡性的,它不会使得稳态值偏离正常值。根据严格的metal delay和gate delay可以计算出Glitch的出现时间和宽度。

组合逻辑很容易带来毛刺,当信号作用在FF的reset,clear,clock,gate端时,会造成严重的后果。

措施:使用Gray编码,保证一个时刻只有一个bit发生变化;

采用寄存器采样;(将异步电路转换为同步电路);

改变电路结构,加入冗余的电路来消除险象;如(加入delay cell进行滤波,再相与输出)

后端加入滤波电容;

寄存器的输入端对毛刺并不敏感,只有当毛刺出现在时钟沿并且影响到数据的建立时间和保持时间,才会导致寄存器输出出错。

glitch的危害,在组合逻辑中大面积传播。

(由于毛刺一般时间很短,多为皮秒级,发生错误的机会不大)

在clock switch中如何保证Glitch-Free

由于select信号与clock0和clock1可能完全无关,clock0与clock1也可能完全无关,所以在下图的电路中很容易出现Glitch

一种Glitch-free的设计电路:(必须是加入clock,之后再进行Latch互锁)

加入两个negative_edge的FF来相互互锁,在FF0和FF1的下降沿都还没到来,select已经改变时,FF输出信号与select信号相与

必然都为0,在第一个FF触发后,FF0或FF1中的某一个工作一拍。

1)由两级FF,且后一级是negative FF,保证拉长的clock段是clock=0的段,同时最终切换的clock一定是一个完整的clock 高电平部分。

2)由互锁,保证只有在当前clock,已经接受到enable之后,另一个clock才能开始准备切换,保证当前clock,有完整沿。

3)一个上升沿,一个下降沿,保证切换时间最小。

总之,正确的切换到另一clock的时间会被拉长,拉长的部分是低电平。

在clock0和clock1完全异步的情况下,做两级寄存器同步处理。

亚稳态:在时序逻辑不满足setup/hold/revovery/removal时。

触发器输出端从一个不确定的状态到一个随机值的过程,可能会经过震荡,这段时间叫做决断时间(resolution time)

两个异步信号之间出现亚稳态的概率由MTBF(Mean Time Between Failures)来表示,一级的register以年为单位。二级的register以万年为单位。

亚稳态造成的危害:

1)时序逻辑存在一个时间tMET来保证亚稳态不能传播到下一级的寄存器。

2)在不同的寄存器load中,造成值不同。原因是不同寄存器的MTBF可能不同。

怎么处理亚稳态:

1)通过同步寄存器链,来进行同步。不能同步频率很高的信号(输入保持至少三个时钟,来保证第二级寄存器能输出正确的值),

且可能带来一个clock的错的值,需要依靠协议来保证电路的正确性。

2)异步FIFO

组合逻辑的Glitch与时序逻辑的亚稳态的更多相关文章

  1. 我的 FPGA 学习历程(09)—— 时序逻辑入门

    讲到这篇时,组合逻辑就告一段落了,下面是一些总结: 描述组合逻辑时,always 语句中的敏感信号列表中需要列出全部的可能影响输出的变量 描述组合逻辑时,always 语句中的赋值总是使用阻塞赋值符号 ...

  2. sv时序组合和时序逻辑

    input a; input b; input c; reg d; wire e; reg f; // 时序逻辑,有寄存器 always@(posedge clk)begin 'b1)begin d ...

  3. 从头学起Verilog(二):时序逻辑基础与回顾

    引言 时序逻辑对于数字电路设计十分重要,本文针对数字电路中的时序逻辑部分进行了系统的回顾. 存储器件 由于时序逻辑的输出不但受当前输入影响,还受之前的输入的影响,所以需要有存储单元对以前的输入进行存储 ...

  4. verilogHDL设计中的同步时序逻辑

    引用自夏宇闻教授 1.同步时序逻辑: 是指表示状态的寄存器组的值只能在唯一确定的触发条件发生改变. 只能由时钟的正跳变沿或者负跳变沿触发的状态机就是一例,always@(posedge clk). 1 ...

  5. FPGA时序逻辑中常见的几类延时与时间(五)

    FPGA逻辑代码重要的是理解其中的时序逻辑,延时与各种时间的记忆也是一件头疼的事,这里把我最近看到的比较简单的几类总结起来,共同学习.    一.平均传输延时 平均传输延时 二.开启时间与关闭时间 开 ...

  6. FPGA学习笔记(六)—— 时序逻辑电路设计

    用always@(posedge clk)描述        时序逻辑电路的基础——计数器(在每个时钟的上升沿递增1) 例1.四位计数器(同步使能.异步复位) // Module Name: coun ...

  7. 一个有趣的异步时序逻辑电路设计实例 ——MFM调制模块设计笔记

    本文从本人的163博客搬迁至此. MFM是改进型频率调制的缩写,其本质是一种非归零码,是用于磁介质硬盘存储的一种调制方式.调制规则有两句话,即两个翻转条件: 1.为1的码元在每个码元的正中进行一次翻转 ...

  8. 03-组合逻辑电路设计之译码器——小梅哥FPGA设计思想与验证方法视频教程配套文档

    芯航线——普利斯队长精心奉献 课程目标:    1. 再次熟悉Quartus II工程的建立以及完整的FPGA开发流程 2. 以译码器为例学会简单组合逻辑电路设计 实验平台:无 实验原理: 组合逻辑, ...

  9. (原创)基于FPGA的调光流水灯(Verilog,CPLD/FPGA)

    1.Abstract     前几天做了一个呼吸灯,觉得确实挺有意思的:可惜的是只有一个灯管亮,板子上有四个灯,要是能让这些灯有序地亮起来,那应该更有趣味了!跟传统的一样,逻辑上做成一个流水灯的样式, ...

随机推荐

  1. IdTcpClient简单示例

    procedure TForm1.btnHttpGetClick(Sender: TObject); begin idtcpclnt1.Host := '192.168.10.88'; idtcpcl ...

  2. SQL集合函数中利用case when then 技巧

    我们都知道SQL中适用case when then来转化数据库中的信息 比如  select (case sex when 0 then '男' else '女' end) AS sex  from ...

  3. Marriage Match IV---hdu3416(spfa + Dinic)

    题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=3416 有一个有向图,n个点,m条边,给一个起点和终点,求出从起点到终点的最短路共有几条,每 ...

  4. VI使用技巧

    命令模式下: 1.YY 拷贝当前行 2.P 粘贴拷贝的内容 3.dd 删除当前行 4.输入“:set nu”,显示行号 5.输入“G”,到文件尾部.输入“gg”,到文件头部. 6.输入“/字符串”,进 ...

  5. iOS ASIHTTPRequest 使用指南

    http://www.devdiv.com/iOS_iPhone-ASIHTTPRequest使用指南---_lt__lt_翻译稿_gt__gt_---连载-thread-93741-1-1.html

  6. 面试&笔试常见题,你了解多少?

    HTML:1.  什么是语义化的HTML?有何意义?为什么要做到语义化?(高频率考题)2.  行内元素和块元素分别有哪些?(高频率)3.  严格模式与混杂模式的区分?如何触发这两种模式?(高频率)4. ...

  7. JQuery AJAX: 了解jQuery AJAX

    jQuery AJAX 一.简介1.AJAX是与服务器交换数据的技术,它在不重载全部页面的情况下,实现了对部分网页的更新.AJAX = 异步 JavaScript 和 XML(Asynchronous ...

  8. svn使用svnsync实现双机热备

    前提条件: 主:10.11.100.205从:10.11.100.50 源目录:http://10.11.100.205/svn/rep-ops目标目录:http://10.11.100.50/svn ...

  9. 30天,APP创业从0到1【7.25上海站】

    活动概况 时间:2015年7月25日13:30-16:30 地点:太库•上海孵化器(张江金科路2889号长泰广场c座12楼) 主办:APICloud.诸葛.圣诺资讯 联合主办:微链.太库•上海孵化器 ...

  10. WPF中model属性即时改变

    新建一个model作为说明即可,以便查阅. 添加引用:using System.ComponentModel ; public class Test:INotifyPropertyChanged { ...