CN102263609A - 帧边界检测方法和设备及解码方法和系统 - Google Patents
帧边界检测方法和设备及解码方法和系统 Download PDFInfo
- Publication number
- CN102263609A CN102263609A CN201010192374XA CN201010192374A CN102263609A CN 102263609 A CN102263609 A CN 102263609A CN 201010192374X A CN201010192374X A CN 201010192374XA CN 201010192374 A CN201010192374 A CN 201010192374A CN 102263609 A CN102263609 A CN 102263609A
- Authority
- CN
- China
- Prior art keywords
- frame
- syndrome
- data
- current
- error correction
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Images
Classifications
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
- H03M13/33—Synchronisation based on error coding or decoding
- H03M13/333—Synchronisation on a multi-bit block basis, e.g. frame synchronisation
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
- H03M13/65—Purpose and implementation aspects
- H03M13/6561—Parallelized implementations
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L1/00—Arrangements for detecting or preventing errors in the information received
- H04L1/004—Arrangements for detecting or preventing errors in the information received by using forward error control
- H04L1/0045—Arrangements at the receiver end
- H04L1/0046—Code rate detection or code type detection
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L7/00—Arrangements for synchronising receiver with transmitter
- H04L7/04—Speed or phase control by synchronisation signals
- H04L7/048—Speed or phase control by synchronisation signals using the properties of error detecting or error correcting codes, e.g. parity as synchronisation signal
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
- H03M13/03—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
- H03M13/05—Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits
- H03M13/09—Error detection only, e.g. using cyclic redundancy check [CRC] codes or single parity bit
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
- H03M13/27—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes using interleaving techniques
- H03M13/2742—Irregular interleaver wherein the permutation pattern is not obtained by a computation rule, e.g. interleaver based on random generators
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03M—CODING; DECODING; CODE CONVERSION IN GENERAL
- H03M13/00—Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
- H03M13/47—Error detection, forward error correction or error protection, not provided for in groups H03M13/01 - H03M13/37
- H03M13/51—Constant weight codes; n-out-of-m codes; Berger codes
Landscapes
- Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- Probability & Statistics with Applications (AREA)
- Theoretical Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Detection And Prevention Of Errors In Transmission (AREA)
Abstract
公开了一种用于以太网前向纠错层接收的数据流的帧边界检测方法和设备,并公开了一种用于以太网前向纠错层接收的数据流的解码方法和系统。该帧边界检测设备可以包括:缓存器,用于对数据流中的数据进行缓存,所述缓存器的数据长度大于1帧;校正子生成器,用于基于第一数据项、第二数据项以及前一校正子的中间计算结果计算当前校正子,其中第一数据项是当前待测帧的最后一比特数据,第二数据项是所述当前待测帧的前一比特数据;以及比较器,用于使用当前校正子检测所述第一比特数据是否是一个以太网前向纠错层帧边界。该帧边界检测设备可以提高帧边界检测速度。
Description
技术领域
本发明的各实施方式涉及数据通信领域,并且更具体地涉及用于以太网前向纠错(Forward Error Correction,简称FEC)层接收的数据流的帧边界检测方法和设备以及用于以太网前向纠错层接收的数据流的解码方法和系统。
背景技术
IEEE 802.3-2008第74章以及IEEEP 802.3 D1.2定义了应用于10G以太网的BASE-R物理层的FEC子层。该FEC子层标准将系统的误码率(BER)从10-7减少到10-12。而且此标准也适用于40G/100G以太网的应用。
为了兼容不同的以太网应用层,协议规定FEC层压缩原始帧头以留出空间加载FEC校验位,从而保证该层与其他应用层保持一致的帧长度(IEEE 802.3ap-2007第74章定义的帧长度为2112比特位)。但是这样的处理方法导致接收端很难识别各帧之间的帧边界,需要耗费大量时间和发送端帧同步,才能找出正确的帧边界位置。
因此,对于以太网前向纠错层接收的数据流而言,需要一种能够快速检测帧边界的方法以及快速进行FEC解码的方法。
发明内容
针对以上问题,本说明书中提供了一种用于以太网前向纠错层接收的数据流的帧边界检测方法和设备以及一种用于以太网前向纠错层接收的数据流的解码方法和系统。
在本发明的一个实施方式中,提供了一种用于以太网前向纠错层接收的数据流的帧边界检测方法。该帧边界检测方法可以包括:基于第一数据项、第二数据项以及前一校正子的中间计算结果,计算当前校正子,其中第一数据项是当前待测帧的最后一比特数据,第二数据项是该当前待测帧的前一比特数据;以及使用当前校正子检测该当前待测帧的前一比特数据是否是一个以太网前向纠错层帧边界。
在本发明的另一个实施方式中,提供了一种用于以太网前向纠错层接收的数据流的帧边界检测设备。该帧边界检测设备可以包括:缓存器,用于对数据流中的数据进行缓存,该缓存器的数据长度大于1帧;校正子生成器,用于基于第一数据项、第二数据项以及前一校正子的中间计算结果计算当前校正子,其中第一数据项是当前待测帧的最后一比特数据,第二数据项是该当前待测帧的前一比特数据;以及比较器,用于使用当前校正子检测该当前待测帧的前一比特数据是否是一个以太网前向纠错层帧边界。
在本发明的又一个实施方式中,提供了一种用于以太网前向纠错层接收的数据流的解码方法。该解码方法可以包括:利用根据本发明的前述实施方式中的帧边界检测方法检测该数据流的帧边界,并输出当前校正子;根据当前校正子和当前待测帧的校验码确定当前帧中的错误;对当前待测帧进行解扰;以及基于所确定的错误对解扰的帧进行前向纠错。
在本发明的另外一个实施方式中,提供了一种用于以太网前向纠错层接收的数据流的解码系统。该解码系统可以包括:根据本发明的前述实施方式的帧边界检测设备,用于检测该数据流的帧边界,并输出当前校正子;错误诊断器,用于根据当前校正子和当前帧的校验码确定当前帧中的错误;解扰器,用于对当前帧进行解扰;以及错误纠正器,用于基于错误诊断器确定的错误对解扰器所解扰的帧进行前向纠错。
根据本发明的各实施方式中的方法、设备和系统,可以快速确定帧边界位置,从而减少帧边界检测所需要的时间,提高帧同步速度。
通过以下对说明本发明原理的优选实施方式的描述,并结合附图,本发明的其他特征以及优点将会更加明显。
附图说明
通过以下结合附图的说明,并且随着对本发明的更全面了解,本发明的其他目的和效果将变得更加清楚和易于理解,其中:
图1是根据一种技术方案的用于以太网前向纠错层接收的数据流的解码系统的框图;
图2示出了根据图1所示的解码系统进行帧同步的示意图;
图3是根据本发明一种实施方式的用于以太网前向纠错层接收的数据流的解码系统的示意框图;
图4是根据本发明的一个实施方式的用于以太网前向纠错层接收的数据流的帧边界检测设备的示意框图;
图5是根据本发明的一个实施方式的用于以太网前向纠错层接收的数据流的帧边界检测方法的示意流程图;
图6是根据本发明的另一个实施例的用于以太网前向纠错层接收的数据流的帧边界检测方法的示意流程图;以及
图7示出了根据本发明的一个实施例的帧边界检测设备如何进行帧同步的示意图。
在所有的上述附图中,相同的标号表示具有相同、相似或相应的特征或功能。
具体实施方式
以下结合附图,对本发明的各实施方式进行更详细的解释和说明。应当理解,本说明书包括的附图及实施方式仅用于示例性作用,并非用于限制本发明的保护范围。
在本发明的一个实施方式中,基于第一数据项、第二数据项以及前一校正子的中间计算结果,计算当前校正子。这里,第一数据项是当前待测帧的最后一比特数据,第二数据项是该当前待测帧的前一比特数据。然后,使用当前校正子检测该当前待测帧的前一比特数据是否是一个以太网前向纠错层帧边界。
本发明的以下实施方式中,1帧数据包括2112比特,其中2080比特是有效载荷,32比特是校验码。应该理解的是,本发明各实施方式中的方法、设备和系统并不限于这些具体数字,而是可以应用于任何长度的帧。
图1根据一种技术方案的用于以太网前向纠错层接收的数据流的解码系统的框图。具体而言,图1示出了根据IEEE 802.3-2008第74章定义的FEC解码系统的结构图,该FEC解码系统接收来自PMA(Physical Medium Attachment物理介质接入子层)层的输入,并且将处理结果输出到PCS(Physical Coding Sublayer物理编码子层)层。FEC解码系统包括五个模块:移位器对从PMA层接收的数据进行移位;PN-2112发生器用于产生PN2112序列,该序列将会用于与移位器移位后的数据进行异或,实现对接收数据的解扰操作;移位器移位后的数据与PN-2112发生器产生的数据进行异或操作后输入到FEC解码器;FEC解码器将输入的数据进行前向纠错,并将纠错后的数据输出。输出后的数据经过重建64/66数据块,该模块能够对经FEC解码后的数据进行帧头恢复,将每个FEC帧数据中2080比特的有效载荷恢复成32帧66比特长度的PCS帧,然后该模块的输出进入PCS层。FEC解码器还将产生的校正子输出给同步控制器,用于FEC帧同步的控制,同步控制器的输出给移位器,可以控制移位器的移位。
FEC解码器本身又包含校正子产生器、错误诊断器和错误纠正器。其本身是用于前向纠错的,但是由于本发明相关协议的特殊性,其也被用于与发送端的帧同步。
图1的电路结构使用的同步过程包括以下步骤:
a)测试一个假设的帧边界位置;
a1)通过移位器假设一个帧边界位置,以该假设的帧边界位置为起始,用PN-2112发生器对接收数据进行解扰码运算;
a2)校验子产生器对以假设帧边界为起始位置的一帧数据进行FEC校验;
如果校验不匹配(接收到的校验码和运算得到的校验码不相等),则同步控制器会控制移位器将假设的帧边界位置跳过一比特位置,然后重试步骤a);
b)对于一个假设帧边界,同步控制器会根据校验子产生器的输出结果确认n个连续帧的FEC校验都正确;
b1)如果n个连续帧中任何一个帧的FEC校验出错,则同步控制器会控制移位器将假设的帧边界位置跳过一比特位置,重新开始整个帧同步过程;
b2)如果同步控制器检测到接收到的n个连续帧的FEC校验都正确,进入步骤c);
c)帧同步建立;
d)如果同步控制器检测到连续m个接收到的数据帧的FEC校验都错误,则认为帧同步失步,重新开始整个帧同步过程。
对于2112比特位的帧长度,上述步骤最多重复2111次来遍历所有可能的2112个位置以找到正确的帧边界位置。在以上描述中,典型数据取:m=8,n=4。
图2示出了根据图1所示的解码系统进行帧同步的示意图。根据图2,开始时,帧同步逻辑不知道正确的起始位置,它需要在帧里面假设一个帧起始位置来检验此帧。但当第一帧的最后一位数据进入帧同步逻辑的时候,帧同步逻辑不能马上产生此帧的校验结果。这是因为硬件实现上会有基于流水线结构设计所造成的延迟,此延迟是因为一些功能逻辑,比如解扰码等逻辑,所引起的,而且是不可避免的。这段流水线延迟过后,如果帧同步逻辑检测到第一帧边界的位置是错误的,帧同步逻辑需要在后续假设的帧边界位置跳过一比特作为下一个假设的帧边界。此时,由于如图2所示的流水线延迟,从第二帧的帧边界的起始位置跳过一比特,并开始检测第二帧数据已经来不及了。所以帧同步逻辑不得不丢弃整个第二帧数据直到第三帧数据来了,帧同步逻辑才会基于第三帧的帧边界跳过一比特位,然后对第三帧重复第一帧中的校验操作。
这样在最坏情况下,帧同步逻辑需要检测2112帧,丢弃2111帧并且进行2111次跳过一比特位的操作。这需要用时(2112+2111)*2112+2111=8,921,087BT(比特时间)才能得到正确帧边界(即帧的正确起始位)。这样的帧同步时间和其他相近速率的高速接口相比(SATA2.0大概600,000BT,PCIE2.0大约500,000BT)要长很多。
在图1和图2的方案中,由于硬件中流水线结构的存在,当检测一次帧边界时,采用每次跳过一比特位置的方法需要丢弃接近一半的帧,造成帧边界检测时间延长,帧同步速度慢。
本发明的实施方式改进了检测帧边界的方法,针对当前待测帧的校正子(当前校验子)不直接通过输入数据产生,而是通过产生针对前一待测帧的校验子(前一校验子)的中间计算结果而获得,从而加速了帧同步过程。
以下为方便描述,假设每个时钟周期只有1比特数据串行输入。在实际电路的实施中,通过对电路结构的展开,可以支持任意比特数据的并行输入和处理。
图3是根据本发明一个实施方式的用于以太网前向纠错层接收的数据流的解码系统300的示意框图。
FEC解码系统300包括:帧边界检测设备310、错误诊断器320、解扰器330、和错误纠正器340。FEC解码系统300还可以包括:控制器350和重构器360。
帧边界检测设备310检测该数据流的帧边界,并输出当前校正子。错误诊断器320根据当前校正子和当前帧的校验码确定当前帧中的错误。解扰器330对当前帧进行解扰。错误纠正器340基于错误诊断器确定的错误对解扰器所解扰的帧进行前向纠错。控制器350根据来自该帧边界检测设备的帧边界检测结果确定是进行帧边界检测还是进行前向纠错。重构器360用于将完成前向纠错的数据重构成适用于物理编码子层的格式。
在根据本发明一实施方式的FEC解码系统300中,帧边界检测设备310可以包括:缓存器311,用于对数据流中的数据进行缓存,该缓存器的数据长度大于1帧;校正子生成器312,用于基于第一数据项、第二数据项以及前一校正子的中间计算结果计算当前校正子,其中第一数据项是当前待测帧的最后一比特数据,第二数据项是该当前待测帧的前一比特数据;以及比较器313,用于使用当前校正子检测该当前待测帧的前一比特数据是否是一个以太网前向纠错层帧边界。
在一个实施方式中,FEC解码系统300的解码过程如下:
首先,帧边界检测设备310利用前述帧边界检测方法检测出所接收的自PMA层输入的数据流的帧边界,并输出与当前帧相关联的校正子,称为当前校正子。当检测到帧边界时,控制器350通知错误诊断器320对当前帧中的错误进行诊断。然后,错误诊断器320根据当前校正子和当前帧的校验码确定当前帧中的错误,其中当前帧的校验码可以根据以太网前向纠错层帧格式得到。随后,对当前帧进行解扰,这例如可以利用图1所示技术方案中采用的解扰方式,利用PN-2112发生器产生的PN2112序列对来自缓存器311的当前帧中的数据进行异或,从而实现对当前帧的解扰操作。然后,错误纠正器340基于错误诊断器320所确定的错误对解扰的帧进行前向纠错。纠错后的数据输入到重构器360,重构器360将完成前向纠错的数据重构成适用于PCS层的格式,其中重构器360将当前帧的2112比特中的2080比特有效载荷恢复成32帧66比特长度的PCS帧,然后该模块的输出到PCS层。
图4是根据本发明的一个实施方式的用于以太网前向纠错层接收的数据流的帧边界检测设备的框图。
图4的帧边界检测设备主要包括三个组件:缓存器410、校正子生成器420和比较器430。
总体而言,图4所示的帧边界检测设备可以执行图5所示的根据本发明的一个实施方式的用于以太网前向纠错层接收的数据流的帧边界检测方法。在步骤501,校正子生成器420可以基于第一数据项、第二数据项以及前一校正子的中间计算结果,计算当前校正子,其中第一数据项是当前待测帧的最后一比特数据,第二数据项是当前待测帧的前一比特数据,第二数据项可以从缓存器410得到。在步骤502,比较器430可以使用当前校正子检测该当前待测帧的前一比特数据是否是一个以太网前向纠错层帧边界。
具体地,图4所示的帧边界检测设备的结构如下:
缓存器410用于对数据流中的数据进行缓存。缓存器410可以存储的数据长度大于1帧,缓存器410例如可以是FIFO存储器。
校正子生成器420包括:第一异或器421、逻辑与运算器422、取模器423、移位器424、寄存器425、第二异或器426。寄存器425可以存储校正子的中间运算结果。移位器424可以对数据项进行移位。取模器423可以对数据项进行取模运算。逻辑与运算器422可以进行逻辑与运算。第一异或器421可以将三个数据项进行异或运算。第二异或器426可以将两个数据项进行异或运算。
第一异或器421接收第一数据项,作为用于计算当前校正子的第一输入;逻辑与运算器422接收该第二数据项并将该第二数据项与第一参数进行逻辑与运算,得到用于计算当前校正子的第二输入;移位器424将该寄存器425存储的用于计算前一校正子的第一输出进行1比特左移位,取模器423对移位后的数据取模,得到用于计算当前校正子的第三输入;第一异或器421将用于计算当前校正子的第一输入、第二输入和第三输入进行异或运算,得到用于计算当前校正子的第一输出并存储在寄存器425中;以及第二异或器426将用于计算当前校正子的第一输出与第二参数进行逻辑异或运算,得到当前校正子。
比较器430可以包括获取器431和判断器432。获取器431可以根据以太网前向纠错层帧格式,得到当前待测帧中的位于校验码位置的数据。判断器432可以在当前校正子与位于校验码位置的数据匹配的情况下,判定当前待测帧的前一比特数据是以太网前向纠错层帧边界。
以下通过图6描述根据图4的帧边界检测设备如何利用根据本发明一实施方式的帧边界检测方法进行帧边界的检测。
图6是根据本发明的另一个实施方式的用于以太网前向纠错层接收的数据流的帧边界检测方法的流程图。
在一个实施方式中,校正子是通过实现式(1)来得到的:
Syndrome(n+1):(n+FL)=r(x)(n+FL)⊕[r(x)n&MOD2]⊕[(MODRn::(n+FL-1)·x)modg(x)]⊕MODPN(1)
其中:
FL是1帧长度,由于在本实施例中假设采用IEEE 802.3标准下的帧,所以1帧的长度是2112比特,即FL=2112。
Syndrome(n+1):(n+FL)是针对当前待测帧计算出的校正子,也即当前校正子,其长度等于帧的校验位长度。由于在本实施例中假设采用IEEE802.3标准下的帧,所以1帧的校验位长度是32比特,即校正子的长度为32比特。本领域技术人员可以理解的是,在采用帧长度不等于2112比特或校验码长度不等于32比特的其他标准的情况下,本发明的方法和系统也是可以应用的。
r(x)(n+FL)是用于计算当前校正子的第一输入。r(x)表示从来自PMA层的数据流中接收的数据,假设当前待测帧的前一比特数据序号为n,该当前待测帧的第一比特数据序号为n+1,所以当前待测帧的最后一比特数据的序号为n+FL。因此,r(x)(n+FL)是来自PMA层的数据流中的当前待测帧的最后一比特数据,在此将其简称为第一数据项。
r(x)n&MOD2是用于计算当前校正子的第二输入。如上所述,r(x)表示从来自PMA层的数据流中接收的数据,假设当前待测帧的第一比特数据序号为n+1,则r(x)n表示当前待测帧的前一比特数据,在此将其简称为第二数据项。MOD2是第一参数,长度等于帧的校验位长度,其是一个预先设定的固定参数并且可以通过MOD2=(MOD1·x)modg(x)得到,其中MOD1=xFL-1modg(x)并且也是一个固定参数。在本发明的一个实施方式中,MOD2可以以硬连线的方式存储在电路中。符号&表示逻辑与运算,例如,若r(x)n=0,则用于计算当前校正子的第二输入是O;若r(x)n=1,则用于计算当前校正子的第二输入是MOD2。
(MODRn::(n+FL-1)·x)modg(x)是用于计算当前校正子的第三输入,其是将MODRn:(n+FL-1)进行1比特左移位(·x表示进行1比特左移位)后关于g(x)进行取模。MODRn:(n+FL-1)是用于计算前一校正子的第一输出。其中,“计算前一校正子的第一输出”是前一校正子的中间计算结果,在本实施例中其是通过将用于计算前一校正子的第一输入、第二输入和第三输入进行异或运算得到的,如以下式(2)所示:
MODRn:(n+FL-1)=[(MODR(n-1):(n+FL-2)·x)mod g(x)]⊕[r(x)n-1&MOD2]⊕r(x)(n+FL-1) (2)
取模处理可以使用以下多项式,其是由IEEE 802.3 74.7.4.4.1节所确定的:
g(x)=x32+x23+x21+x11+x2+1。
得到以上用于计算当前校正子的第一输入、用于计算当前校正子的第二输入和用于计算当前校正子的第三输入后,将这三者进行异或处理,可以得到用于计算当前校正子的第一输出。所得到的第一输出是当前校正子的中间计算结果,可以用于计算下一校正子,从而每次计算校正子时都可以利用前一校正子的中间计算结果,从而显著减少了计算量,大大提高了处理速度。
MODPN是第二参数,长度等于帧的校验位长度,其是一个预先设定的固定参数且MODPN=PN2112modg(x),其中PN2112是长度为1帧长度的伪噪声序列,可以利用现有技术中的PN-2112发生器来产生,用于实现对数据的解扰。
将第二参数MODPN与用于计算当前校正子的第一输出r(x)(n+FL)⊕[r(x)n&MOD2]⊕[(MODRn:(n+FL-1)·x)modg(x)]进行逻辑异或运算,可以得到当前校正子Syndrome(n+1):(n+FL)。
接着参照图6。在步骤601,接收当前待测帧的最后一比特数据,即上述第一数据项r(x)(n+FL),作为用于计算当前校正子的第一输入。在一个实施方式中,如在图4所示的帧边界检测设备中,由第一异或器421来接收当前待测帧的最后一比特数据。
然后,在步骤602,接收当前待测帧的前一比特数据,即上述第二数据项r(x)n。
接着,在步骤603,将第二数据项r(x)n与第一参数MOD2进行逻辑与运算,得到用于计算当前校正子的第二输入r(x)n&MOD2。在一个实施方式中,如在图4所示的帧边界检测设备中,由逻辑与运算器422接收当前待测帧的前一比特数据r(x)n以及第一参数MOD2,并将r(x)n与MOD2进行逻辑与运算,得到用于计算当前校正子的第二输入,并将其传输到第一异或器421。
然后,在步骤604,将用于计算前一校正子的第一输出MODRn:(n+FL-1)进行1比特左移位,从而得到MODRn:(n+FL-1)·x。在一个实施方式中,如在图4所示的帧边界检测设备中,用于计算前一校正子的第一输出MODRn:(n+FL-1)来自于第一异或器421,由移位器424对其进行1比特左移位。
然后,在步骤605,对步骤604的得到的结果关于g(x)取模,得到用于计算当前校正子的第三输入(MODRn:(n+FL-1)·x)mod g(x)。在一个实施方式中,如在图4所示的帧边界检测设备中,取模器423对经移位器424移位后的结果进行关于g(x)的取模运算,从而得到用于计算当前校正子的第三输入,并将其输入第一异或器421。
接着,在步骤606,将用于计算当前校正子的第一输入r(x)(n+FL)、第二输入r(x)n&MOD2和第三输入(MODRn:(n+FL-1)·x)modg(x)进行异或运算,得到用于计算当前校正子的第一输出
r(x)(n+FL)⊕[r(x)n&MOD2]⊕[(MODRn:(n+FL-1)·x)mod g(x)]。
在一个实施方式中,如在图4所示的帧边界检测设备中,第一异或器421将步骤601得到的用于计算当前校正子的第一输入、步骤603得到的来自于逻辑与运算器422的用于计算当前校正子的第二输入、以及步骤605得到的来自于取模器423的用于计算当前校正子的第三输入进行异或运算,得到用于计算当前校正子的第一输出。
然后,在步骤607,将用于计算当前校正子的第一输出与第二参数MODPN进行逻辑异或运算,得到当前校正子Syndrome(n+1):(n+FL)。在一个实施方式中,如在图4所示的帧边界检测设备中,第二异或器426接收第二参数,并将其与步骤606得到的用于计算当前校正子的第一输出进行异或运算,最终得到针对当前待测帧的校正子,即当前校正子。第二异或器426得到当前校正子后,可以将其提供给比较器430中的判断器以进行帧边界的判断,还可以将其提供给图2所示的错误诊断器320以便诊断当前帧(由于进行错误诊断时以确定当前待测帧是一个以太网前向纠错层帧,所以此时将当前待测帧称为当前帧)中的错误。
接着,在步骤608,根据以太网前向纠错层帧格式,得到当前待测帧中的位于校验码位置的数据。在一个实施方式中,如在图4所示的帧边界检测设备中,由比较器430中的获取器431执行步骤608的操作,从当前待测帧中得到与校正子长度相等的当前待测帧中的位于校验码位置的数据,并输入到判断器432。
然后,在步骤609,在当前校正子Syndrome(n+1):(n+FL)与位于校验码位置的数据匹配的情况下,判定当前待测帧的前一比特数据是以太网前向纠错层帧边界。在一个实施方式中,如在图4所示的帧边界检测设备中,比较器430中的判断器432接收得到当前待测帧中的位于校验码位置的数据,并接收来自第二异或器426的当前校正子,将二者的每个比特分别进行比较。比较器430可以在二者一致的情况下,认为当前校正子与位于校验码位置的数据匹配,从而判定第一异或器421在步骤601所接收的当前待测帧的最后一比特数据(即第一数据项)是一个以太网前向纠错层帧边界。
在步骤609之后,流程结束。
图7示出了根据本发明的一个实施方式的帧边界检测设备如何进行帧同步的示意图。
假设在第一待测帧之前存在一个“假(fake)”帧,该假帧具有2112个为0的比特,其并不是来自PMA层的数据流中的数据。
如图7所示,在时间-2111处,可以得到帧-2111的校正子,此时MODR(-2112):(-1)是32比特的0值。在时间-2110处,根据本发明的式(1)和式(2)可以得到与帧-2110对应的MODR(-2111):0和校正子Syndrome(-2111):0,但是该校正子是“假”校正子,因为这种“假”校正子对应的是假设的“假”帧。
类似地,在时间1处,可以得到与帧1(即第一待测帧)对应的MODR:0:2111和校正子Syndrome0:2111。此时,可以使用该校正子与帧1中的位于校验码位置的数据进行比较,从而判定帧1是否是一个以太网前向纠错层帧。
在时间2处,可以得到与帧2(即第二待测帧)对应的MODR:1:2112和校正子Syndrome1:2112。此时,可以使用该校正子与帧2中的位于校验码位置的数据进行比较,从而判定帧2是否是一个以太网前向纠错层帧。
如此一直进行,当在时间2112处,可以得到与帧2112对应的MODR:2111:4222和校正子Syndrome2111:4222。此时,可以使用该校正子与帧2112中的位于校验码位置的数据进行比较,从而判定帧2112是否是一个以太网前向纠错层帧。
由此,在最差的情况下,通过对以连续的2112比特为起始位置的2112个待测帧进行帧边界检测,一定可以检测到帧边界。也就是说,利用本发明的方法,检测到帧边界所需要的时间最多是4224BT(比特时间)。与现有技术的8,921,087 BT相比,本发明实施方式中的方法将以太网前向纠错层接收的数据流的帧边界检测速度提高了约2112倍,显著提高了FEC解码系统的处理效率。附图中的流程图和框图示出了根据各种实施方式的系统、方法和计算机程序产品的可能实现的架构、功能和操作。在这点上,流程图或框图中的每个步骤可以代表模块、程序段、或代码的一部分,所述模块、程序段、或代码的一部分包括一个或多个用于实现指定的逻辑功能的可执行指令。还应当注意,在有些备选实现中,步骤中标注的功能也可以以不同于附图中所标注的顺序发生。例如,连续示出的两个步骤实际上可以基本并行地执行,或者这些步骤有时也可以按相反的顺序执行,这依所涉及的功能而定。
本发明可以采取完全硬件实施方式、完全软件实施方式或既包含硬件组件又包含软件组件的实施方式的形式。在优选实施方式中,本发明实现为软件,其包括但不限于固件、驻留软件、微代码等。
而且,本发明还可以采取可从计算机可用或计算机可读介质访问的计算机程序产品的形式,这些介质提供程序代码以供计算机或任何指令执行系统使用或与其结合使用。出于描述目的,计算机可用或计算机可读机制可以是任何有形的装置,其可以包含、存储、通信、传播或传输程序以由指令执行系统、装置或设备使用或与其结合使用。
介质可以是电的、磁的、光的、电磁的、红外线的、或半导体的系统(或装置或器件)或传播介质。计算机可读介质的例子包括半导体或固态存储器、磁带、可移动计算机磁盘、随机访问存储器(RAM)、只读存储器(ROM)、硬磁盘和光盘。目前光盘的例子包括紧凑盘-只读存储器(CD-ROM)、压缩盘-读/写(CD-R/W)和DVD。
适合与存储/或执行程序代码的数据处理系统将包括至少一个处理器,其直接地或通过系统总线间接地耦合到存储器元件。存储器元件可以包括在程序代码的实际执行期间所利用的本地存储器、大容量存储器、以及提供至少一部分程序代码的临时存储以便减少执行期间从大容量存储器必须取回代码的次数的高速缓冲存储器。
输入/输出或I/O设备(包括但不限于键盘、显示器、指点设备等等)可以直接地或通过中间I/O控制器耦合到系统。
网络适配器也可以耦合到系统,以使得数据处理系统能够通过中间的私有或公共网络而耦合到其他数据处理系统或远程打印机或存储设备。调制解调器、线缆调制解调器以及以太网卡仅仅是当前可用的网络适配器类型的几个例子。
从上述描述应当理解,在不脱离本发明真实精神的情况下,可以对本发明各实施方式进行修改和变更。本说明书中的描述仅仅是用于说明性的,而不应被认为是限制性的。本发明的范围仅受所附权利要求书的限制。
Claims (16)
1.一种用于以太网前向纠错层接收的数据流的帧边界检测方法,包括:
基于第一数据项、第二数据项以及前一校正子的中间计算结果,计算当前校正子,其中第一数据项是当前待测帧的最后一比特数据,第二数据项是所述当前待测帧的前一比特数据;以及
使用当前校正子检测所述当前待测帧的前一比特数据是否是一个以太网前向纠错层帧边界。
2.根据权利要求1所述的方法,其中计算当前校正子包括:
接收所述第一数据项,作为用于计算当前校正子的第一输入;
接收所述第二数据项并将所述第二数据项与第一参数进行逻辑与运算,得到用于计算当前校正子的第二输入;
将用于计算前一校正子的第一输出进行1比特左移位并取模,得到用于计算当前校正子的第三输入;
将所述用于计算当前校正子的第一输入、第二输入和第三输入进行异或运算,得到用于计算当前校正子的第一输出;
将用于计算当前校正子的第一输出与第二参数进行逻辑异或运算,得到当前校正子。
3.根据权利要求2所述的方法,其中在取模的处理中使用以下多项式:
g(x)=x32+x23+x21+x11+x2+1
4.根据权利要求2所述的方法,其中所述第一参数和所述第二参数是预先设定的固定参数。
5.根据权利要求1所述的方法,其中使用当前校正子检测所述当前待测帧的前一比特数据是否是一个以太网前向纠错层帧边界包括:
根据以太网前向纠错层帧格式,得到当前待测帧中的位于校验码位置的数据;以及
在当前校正子与所述位于校验码位置的数据匹配的情况下,判定所述当前待测帧的前一比特数据是一个以太网前向纠错层帧边界。
6.一种用于以太网前向纠错层接收的数据流的帧边界检测设备,该设备包括:
缓存器,用于对数据流中的数据进行缓存,所述缓存器的数据长度大于1帧;
校正子生成器,用于基于第一数据项、第二数据项以及前一校正子的中间计算结果计算当前校正子,其中第一数据项是当前待测帧的最后一比特数据,第二数据项是所述当前待测帧的前一比特数据;以及
比较器,用于使用当前校正子检测所述当前待测帧的前一比特数据是否是一个以太网前向纠错层帧边界。
7.根据权利要求6所述的设备,其中所述校正子生成器包括:
寄存器,用于存储校正子的中间运算结果;
移位器,用于对数据项进行移位;
取模器,用于对数据项进行取模运算;
逻辑与运算器,用于进行逻辑与运算;
第一异或器,用于将三个数据项进行异或运算;以及
第二异或器,用于将两个数据项进行异或运算,
其中,所述第一异或器接收所述第一数据项,作为用于计算当前校正子的第一输入;
其中所述逻辑与运算器接收所述第二数据项并将所述第二数据项与第一参数进行逻辑与运算,得到用于计算当前校正子的第二输入;
其中所述移位器将所述寄存器存储的用于计算前一校正子的第一输出进行1比特左移位,所述取模器对移位后的数据取模,得到用于计算当前校正子的第三输入;
其中所述第一异或器将所述用于计算当前校正子的第一输入、第二输入和第三输入进行异或运算,得到用于计算当前校正子的第一输出并存储在所述寄存器中;以及
其中所述第二异或器将用于计算当前校正子的第一输出与第二参数进行逻辑异或运算,得到当前校正子。
8.根据权利要求7所述的设备,其中所述取模器使用以下多项式进行取模:
g(x)=x32+x23+x21+x11+x2+1
9.根据权利要求7所述的设备,其中所述第一参数和所述第二参数是预先设定的固定参数。
10.根据权利要求7所述的设备,所述比较器包括:
获取器,用于根据以太网前向纠错层帧格式,得到当前待测帧中的位于校验码位置的数据;以及
判断器,用于在当前校正子与所述位于校验码位置的数据匹配的情况下,判定所述当前待测帧的前一比特数据是一个以太网前向纠错层帧边界。
11.一种用于以太网前向纠错层接收的数据流的解码方法,包括:
利用根据权利要求1-5中任一项的帧边界检测方法检测所述数据流的帧边界,并输出当前校正子;
根据当前校正子和当前待测帧的校验码确定当前帧中的错误;
对当前待测帧进行解扰;以及
基于所确定的错误对解扰的帧进行前向纠错。
12.根据权利要求11所述的方法,还包括:
根据帧边界检测结果确定是进行帧边界检测还是进行前向纠错。
13.根据权利要求11所述的方法,还包括:
将完成前向纠错的数据重构成适用于物理编码子层的格式。
14.一种用于以太网前向纠错层接收的数据流的解码系统,包括:
根据权利要求6-10中任一项的帧边界检测设备,用于检测所述数据流的帧边界,并输出当前校正子;
错误诊断器,用于根据当前校正子和当前帧的校验码确定当前帧中的错误;
解扰器,用于对当前帧进行解扰;以及
错误纠正器,用于基于错误诊断器确定的错误对解扰器所解扰的帧进行前向纠错。
15.根据权利要求14所述的系统,还包括:
控制器,用于根据来自所述帧边界检测设备的帧边界检测结果确定是进行帧边界检测还是进行前向纠错。
16.根据权利要求14所述的系统,还包括:
重构器,用于将完成前向纠错的数据重构成适用于物理编码子层的格式。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201010192374.XA CN102263609B (zh) | 2010-05-31 | 2010-05-31 | 帧边界检测方法和设备及解码方法和系统 |
US13/108,081 US8495478B2 (en) | 2010-05-31 | 2011-05-16 | Frame boundary detection and decoding |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201010192374.XA CN102263609B (zh) | 2010-05-31 | 2010-05-31 | 帧边界检测方法和设备及解码方法和系统 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN102263609A true CN102263609A (zh) | 2011-11-30 |
CN102263609B CN102263609B (zh) | 2014-03-05 |
Family
ID=45010087
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201010192374.XA Active CN102263609B (zh) | 2010-05-31 | 2010-05-31 | 帧边界检测方法和设备及解码方法和系统 |
Country Status (2)
Country | Link |
---|---|
US (1) | US8495478B2 (zh) |
CN (1) | CN102263609B (zh) |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2016011592A1 (zh) * | 2014-07-22 | 2016-01-28 | 华为技术有限公司 | 确定前向纠错帧边界的方法、装置和解码系统 |
CN108234074A (zh) * | 2016-12-22 | 2018-06-29 | Macom连接解决有限公司 | 通过有选择地禁止帧定位处理的成帧器的功率优化机制 |
CN109428674A (zh) * | 2017-08-30 | 2019-03-05 | 深圳市中兴微电子技术有限公司 | 数据传输方法、装置和系统、发送端、接收端及存储介质 |
CN109600196A (zh) * | 2017-09-30 | 2019-04-09 | 深圳市海思半导体有限公司 | 检测帧边界的方法、装置及系统 |
Families Citing this family (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8677225B1 (en) * | 2011-02-11 | 2014-03-18 | Marvell International Ltd. | Low-density parity-check decoder |
US8855248B2 (en) * | 2011-10-25 | 2014-10-07 | Cavium, Inc. | Word boundary lock |
US9065626B2 (en) | 2011-10-25 | 2015-06-23 | Cavium, Inc. | Bit error rate impact reduction |
US9768950B2 (en) | 2015-06-25 | 2017-09-19 | International Business Machines Corporation | Codeword synchronization for fiber channel protocol |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1640037A (zh) * | 2003-01-23 | 2005-07-13 | 连宇通信有限公司 | 一种基于las-cdma系统的初始帧边界检测方法及装置 |
CN1751490A (zh) * | 2003-02-27 | 2006-03-22 | 摩托罗拉公司 | 无线通信系统中的帧同步与扰码识别及其方法 |
CN1930835A (zh) * | 2004-03-12 | 2007-03-14 | 艾利森电话股份有限公司 | 在通用路由封装帧中提供高层分组/帧边界信息 |
CN101405985A (zh) * | 2006-03-29 | 2009-04-08 | Posdata株式会社 | 在数字通信系统中检测接收信号的帧边界的方法及实现该方法的装置 |
Family Cites Families (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5144304A (en) * | 1989-07-17 | 1992-09-01 | Digital Equipment Corporation | Data and forward error control coding techniques for digital signals |
US6990624B2 (en) * | 2001-10-12 | 2006-01-24 | Agere Systems Inc. | High speed syndrome-based FEC encoder and decoder and system using same |
JP4313391B2 (ja) * | 2006-12-13 | 2009-08-12 | 株式会社日立コミュニケーションテクノロジー | 光集線装置および光加入者装置 |
-
2010
- 2010-05-31 CN CN201010192374.XA patent/CN102263609B/zh active Active
-
2011
- 2011-05-16 US US13/108,081 patent/US8495478B2/en active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1640037A (zh) * | 2003-01-23 | 2005-07-13 | 连宇通信有限公司 | 一种基于las-cdma系统的初始帧边界检测方法及装置 |
CN1751490A (zh) * | 2003-02-27 | 2006-03-22 | 摩托罗拉公司 | 无线通信系统中的帧同步与扰码识别及其方法 |
CN1930835A (zh) * | 2004-03-12 | 2007-03-14 | 艾利森电话股份有限公司 | 在通用路由封装帧中提供高层分组/帧边界信息 |
CN101405985A (zh) * | 2006-03-29 | 2009-04-08 | Posdata株式会社 | 在数字通信系统中检测接收信号的帧边界的方法及实现该方法的装置 |
Cited By (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2016011592A1 (zh) * | 2014-07-22 | 2016-01-28 | 华为技术有限公司 | 确定前向纠错帧边界的方法、装置和解码系统 |
US10116419B2 (en) | 2014-07-22 | 2018-10-30 | Huawei Technologies Co., Ltd. | Method and apparatus for determining forward error correction frame boundary, and decoding system |
CN110784283A (zh) * | 2014-07-22 | 2020-02-11 | 华为技术有限公司 | 确定前向纠错帧边界的方法、装置和解码系统 |
CN110784283B (zh) * | 2014-07-22 | 2022-01-14 | 华为技术有限公司 | 确定前向纠错帧边界的方法、装置和解码系统 |
CN108234074A (zh) * | 2016-12-22 | 2018-06-29 | Macom连接解决有限公司 | 通过有选择地禁止帧定位处理的成帧器的功率优化机制 |
CN109428674A (zh) * | 2017-08-30 | 2019-03-05 | 深圳市中兴微电子技术有限公司 | 数据传输方法、装置和系统、发送端、接收端及存储介质 |
CN109600196A (zh) * | 2017-09-30 | 2019-04-09 | 深圳市海思半导体有限公司 | 检测帧边界的方法、装置及系统 |
CN109600196B (zh) * | 2017-09-30 | 2021-12-21 | 深圳市海思半导体有限公司 | 检测帧边界的方法、装置及系统 |
Also Published As
Publication number | Publication date |
---|---|
US8495478B2 (en) | 2013-07-23 |
CN102263609B (zh) | 2014-03-05 |
US20110296282A1 (en) | 2011-12-01 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN102263609B (zh) | 帧边界检测方法和设备及解码方法和系统 | |
CN102035616B (zh) | 以太网前向纠错层接收的数据流的帧边界检测和同步系统 | |
US8468439B2 (en) | Speed-optimized computation of cyclic redundancy check codes | |
CN114328316B (zh) | Dma控制器、soc系统及基于dma控制器的数据搬运方法 | |
RU2014102640A (ru) | Способ и устройство для последовательной передачи данных с гибким размером сообщений и переменной длительностью бита | |
US8996968B2 (en) | Method, apparatus and decoder for decoding cyclic code | |
US20100023846A1 (en) | Methods and apparatuses for performing error detection and error correction for synchronization frame | |
WO2006121014A1 (ja) | 通信装置およびスイッチ処理装置 | |
US8166375B2 (en) | Radio communications device and reception method | |
CN105281883A (zh) | 多通道同步方法、同步装置及系统 | |
JP4260688B2 (ja) | データ送信装置、データ送受信システム、データ送信装置の制御方法およびデータ送受信システムの制御方法 | |
JP5536889B2 (ja) | イーサネット内の順方向誤り訂正層で受信したデータ・ストリームのフレーム境界を検出するための方法およびシステムならびにそのデータ・ストリームに関するフレーム同期方法およびシステム | |
US10771364B2 (en) | Network interface controller | |
TW201631921A (zh) | 在一經符號編碼之傳輸流中輸送錯誤校正碼之高效記憶體之方法 | |
US9465689B2 (en) | Forward error correction synchronization | |
KR20240022449A (ko) | 오류 용인 순방향 오류 정정 순서 세트 메시지 디코더 | |
JP4419867B2 (ja) | データ処理装置 | |
CN112671526B (zh) | 以太网物理编码子层pcs的线对对齐方法、装置和设备 | |
US20210250123A1 (en) | User station for a serial communication network and method for correcting individual errors in a message of a serial communication network | |
JP2007295089A (ja) | 誤り訂正復号回路 | |
WO2013088985A1 (ja) | センサおよびセンシング方法 | |
JP2012010108A (ja) | データ処理回路及びデータ処理方法 | |
Yang et al. | Fast FEC synchronization for 10G Ethernet receiver | |
US11871166B2 (en) | Sensor system | |
JP2008022066A (ja) | 通信ネットワークシステム及びノード同期補正機能の故障診断方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
C06 | Publication | ||
PB01 | Publication | ||
C10 | Entry into substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |