US 6347389 B1 Abstract The pipelined high speed Reed-Solomon error/erasure decoder processes multiple code words in a pipelined fashion. The pipelined high speed Reed-Solomon error/erasure decoder is designed to process Reed-Solomon encoded words that have been corrupted in a digital system by processing errors as well as erasures through a simple iterative modified syndrome process. The iterative nature of this method provides for limited computational effort at each step of the pipeline. This allows the pipelined high speed Reed-Solomon error/erasure decoder to easily handle full or shortened Reed-Solomon codes, as well as parallel processing to achieve higher data rates. The iterative modified syndrome process is one of the pipelined steps. It relieves the erasure pre-shifting burden from the Berlekamp/Massey synthesis process, which reduces the number of cycles required at that stage of processing. The decoder proceeds classically with a Chien Search for any remaining error locations. This approach allows the pipelined high speed Reed-Solomon error/erasure decoder to relay early information on all error locations. The final stage of the decoding process is a parallel, iterative solution to Forney's equation for the calculation of the error magnitudes.
Claims(28) 1. A system for detecting and correcting both erasures and errors that are contained in a data transmission that includes multiple error correcting codes to identify said both erasures and errors, comprising:
means for storing said data transmission;
means, responsive to said data transmission, for generating syndrome data;
means, responsive to said data transmission and said generated syndrome data, for generating location data representative of error and erasure locations in said data transmission;
means, responsive to said generated syndrome data and said location data, for creating an associated error and erasure magnitude for each respective error and erasure location in said data transmission; and
means, responsive to said location data, said error and erasure magnitudes, and said data transmission, for correcting each said both erasures and errors contained in said data transmission.
2. The system for detecting and correcting both erasures and errors that are contained in a data transmission of
means for producing a digital indication that a code word symbol of said data transmission being received has been determined to contain an erasure; and
means, responsive to said digital indication, for identifying locations of said erasure in said code word symbol.
3. The system for detecting and correcting both erasures and errors that are contained in a data transmission of
means for creating an error locator polynomial that represents said errors contained in said data transmission;
means for determining roots of said error locator polynomial representing said errors; and
means for creating data indicative of error locations of said error in said data transmission.
4. The system for detecting and correcting both erasures and errors that are contained in a data transmission of
means for executing a Berlekamp/Massey process to create said error locator polynomial that represents said errors contained in said data transmission.
5. The system for detecting and correcting both erasures and errors that are contained in a date transmission of
means for executing a Chien Search process to determine said roots of said error locator polynomial.
6. The system for detecting and correcting both erasures and errors that are contained in a data transmission of
means for executing a Sigma process on said roots of said error locator polynomial.
7. The system for detecting and correcting both erasures and errors that are contained in a data transmission of
means for reading code words of said data transmission from said means for storing; and
means for correcting each said both erasures and errors contained in said code words in said data transmission using said error and erasure location and a corresponding said error and erasure magnitude.
8. The system for detecting and correcting both erasures and errors that are contained in a data transmission of
means for generating a set of syndrome data indicative of at least one erasure contained in said data transmission; and
means for modifying said set of syndrome data to generate modified syndrome data indicative of at least one error contained in said data transmission.
9. The system for detecting and correcting both erasures and errors that are contained in a data transmission of
means for iteratively activating said means for generating a set of syndrome data and said means for modifying said set of syndrome data to correct a plurality of erasures and errors contained in said data transmission.
10. A method for detecting and correcting both erasures and errors that are contained in a data transmission that includes multiple error correcting codes to identify said both erasures and errors, comprising the steps of:
storing said data transmission in a memory;
generating, in response to said data transmission, syndrome data;
generating, in response to said data transmission and said generated syndrome data, location data representative of error and erasure locations in said data transmission;
creating, in response to said generated syndrome data and said location data, an associated error and erasure magnitude for each respective error and erasure location in said data transmission; and
correcting, in response to said location data, said error and erasure magnitudes, and said data transmission, each said both erasures and errors contained in said data transmission.
11. The method for detecting and correcting both erasures and errors that are contained in a data transmission of
producing a digital indication that a code word symbol of said data transmission being received has been determined to contain an erasure; and
identifying locations of said erasure in said code word symbol.
12. The method for detecting and correcting both erasures and errors that are contained in a data transmission of
creating an error locator polynomial that represents said errors contained in said data transmission;
determining roots of said error locator polynomial representing said errors; and
creating data indicative of error locations of said error in said data transmission.
13. The method for detecting and correcting both erasures and errors that are contained in a data transmission of
executing a Berlekamp/Massey process to create said error locator polynomial that represents said errors contained in said data transmission.
14. The method for detecting and correcting both erasures and errors that are contained in a data transmission of
executing a Chien Search process to determine said roots of said error locator polynomial.
15. The method for detecting and correcting both erasures and errors that are contained in a data transmission of
executing a Sigma process on said roots of said error locator polynomial.
16. The method for detecting and correcting both erasures and errors that are contained in a data transmission of
reading code words of said data transmission from said means for storing; and
correcting each said both erasures and errors contained in said code words in said data transmission using said error and erasure location and a corresponding said error and erasure magnitude.
17. The method of detecting and correcting both erasures and errors that are contained in a data transmission of
generating a set of syndrome data indicative of at least one erasure contained in said data transmission; and
modifying said set of syndrome data to generate modified syndrome data indicative of at least one error contained in said data transmission.
18. The method of detecting and correcting both erasures and errors that are contained in a data transmission of
iteratively activating said step of generating a set of syndrome data and said step of modifying said set of syndrome data to correct a plurality of erasures and errors contained in said data transmission.
19. A system for detecting and correcting both erasures and errors that are contained in a data transmission that includes multiple error correcting codes to identify said both erasures and errors, comprising:
means for storing said data transmission;
means, responsive to said data transmission, for producing a digital indication that a code word symbol of said data transmission being received has been determined to contain an erasure;
means, responsive to said digital indication, for identifying locations of said erasure in said code word symbol;
means for generating data representative of error locations in said data transmission;
means for creating an associated error and erasure magnitude for each respective error and erasure location in said data transmission; and
means, responsive to said error and erasure locations, said error and erasure magnitudes, and said data transmission, for correcting each said both erasures and errors contained in said data transmission, comprising:
means for reading code words of said data transmission from said means for storing; and
means for correcting each said both erasures and errors contained in said code words in said data transmission using said error and erasure location and a corresponding said error and erasure magnitude.
20. The system for detecting and correcting both erasures and errors that are contained in a data transmission of
means for creating ah error locator polynomial that represents said errors contained in said data transmission;
means for determining roots of said error locator polynomial representing said errors; and
means for creating data indicative of error locations of said error in said data transmission.
21. The system for detecting and correcting both erasures and errors that are contained in a data transmission of
means for executing a Berlekamp/Massey process to create said error locator polynomial that represents said errors contained in said data transmission.
22. The system for detecting and correcting both erasures and errors that are contained in a data transmission of
means for executing a Chien Search process to determine said roots of said error locator polynomial.
23. The system for detecting and correcting both erasures and errors that are contained in a data transmission of
means for executing a Sigma process on said roots of said error locator polynomial.
24. A method for detecting and correcting both erasures and errors that are contained in a data transmission that includes multiple error correcting codes to identify said both erasures and errors, comprising the step of:
storing said data transmission in a memory;
producing, in response to said data transmission, a digital indication that the code word symbol of said data transmission being received has been determined to contain an erasure;
identifying locations of said erasure in said code word symbol;
generating data representative of error locations in said data transmission;
creating an associated error and erasure magnitude for each respective error and erasure location in said data transmission; and
correcting, in response to said error and erasure locations, said error and erasure magnitudes, and said data transmission, each said both erasures and errors contained in said data transmission, comprising:
reading code words of said data transmission from said means for storing; and
correcting each said both erasures and errors contained in said code words in said data transmission using said error and erasure location and a corresponding said error and erasure magnitude.
25. The method for detecting and correcting both erasures and errors that are contained in a data transmission of
creating an error locator polynomial that represents said errors contained in said data transmission;
determining roots of said error locator polynomial representing said errors; and
creating data indicative of error locations of said error in said data transmission.
26. The method for detecting and correcting both erasures and errors that are contained in a data transmission of
executing a Berlekamp/Massey process to create said error locator polynomial that represents said errors contained in said data transmission.
27. The method for detecting and correcting both erasures and errors that are contained in a data transmission of
executing a Chien Search process to determine said roots of said error locator polynomial.
28. The method for detecting and correcting both erasures and errors that are contained in a data transmission of
executing a Sigma process on said roots of said error locator polynomial.
Description This invention relates to a system that decodes a class of multiple error correcting codes known as Reed-Solomon Codes, which are typically used within digital communication systems to detect corrupted data contained in the digital transmission and correct these corrupted data. As part of the Reed-Solomon error correcting process, redundancy is added to the transmitted data, such that upon receipt of a data transmission, the possibly corrupted data and redundancy are mathematically processed to correct the corrupted data in the data transmission. It is a problem in high speed decoding of multiple error correcting codes, known as Reed-Solomon codes, with or without erasure pointers, to reduce the number of computational steps that are required at each stage of decoding. It is, likewise, a problem to reduce the number of combinatorial operations that are required to exchange data between any two hardware registers that are operational within the Reed-Solomon decoder. Reed-Solomon Codes are used within digital communication systems, such as fiber optic transmission systems, optical and magnetic data storage systems, where the corruption of data being transferred between any two points affects system reliability. As part of the Reed-Solomon error correcting process, redundancy is added to the transmitted data, such that upon receipt of a data transmission the possibly corrupt data and redundancy are mathematically processed to correct errors in the data transmission. Prior art Reed-Solomon decoders use both Berlekamp/Massey and Chien Search processes to detect and correct the errors that are present in the data transmission. These prior art Reed-Solomon decoders are primarily concerned with the total number of computations required to perform the data transmission decoding process, and the amount of hardware required to perform the data transmission decoding process. The Berlekamp/Massey synthesis process includes an erasure pre-shifting burden which adds to the processing complexity. These prior art Reed-Solomon decoders typically lack explicit early indication of error locations and do not provide early erasure information from the Berlekamp/Massey and Chien Search processes. The above described problems are solved and a technical advance achieved by the pipelined high speed Reed-Solomon error/erasure decoder of the present invention which processes multiple code words in a pipelined fashion. The piplelined high speed Reed-Solomon error/erasure decoder processes Reed-Solomon encoded data words to detect the presence of data words that have been corrupted in a digital system and processes corrupted data, that comprises both errors as well as erasures, through a simple iterative modified syndrome process. The iterative nature of this method provides for limited computational effort at each step of the pipeline. This allows the pipelined high speed Reed-Solomon error/erasure decoder to easily handle full or shortened Reed-Solomon codes, as well as parallel processing to achieve higher data rates. The iterative modified syndrome process is one of the pipelined steps. It relieves the erasure pre-shifting burden from the Berlekamp/Massey synthesis process, which reduces the number of cycles required at that stage of processing. The pipelined high speed Reed-Solomon error/erasure decoder then proceeds classically with a Chien Search for any remaining error locations. This approach allows the pipelined high speed Reed-Solomon error/erasure decoder to relay early information on all error locations. The final stage of the decoding process is a parallel, iterative solution to Forney's equation for the calculation of the error magnitudes. This pipelined high speed Reed-Solomon error/erasure decoder emphasizes the number of iterations (or clock cycles) and the number of combinatorial operations between each hardware register, which is accomplished by combining iterative LFSR solutions for syndrome modification and error magnitude processing to the well known Berlekamp/Massey and Chien Search iterative hardware solutions. Additionally, in augmenting the known erasure locations with a classic Berlekamp/Massey—Chien Search for any remaining error locations, the pipelined high speed Reed-Solomon error/erasure decoder also provides explicit early indication of all error locations. This can be helpful in providing early erasure information for errors that no erasure location was provided. FIG. 1 illustrates in block diagram form the pipelined high speed Reed-Solomon error/erasure decoder of the present invention; FIG. 2 illustrates in block diagram form the Error Locator Coefficient Generator (Sigma Processor) FIG. 3 illustrates in block diagram form the topology of the Modified Syndrome Processor hardware shift register; and FIG. 4 illustrates in block diagram form the circuit construction of the Errata Value Processor for generating each of the error magnitudes. In the encoding of an (n, k) Reed-Solomon code, k data symbols are processed for each n−k=r redundancy symbols. The maximum number of symbols in the code word, which are developed by appending the k data symbols to the r redundancy symbols, is determined by the size of the Galois Field that the Reed-Solomon code is based on. This finite field, known as GF (2 A Reed-Solomon decoder should handle corrupted data that comprises both erasures and errors to be effective in correcting data transmissions. When the location of corrupted data is know by any means that is external to a decoding process, it is called an erasure (e), and when the location of corrupted data is not know to the decoding process it is referred to as an error (t). Considering the minimum distance (r) of the redundancy code, for (r) symbols to be corrected, the location of each corrupted data byte must be known. The gives a code constraint of (2t+e≦d−1) for an erasure/error correcting Reed-Solomon decoder. The pipelined high speed Reed-Solomon error/erasure decoder In the case where both errors and erasures are considered by the Reed-Solomon decoding process, the syndrome includes the transform for both the (t) errors and (e) erasures: With the (e) know erasure locations, the pipelined high speed Reed-Solomon error/erasure decoder These coefficients are then processed in an iterative fashion to create the remaining modified transform syndromes T The modified transform syndromes T The coefficients of σ(X) are related to the erasure and error locations by the elementary symmetric functions σ Many decoding circuits for Reed-Solomon codes consider erasure pointers, but as disclosed in U.S. Pat. No. 5,379,305 (Lih-Jyh Weng), the decoder modifies the original transform syndromes for (p+e) erasures according to assumed precalculated coefficients. The pipelined high speed Reed-Solomon error/erasure decoder
where σ The recursion shifts to the highest possible order, shifting with zero for any missing erasure locations. In this way, the circuit always has the least significant coefficient (σ Similarly, the process of determining the error magnitudes requires the coefficients of the combined error locator polynomial σ(X). In the iterative solution of the above-noted U.S. Pat. No. 5,379,305, these coefficients are again needed. The pipelined high speed Reed-Solomon error/erasure decoder
The coefficients are retained in a shift register during the generation of the numerator, and used in a similar fashion to generate the denominator. The spirit of the pipelined high speed Reed-Solomon error/erasure decoder FIG. 1 depicts the complete pipelined high speed Reed-Solomon error/erasure decoder This is a well known process, that yields (2t) syndrome values which are output on data path The Modified Syndrome process Together with the original syndromes, the entire set of corrupted data locations {X With all the corrupted data locations {X In FIG. 2, the error location “X” register
where σ This corrupted data locator coefficient generator Each finite field multiplier is denoted by a circle with a dot in the middle. Likewise, each finite field adder is denoted by a circle with an addition or “+” sign contained within. The addition is simple modulo 2, per bit, while the multiplication is the classic multiplication of two finite field values modulo g(x) (where g(x) is the primitive polynomial which defines the finite field GF (2 FIG. 3 shows the topology of the Modified Syndrome Processor The register Ultimately, the Modified Syndrome Process FIG. 4 shows the circuit construction of the Errata Value Processor The first step in processing the error magnitudes is to generate the coefficients of the error locator polynomial {σ For the first (t) cycles, the σ For the second (t) cycles, the σ The pipelined high speed Reed-Solomon error/erasure decoder processes multiple code words in a pipelined fashion. The pipelined high speed Reed-Solomon error/erasure decoder processes Reed-Solomon encoded words that have been corrupted in a digital system. The pipelined high speed Reed-Solomon error/erasure decoder processes errors as well as erasures through a simple iterative modified syndrome process. The iterative nature of this processing method provides for limited computational effort at each step of the pipeline. This allows the pipelined high speed Reed-Solomon error/erasure decoder to easily handle full or shortened Reed-Solomon codes, as well as parallel processing to achieve higher data rates. Patent Citations
Non-Patent Citations
Referenced by
Classifications
Legal Events
Rotate |