新闻中心

EEPW首页>嵌入式系统>牛人业话> 跨越鸿沟:同步世界中的异步信号

跨越鸿沟:同步世界中的异步信号

作者: 时间:2015-01-26 来源:网络 收藏

  现在指针逻辑的设计有多种方法。第一种方法是将读、写选通进行同步,同时在各个时钟域使用计数器来跟踪中可用的项。计数器反映出可用于读写的项目号,计数器也与相应的端口同步。读计数器跟踪包含有效数据的项数,而写计数器则跟踪可以存储数据的项数。当对指针逻辑进行复位时,由于没有数据可读,读计数器从零起始。写计数器则从中项的总数开始计数,即所有项均可用来存储数据。

本文引用地址://m.amcfsurvey.com/article/268638.htm

  读选通信号累减读计数器,并与写时钟域同步,因为它同时也累加写计数器。写选通信号则累减写计数器,并与读时钟域同步,因为它同时也累加读计数器。

  这种设计需要单时钟宽度脉冲以及用于读、写选通的脉冲同步器,因为当一个电平信号从一个时钟域跨越到

  另一个更快的时钟域时,在较快时钟域中它能在更多的时钟周期中保持有效。由于只要读或写信号是有效的,每个计数器就会发生变化,因此较快的时钟域就检测到更多的读、写,超出较慢时钟域实际发生的数量。脉冲同步器可以将一个时钟域的时钟宽度脉冲转换为新时钟域的时钟宽度脉冲,每个脉冲都表示一次 FIFO 的读或写。

  这种 FIFO 状态技术对读、写状态都不太有利。当 FIFO 中所有项均充满时,写端口状态指示为满,并在读选通触发后继续指示 FIFO 满,因为同步过程会使选通信号延迟送给写计数器。读端口为空时也会出现这种情况,因为同步过程会使写选通信号延迟到达读计数器。

  这种设计的另一种考虑是及时检测全满/全空状态。如果 FIFO 还有一项可用,并且有写选通触发,则 FIFO 必须立即置为全满状态。这样才能提前一个时钟给出全满标志,使 FIFO 有足够时间防止下一个数据写入而产生溢出。对 FIFO 的读端口也是这样。这种情况下,如果 FIFO 里只有一个数,并且有读选通触发,则必须置全空状态,以给读电路足够的时间防止读空 FIFO。

  这种指针逻辑限制电路在每个时钟周期中访问 FIFO,即使在慢速时钟域中也是这样。这一功能的优点在于访问 FIFO 的电路至少有一个时钟周期来评估 FIFO 的状态。FIFO 可以将所有项都填满数据,而不会出现数据被覆盖或全空无数据可读的情况。这种设计的另一个优点是每一端都可以读其相应的计数器,来判断 FIFO 中还有多少项可用。设计者可以将这种 FIFO设计用在进行多次数据读/写的电路中,而不会造成上溢或下溢的情况。

  这种设计的不足之处是由计数器来判断状态,而不是直接比较读、写指针。对大型 FIFO 来说,这些计数器也很大。而且,由于使用脉冲同步时,来自较快时钟域的读、写脉冲在较慢时钟域的脉冲间至少必须有两个时钟周期,因此平均数据速率为最低时钟频率的一半。解决这些问题的一种方法是采用直接指针比较法。

  在这种 FIFO 设计中,读、写指针的比较决定了 FIFO 的状态。异步设计中的指针比较更富有挑战性,因为每个指针位于不同的时钟域中,对信号总线的同步要求在同步握手信号期间总线不发生改变。将这种技术用于指针同步的 FIFO 设计可能会很慢。要解决这个问题,FIFO 指针逻辑使用了格雷码,代替指针使用的二进制码。

  格雷码在每一次计数增减时只改变其中的一位(表 3)。你可以在格雷码总线上使用同步器,因为每一次总线改变时只有一根信号线有变化,于是就消除了格雷码总线各位通过不同同步器时的竞争情况。这种设计的指针为格雷码计数器。使用二进制指针时需要将其变换成格雷码后的同步指针,而使用变换逻辑会违反对同步信号的限制,即同步的信号在跨越时钟域前要来自触发器。

格雷码与二进制码比较

  表 3

  格雷码计数器是一个二进制累加器,在累加器前、后各带有一个转换器,分别用于格雷码转换为二进制码,和二进制码转换为格雷码(图 8)。格雷码与二进制码的转换是一个异或运算,所以只需比一个二进制计数器多几个逻辑电平。在格雷码转换成二进制码时,使用:BN=GN;BN-1=BN+GN-1;BN-2=BN-1+GN-2 . B1=B2+G1;B0=B1+G0。而将二进制码转换成格雷码时,使用:GN=BN;GN-1=BN+BN-1;GN-2=BN-1+BN-2 . G1=B2+B1;G0=B1+B0。在设计中可以采用同样的技术来比较格雷码指针的值,即在各个指针与二进制比较逻辑之间增加转换器。

格雷码计数器是一个二进制累加器

  图8,格雷码计数器是一个二进制累加器,在累加器前、后各带有一个转换器。

  用这种指针逻辑的 FIFO 很快,每个时钟周期中电路都可以读写 FIFO。但是,在每个周期都访问 FIFO 意味着 FIFO 状态要包括“将满”和“将空”两种指示,这样读写 FIFO 的电路才能有停止时间。“将满”表示只能再写入一项,“将空”则表示只有一项可读。这种情况描述了一个要求最少的可能状态信号的设计,以及一个需要更多指示的设计,如果在固定的最小尺寸情况下用猝发方式访问 FIFO 的电路的话。

  这种 FIFO 状态技术会给读、写带来不良状态。当 FIFO 满时,写端口的状态指示已满,而在电路从 FIFO 中读出一项后,该状态仍为满,因为同步机制使读指针相对写入一侧的比较逻辑有个延迟。同样,在读出一侧的空状态指示也有这个问题,因为同步机制使写指针相对读出一侧的比较逻辑有延迟。

  如果你在设计跨不同时钟域电路时,使用一些技术来降低通信失败的风险,则处理跨时钟域的信号就不再是艰巨的任务。同步机制可以防止接收跨时钟域信号的触发器出现亚稳态,从而避免导致不可预知的电路行为。对于在多个时钟周期内一直保持有效的信号来说,电平同步器的效果很好。对于要转换成新时钟域脉冲的较慢时钟域电平信号,要采用边沿检测同步器。最后,对跨时钟

  域的脉冲信号应使用脉冲同步器。还要记住,当一个信号总线跨越时钟域时,整个总线要在同一个时钟周期内到达新的时钟域。不要分别同步每一个信号,而要采用一个保持寄存器和握手方式。握手用来表示寄存器中的信号何时有效,何时可以采样。对数据总线来说,握手和一个保持寄存器很有用,但每次向新时钟域传送的数据字不超过一个。

模拟信号相关文章:什么是模拟信号


电路相关文章:电路分析基础


脉冲点火器相关文章:脉冲点火器原理

上一页 1 2 3 下一页

关键词:FPGA异步信号FIFO

评论


相关推荐

技术专区

关闭