Reconfigurable FEC
11265025 · 2022-03-01
Assignee
Inventors
Cpc classification
H03M13/617
ELECTRICITY
H03M13/159
ELECTRICITY
H03M13/1545
ELECTRICITY
International classification
H03M13/00
ELECTRICITY
H03M13/15
ELECTRICITY
Abstract
The present invention is directed to data communication systems and methods thereof. According to various embodiments, the present invention provides a communication with a reconfigurable forward-error-correction (FEC) module. The FEC module processes data received from two or more communication lanes, and depending on the mode of operation, the FEC module can combine data from the two or more communication lanes and perform error correction on the combined data, or the FEC module can processes data from the two communications lanes separately and perform error correction independently for the each of the data communication lanes. There are other embodiments as well.
Claims
1. A transceiver device comprising: a receiver configured to receive analog signals from one or more physical channels; an analog-to-digital converter (ADC) configured to convert the analog signals to digital data streams, the digital data streams being associated with a first communication lane and a second communication lane; forward-error correction (FEC) module with multiple operating modes for processing the digital data streams from at least the first communication lane and the second communication lane operating at n-bit, n being associated with a data width, the FEC module comprising: a syndrome computation (SC) module configured to perform syndrome computation (SC) using a first processing module to generate an equation using a 2n-bit vector if an operating mode is in a 2n-bit mode, the 2n-bit vector including data from the first communication lane and the second communication lane, the SC module further being configured to perform syndrome computation (SC) using a second process module to generate the equation using a first n-bit vector if the operating mode is in a n-bit mode; a key equation solver (KES) module coupled to the SC module and configured to generate a first polynomial and a second polynomial based at least on the equation; and a Chien Search (CS) being operational in the multiple operating modes and configured to determine an error location.
2. The device of claim 1 further comprising an accumulator for aligning data at least from the first communication lane.
3. The device of claim 1 wherein the multiple operating modes are selected from the n-bit mode, the 2n-bit mode, and a 4n-bit mode.
4. The device of claim 1 further comprising a digital signal processing module for processing the digital data streams.
5. The device of claim 1 wherein the 2n-bit vector is stored in a first vector module and a second vector module.
6. The device of claim 1 further comprising a Forney module coupled to the CS module for determining error locations.
7. The device of claim 1 wherein the SC module is configured to perform serial computations.
8. The device of claim 5 wherein the first n-bit vector is stored in the first vector module.
9. The device of claim 1 wherein the first polynomial is associated with the error location and the second polynomial is associated with an error value.
10. The device of claim 9 wherein the first communication lane is configured to transmit pulse-amplitude modulation (PAM) signals.
11. The device of claim 1 wherein n in the n-bit and 2n-bit modes and in the n-bit and 2n-bit vectors equals 4.
12. The device of claim 1 wherein the first processing module further comprises a selector module for selecting from two or more root values.
13. The device of claim 1 wherein the CS module comprises a first section and a second section corresponding to the multiple operational modes.
14. The device of claim 13 wherein the first section is configured to operate in the n-bit mode and the 2n-bit mode for determining errors.
15. The device of claim 1 wherein the SC module is further configured to generate the equation using a 4n-bit vector if the operating mode is in a 4n-bit mode.
16. The device of claim 1 wherein the CS is configured to use at least the first polynomial to determine the error location.
17. A transceiver device comprising: a receiver configured to receive analog signals from one or more physical channels; an analog-to-digital converter (ADC) configured to convert the analog signals to digital data streams, the digital data streams being associated with a first communication lane and a second communication lane; a plurality of accumulators corresponding to a plurality of communication lanes, the plurality of communication lanes including the first communication lane and the second communication lane, the plurality of accumulators being configured to align the digital data streams; forward-error correction (FEC) module with multiple operating modes for processing the digital data streams from at least the first communication lane and the second communication lane operating at n-bit, n being associated with a data width, the FEC module comprising: a syndrome computation (SC) module configured to perform syndrome computation (SC) to generate an equation using a 2n-bit vector if an operating mode is in a 2n-bit mode, the 2n-bit vector including data from the first communication lane and the second communication lane, the SC module further being configured to perform syndrome computation (SC) to generate the equation using a first n-bit vector if the operating mode is in a n-bit mode; a key equation solver (ICES) module configured to generate a first polynomial and a second polynomial based at least on the equation; and a Chien Search (CS) module configured to determine an error location.
18. The device of claim 17 wherein the multiple operating modes includes a 4n-bit mode.
19. The device of claim 17 the CS module uses at least the first polynomial to determine the error location.
Description
BRIEF DESCRIPTION OF THE DRAWINGS
(1)
(2)
(3)
(4)
(5)
(6)
(7)
DETAILED DESCRIPTION OF THE INVENTION
(8) The present invention is directed to data communication systems and methods thereof. According to various embodiments, the present invention provides a communication with a reconfigurable forward-error-correction (FEC) module. The FEC module processes data received from two or more communication lanes, and depending on the mode of operation, the FEC module can combine data from the two or more communication lanes and perform error correction on the combined data, or the FEC module can processes data from the two communications lanes separately and perform error correction independently for the each of the data communication lanes. There are other embodiments as well.
(9) As explained above, improved communication systems and methods are desired. For example, to move a large amount of data, error correction devices and mechanisms are essential aspects of communication systems. Forward-error-correction (FEC) mechanism has been used in many communication systems and applications thereof. Among other things, FEC provides the capability of both detecting and correcting errors that are in data transmitted through a communication network. There have been various types of FEC mechanisms in the past. It is to be appreciated that the embodiments of the present invention provide a reconfigurable FEC device and method thereof.
(10) The following description is presented to enable one of ordinary skill in the art to make and use the invention and to incorporate it in the context of particular applications. Various modifications, as well as a variety of uses in different applications will be readily apparent to those skilled in the art, and the general principles defined herein may be applied to a wide range of embodiments. Thus, the present invention is not intended to be limited to the embodiments presented, but is to be accorded the widest scope consistent with the principles and novel features disclosed herein.
(11) In the following detailed description, numerous specific details are set forth in order to provide a more thorough understanding of the present invention. However, it will be apparent to one skilled in the art that the present invention may be practiced without necessarily being limited to these specific details. In other instances, well-known structures and devices are shown in block diagram form, rather than in detail, in order to avoid obscuring the present invention.
(12) The reader's attention is directed to all papers and documents which are filed concurrently with this specification and which are open to public inspection with this specification, and the contents of all such papers and documents are incorporated herein by reference. All the features disclosed in this specification, (including any accompanying claims, abstract, and drawings) may be replaced by alternative features serving the same, equivalent or similar purpose, unless expressly stated otherwise. Thus, unless expressly stated otherwise, each feature disclosed is one example only of a generic series of equivalent or similar features.
(13) Furthermore, any element in a claim that does not explicitly state “means for” performing a specified function, or “step for” performing a specific function, is not to be interpreted as a “means” or “step” clause as specified in 35 U.S.C. Section 112, Paragraph 6. In particular, the use of “step of” or “act of” in the Claims herein is not intended to invoke the provisions of 35 U.S.C. 112, Paragraph 6.
(14) Please note, if used, the labels left, right, front, back, top, bottom, forward, reverse, clockwise and counter clockwise have been used for convenience purposes only and are not intended to imply any particular fixed direction. Instead, they are used to reflect relative locations and/or directions between various portions of an object.
(15)
(16)
(17)
(18)
(19)
(20) It is to be appreciated that the FEC module 500 may include additional components as well. In various embodiments, the FEC module 500 additionally includes a Forney module (not shown in
(21)
(22) During the RS decoding process, 2t syndrome coefficients are needed to provide up to t symbols of error correction. For example, in a syndrome calculation, coefficients with i=1, 2, . . . 2t are computing using Equation 1 below:
s.sub.i=Σ.sub.j=0.sup.N-1r.sub.j(α.sup.i).sup.j Equation 1
(23) In Equation 1, r.sub.j refers to N received symbols, and a is a root of the primitive polynomial. As can be seen that according to Equation 1, syndrome calculation involves many iterations of multiple, addition, and root calculations, and thus is computationally complex. To reduce computational complexity, Homer's rule is sometimes used to perform syndrome calculations recursively. For example, in a syndrome computation cell, a received symbol, which is typically provided in a form of a bit vector, is multiplied and added for calculating coefficients.
(24) To use the
(25) Depending on how the communication systems are set up (e.g., how the communication lanes are grouped), the corresponding FEC modules may use a 40-bit vector, an 80-bit vector, a 160-bit vector, or vectors of other sizes. The FEC modules, depending on the size and structure of the vectors, perform computations (i.e., syndrome calculation, key equation solving, and Chien search process) that are specifically based on the vector size. However, conventional systems described above use FEC modules are can only process a single size of vector; for example, the FEC module that is configured to process a 40-bit vector cannot process an 80-bit or 160-bit vector. Thus, for different configurations of the communication system, different vector modules and processing modules (i.e., for both SC module and CS module of the FEC module) thereof need to be used. It is to be appreciated that the SC module 600 in
(26) The SC module 600 includes four vector modules 601-604. Each of the vector modules is 40-bit wide. For example, the vector module 604 includes a vector that is 40-bit wide, storing bits vector bits R[0] to R[39]. The vector module 601 also comprises 40 multipliers that multiplies input vector bits and corresponding root values. More specifically, a vector bit R[n] is multiplied with root value α.sup.n-1, which is based on Equation 1 described above. For example, R[0] multiplies with α.sup.−1, R[1] multiplies with α.sup.0, R[2] multiplies with α.sup.1, and so on and so forth. Vector module 601, 602, and 603 are configured similar to the vector module 604, where bits of a 40-bit vector are multiplied respectively with corresponding root values.
(27) Each of vector modules 601-604 corresponds to a processing module. As shown in
(28) The vector modules 601-604 and their corresponding processing modules are configured to operate in different modes. As an example, to operate in the independent mode described above, the vector modules and their corresponding processing modules operate independently from one another. For example, the vector module 603 and its processing module 622 may work together as an independent SC module that calculates performing syndrome calculation for a 40-bit vector, ignoring input from the multiplier 611, which is based on the vector module 604. The selector module 614 as shown selects between α.sup.40 and α.sup.80, depending on whether the SC module 600 operate in 40-bit mode, 80-bit mode, or 160-bit mode. For example, the selector module 614 comprises an MUX. If the SC module 600 is operating in an 80-bit mode, the processing module 622 uses the input from the multiplier 611 and α.sup.80 as an input to calculate syndrome polynomials up to α.sup.80 and R[79], where R[79] comes from vector modules 603 and 604. If the SC module 600 is operating in a 160-bit mode (i.e., data combined from four data communication lanes), the vector module 603 and its processing module 622 provides its output at multiplier 612 to the vector module 601 and its corresponding processing module 620.
(29) The vector module 601 and its corresponding processing module 620 are configured to operates in 40-bit mode, 80-bit mode, or 160-bit mode. Operating in 40-bit mode, the vector module 601 and processing 620 ignore inputs from other vector modules and their corresponding processing modules; the selector module 615 selects α.sup.40 as the input to the processing module 620. Operating in 80-bit mode, the processing module 620 uses vector data from vector modules 601 and 602, and selects value α.sup.80 as its input for calculating the syndrome polynomials. Operating in a 160-bit mode, the processing module 620 uses vector data from all for vector modules 601-604, and selects value α.sup.60 as its input for calculating the syndrome polynomials. In various implementations, when operating in 80-bit mode, the processing module 620 uses data from vector modules 601 and 602 as the input to perform syndrome calculation, and the processing module 622 uses data from vector modules 603 and 604 as the input to perform syndrome calculation. As mentioned above, depending on the specific implementations, vector modules and corresponding processing modules can be added or removed. In various configurations, a syndrome search module according to embodiments of the present invention may have 2, 4, 8, 16, or other numbers of vector module and corresponding processing module sets, which are used respectively for 2, 4, 8, 16, or other numbers of communication lanes in a communication system.
(30) Similar to the SC module, the CS module comprises vectors and corresponding correction modules that can be configured to operate in different modes (e.g., 4 lanes, 2 lanes, and independent modes).
(31) When the CS module 700 operates in 80-bit mode, the four sections 710, 720, 730, and 740 are grouped into two sets, where each set processes 80 bits. To process 80-bit wide data stream, sections 710 and 720 are grouped together as a set, and sections 730 and 740 are grouped together as another set. For example, when operating in 80-bit mode, sections 710 and 720 share their vectors. More specifically, among the 80 bits, section 720 provides vector [39:0] and section 710 provides vector [79:40]. Similarly, in 80-bit mode, section 730 provides vector [39:0] and section 740 provides vector [79:40]. As shown in
(32) When the CS module 700 operate in 160-bit mode, the four sections 710, 720, 730, and 740 share their vectors and operate as a single 160-bit unit. The four sections are connected by the data path 703 as shown. Section 740 provides vector [39:0], section 730 provides vector [79:40], section 720 provides vector [119:80], and section 710 provides vector [159:120]. The selector 711, when operating in 160 mode, selects data path 703. Depending on the mode of operation, section 710 may perform error detections for 40-bit, 80-bit, or 160-bit data.
(33) It is to be understood that CS module 700 can be implemented in various ways. With the use of data paths as illustrated in
(34) In various embodiments, communication systems according to embodiments of the present invention include a controller module that coordinate the operation the FEC. For example, depending on the mode of operation (e.g., 40-bit, 80-bit, 160-bit), the controller module indicates how SC module and SC module process data and what data path is to be used. There are other embodiments as well.
(35) While the above is a full description of the specific embodiments, various modifications, alternative constructions and equivalents may be used. Therefore, the above description and illustrations should not be taken as limiting the scope of the present invention which is defined by the appended claims.