US 7216285 B2 Abstract A method for generating a Cyclic Redundancy Check (CRC) in a system including steps of creating a circuit comprising a plurality of registers wherein each of the plurality of registers is associated with a corresponding logic gate, and programming a subset of the plurality of registers to have a value of zero and programming a corresponding subset of the logic gates to have a value of zero. The step of programming is based on a pre-selected polynomial key word.
Claims(80) 1. A method for generating a Cyclic Redundancy Check (CRC) in a system comprising the steps of:
creating a circuit comprising a plurality of registers wherein each of the plurality of registers is associated with a corresponding logic gate; and
programming a subset of the plurality of registers to have a value of zero and programming a corresponding subset of the logic gates to have a value of zero,
wherein the step of programming is based on a pre-selected polynomial key word.
2. The method as recited in
using a first set of multiplexers in conjunction with a first set of selection inputs for selecting at least one input for shifting data to a next shift register of the plurality of registers,
wherein the at least one input is a member of a set of inputs that includes an output from an adjacent logic gate and a straight shift input from an adjacent register of the plurality of registers.
3. The method as recited in
using a second set of multiplexers in conjunction with a second set of selection inputs for selecting at least one input to a corresponding logic gate,
wherein the at least one input is a member of a set of inputs that includes a primary input and a feedback input.
4. The method as recited in
using a second set of multiplexers in conjunction with a second set of selection inputs for selecting a final output from among output from the plurality of registers.
5. The method as recited in
6. The computer program of
7. A method for generating a Cyclic Redundancy Check (CRC) in a system, comprising the steps of:
creating a circuit comprising a plurality of registers wherein each of the plurality of registers is associated with a corresponding logic gate; and
programming a subset of the plurality of registers to have a value of zero and programming a corresponding subset of the logic gates to have a value of zero,
wherein the step of programming is based on a pre-selected polynomial key word, and
wherein the step of programming comprises:
programming a first set of selection inputs, wherein:
the step of programming the first set of selection inputs is based on the pre-selected polynomial key word;
the first set of selection inputs is associated with:
selecting corresponding input from each of the logic gates; and
a shift logic that is associated with the plurality of registers.
8. A method for generating a Cyclic Redundancy Check (CRC) in a system, comprising the steps of:
creating a circuit comprising a plurality of registers wherein each of the plurality of registers is associated with a corresponding logic gate; and
programming a subset of the plurality of registers to have a value of zero and programming a corresponding subset of the logic gates to have a value of zero,
wherein the step of programming is based on a pre-selected polynomial key word, and
wherein the step of programming comprises:
programming a second set of selection inputs, wherein:
the second set of selection inputs is associated with selecting corresponding input to each of the logic gates;
the second set of selection inputs is associated with the selecting a final output from among output from the plurality of registers; and
the step of programming the second set of selection inputs is based on the pre-selected polynomial key word.
9. A method for generating a Cyclic Redundancy Check (CRC) generator in a system comprising the steps of:
programming a first set of selection inputs, wherein:
the step of programming the first set of selection inputs is based on a pre-selected polynomial that is associated with the CRC generator;
the first set of selection inputs is associated with:
selecting corresponding input from each of the one or more logic gates; and
a shift logic that is associated with the plurality of registers; and programming a second set of selection inputs, wherein:
the second set of selection inputs is associated with selecting corresponding input to each logic gate;
the second set of selection inputs is associated with selecting a final output from among output from the plurality of registers; and
the step of programming the second set of selection inputs is based on the pre-selected polynomial that is associated with the CRC generator.
10. The method as recited in
using a first set of multiplexers in conjunction with the first set of selection inputs for selecting at least one input for shifting to a next register of the plurality of registers,
wherein the at least one input is a member of a set of inputs that includes an output from an adjacent logic gate and a straight shift from an adjacent register of the plurality of registers.
11. The method as recited in
using a second set of multiplexers in conjunction with the second set of selection inputs for selecting at least one input to a corresponding logic gate,
wherein the at least one input is a member of a set of inputs that includes a primary input and a feedback input.
12. The method as recited in
using a second set of multiplexers in conjunction with the second set of selection inputs for selecting the final output from among output from the plurality of registers.
13. The method as recited in
14. A computer-readable medium carrying one or more sequences of instructions for generating a Cyclic Redundancy Check (CRC) generator in a system, which instructions, when executed by one or more processors, cause the one or more processors to carry out the steps of:
programming a subset of the plurality of registers to have a value of zero and programming a corresponding subset of the logic gates to have a value of zero,
wherein the step of programming is based on a pre-selected polynomial key word.
15. A computer-readable medium carrying one or more sequences of instructions for generating a Cyclic Redundancy Check (CRC) generator in a system, which instructions, when executed by one or more processors, cause the one or more processors to carry out the steps of:
programming a first set of selection inputs, wherein:
the step of programming the first set of selection inputs is based on a pre-selected polynomial that is associated with the CRC generator;
the first set of selection inputs is associated with:
selecting corresponding input from each of the one or more logic gates; and
a shift logic that is associated with the plurality of registers; and
programming a second set of selection inputs, wherein:
the second set of selection inputs is associated with selecting corresponding input to each logic gate;
the second set of selection inputs is associated with selecting a final output from among output from the plurality of registers; and
the step of programming the second set of selection inputs is based on the pre-selected polynomial that is associated with the CRC generator.
16. An apparatus for creating a Cyclic Redundancy Check (CRC) generator in a system, comprising:
means for creating a circuit comprising a plurality of registers wherein each of the plurality of registers is associated with a corresponding logic gate; and
means for programming a subset of the plurality of registers to have a value of zero and programming a corresponding subset of the logic gates to have a value of zero,
wherein the step of programming is based on a pre-selected polynomial key word.
17. An apparatus for creating a Cyclic Redundancy Check (CRC) generator in a system, comprising:
means for creating a circuit comprising a plurality of registers wherein each of the plurality of registers is associated with a corresponding logic gate; and
means for programming a first set of selection inputs, wherein:
the step of programming the first set of selection inputs is based on a pre-selected polynomial that is associated with the CRC generator;
the first set of selection in puts is associated with:
selecting corresponding input from each of the one or more logic gates; and
a shift logic that is associated with the plurality of registers; and
means for programming a second set of selection inputs, wherein:
the second set of selection inputs is associated with selecting corresponding input to each logic gate;
the second set of selection inputs is associated with selecting a final output from among output from the plurality of registers; and
means for the step of programming the second set of selection inputs is based on the pre-selected polynomial that is associated with the CRC generator.
18. An apparatus for creating a Cyclic Redundancy Check (CRC) generator in a system, comprising:
a processor;
one or more stored sequences of instructions which, when executed by the processor, cause the processor to carry out the steps of:
programming a subset of the plurality of registers to have a value of zero and programming a corresponding subset of the logic gates to have a value of zero,
wherein the step of programming is based on a pre-selected polynomial key word.
19. An apparatus for creating a Cyclic Redundancy Check (CRC) generator in a system, comprising:
a processor;
one or more stored sequences of instructions which, when executed by the processor, cause the processor to carry out the steps of:
programming a first set of selection inputs wherein:
the first set of selection inputs is associated with:
selecting corresponding input from each of the one or more logic gates; and
a shift logic that is associated with the plurality of registers; and
programming a second set of selection inputs, wherein:
the second set of selection inputs is associated with selecting a final output from among out put from the plurality of registers; and
the step of programming the second set of selection inputs is based on the pre-selected polynomial that is associated with the CRC generator.
20. A cyclic redundancy check (CRC) generator for generating CRC codes, comprising:
a first set of N storage elements,
wherein a first selection signal is configured to select a subset of the first set of N storage elements, and
wherein each storage element of the subset of the first set of N storage elements corresponds to a term of a pre-selected CRC polynomial keyword; and
M logic circuits,
wherein an input of each of the M logic circuits is in communication with an output of a corresponding one of the first set of N storage elements, and
wherein a second selection signal is configured to select an output of one storage element of the subset of the first set of N storage elements corresponding to a length of the pre-selected CRC polynomial keyword.
21. The CRC generator of
wherein the length of the pre-selected CRC polynomial keyword is at most N.
22. The CRC generator of
a first plurality of selector circuits,
wherein each selector circuit of the first plurality of selector circuits is configured to output one of an output of a corresponding one of the M logic circuits and an output of a corresponding one of the first set of N storage elements, and
wherein each selector circuit of the first plurality of selector circuits is configured to receive the first selection signal based upon the pre-selected CRC polynomial keyword.
23. The CRC generator of
a second set of N storage elements,
wherein each storage element of the second set of N storage elements is in communication with a corresponding one of the first set of N storage elements, and
wherein each storage element of the second set of N storage elements is configured to provide the first selection signal to the corresponding one of the first set of N storage elements based upon the pre-selected CRC polynomial keyword.
24. The CRC generator of
25. The CRC generator of
a second plurality of selector circuits,
wherein each selector circuit of the second plurality of selector circuits is configured to output one of an output of a first subset of the first set of N storage elements and an output of a second subset of the first set of N storage elements, and
wherein one of the second plurality of selector circuits receives the second selection signal to select the output of the first subset of the first set of N storage elements for output.
26. The CRC generator of
a third set of selector circuits,
wherein the output of each selector circuit of the third set of selector circuits is in communication with an input of a corresponding one of the M logic circuits,
wherein each selector circuit of the third set of selector circuits is configured to output one of an output of a corresponding one of the second set of selector circuits and an input signal, and
wherein one of the third plurality of selector circuits receives the second selection signal to select the input signal for output.
27. The CRC generator of
28. The CRC generator of
an output selector circuit,
wherein inputs of the output selector circuit are in communication with outputs of each storage element of the first set of N storage elements, and
wherein the output selector circuit is configured to receive the second selection signal to select the output of the one storage element of the subset of the first set of N storage elements as the output of the CRC generator for the pre-selected CRC polynomial keyword.
29. The CRC generator of
30. The CRC generator of
31. The CRC generator of
32. The CRC generator of
33. The CRC generator of
34. A cyclic redundancy check (CRC) generator for generating CRC codes, comprising:
a first set of N means for storing data,
wherein a first selection signal is configured to select a subset of the first set of N data storing means, and
wherein each data storing means of the subset of the first set of N data storing means corresponds to a term of a pre-selected CRC polynomial keyword; and
M logic circuit means,
wherein an input of each of the M logic circuit means is in communication with an output of a corresponding one of the first set of N data storing means, and
wherein a second selection signal is configured to select an output of one data storing means of the subset of the first set of data storing means corresponding to a length of the pre-selected CRC polynomial keyword.
35. The CRC generator of
wherein the length of the pre-selected CRC polynomial keyword is at most N.
36. The CRC generator of
a first plurality of means for signal selecting,
wherein each signal selecting means of the first plurality of signal selecting means is configured to output one of an output of a corresponding one of the M logic circuit means and an output of a corresponding one of the first set of N data storing means, and
wherein each signal selecting means of the first plurality of signal selecting means is configured to receive the first selection signal based upon the pre-selected CRC polynomial keyword.
37. The CRC generator of
a second set of N means for storing data,
wherein each data storing means of the second set of N data storing means is in communication with a corresponding one of the first set of N data storing means, and
wherein each data storing means of the second set of N data storing means is configured to provide the first selection signal to the corresponding one of the first set of N data storing means based upon the pre-selected CRC polynomial keyword.
38. The CRC generator of
39. The CRC generator of
a second plurality of means for signal selecting,
wherein each signal selecting means of the second plurality of signal selecting means is configured to output one of an output of a first subset of the first set of N data storing means and an output of a second subset of the first set of N data storing means, and
wherein one of the second plurality of signal selecting means receives the second selection signal to select the output of the first subset of the first set of N data storing means for output.
40. The CRC generator of
a third set of means for signal selecting,
wherein the output of each signal selecting means of the third set of signal selecting means is in communication with an input of a corresponding one of the M logic circuit means,
wherein each signal selecting means of the third set of signal selecting means is configured to output one of an output of a corresponding one of the second set of signal selecting means and an input signal, and
wherein one of the third plurality of signal selecting means receives the second selection signal to select the input signal for output.
41. The CRC generator of
42. The CRC generator of
an output means for signal selecting,
wherein inputs of the output signal selecting means are in communication with outputs of each data storing means of the first set of N data storing means, and
wherein the output signal selecting means is configured to receive the second selection signal to select the output of the one data storing means of the subset of the first set of N data storing means as the output of the CRC generator for the pre-selected CRC polynomial keyword.
43. The CRC generator of
44. The CRC generator of
45. The CRC generator of
46. The CRC generator of
47. The CRC generator of
48. A method of generating cyclic redundancy check (CRC) codes, comprising the steps of:
a.) storing a first signal N times;
b.) logically combining each stored first signal with one of an input signal and a selected signal M times;
c.) selecting a subset of the N storing steps in response to a first selection signal, wherein each storing step of the subset of the N storing steps corresponds to a term of a pre-selected CRC polynomial; and
d.) selecting an output of one storing step of the subset of N storing steps corresponding to a length of the pre-selected CRC polynomial keyword, in response to a second selection signal.
49. The method of
wherein the length of the pre-selected CRC polynomial keyword is at most N.
50. The method of
e.) selecting one of an output of a corresponding one of the M logically combining steps and an output of a corresponding one of the N storing steps in response to the first selection signal.
51. The method of
f.) selecting one of an output of a first subset of the N storing steps and an output of a second subset of the N storing steps, in response to the second selection signal.
52. The method of
g.) selecting one of an output of step (f) and an input signal to form the selected signal, in response to the second selection signal.
53. The method of
e.) selecting the output of the one of the storing steps of the subset of N storing steps as the output of the pre-selected CRC polynomial keyword, in response to the second selection signal.
54. The method of
e.) receiving an input signal at one of the M logically combining steps.
55. The method of
56. The method of
57. The method of
58. A computer program for generating cyclic redundancy check (CRC) codes, wherein the computer program performs the steps of:
a.) controlling storing of a first signal N times;
b.) logically combining each stored first signal with one of an input signal and a selected signal M times;
c.) providing a first selection signal to select a subset of the N storing steps, wherein each storing step of the subset of the N storing steps corresponds to a term of a pre-selected CRC polynomial; and
d.) providing a second selection signal to select an output of one storing step of the subset of N storing steps corresponding to a length of the pre-selected CRC polynomial keyword.
59. The computer program of
wherein the length of the pre-selected CRC polynomial keyword is at most N.
60. The computer program of
e.) providing the first selection signal to select one of an output of a corresponding one of the M logically combining steps and an output of a corresponding one of the N storing steps.
61. The computer program of
f.) providing the second selection signal to select one of an output of a first subset of the N storing steps and an output of a second subset of the N storing steps.
62. The computer program of
g.) providing the second selection signal to select one of an output of step (f) and an input signal to form the selected signal.
63. The computer program of
e.) providing the second selection signal to select the output of the one of storing steps of the subset of the N storing steps as the output of the pre-selected CRC polynomial keyword.
64. The computer program of
e.) providing an input signal at one of the M logically combining steps.
65. The computer program of
66. The computer program of
67. A cyclic redundancy check (CRC) generator for generating CRC codes, comprising:
N CRC subcircuits,
wherein each of the N CRC subcircuits comprises:
a storage element;
a logic circuit in communication with the storage element; and
a first selector circuit in communication with an output of the storage element and an output of the logic circuit,
wherein an input of a storage element of an nth one of the N CRC subcircuits is in communication with an output of a first selector circuit of an n−1th one of the N CRC subcircuits,
wherein a first selection signal is configured to select a subset of the N CRC subcircuits, and
wherein each storage element of the subset of the N CRC subcircuits corresponds to a term of a pre-selected CRC polynomial keyword;
M selector subcircuits,
wherein each of the M selector subcircuits comprises:
a second selector circuit,
wherein a first input of the second selector circuit of an mth one of the M selector subcircuits is in communication with an output of a second selector circuit of an m+1th one of the M selector subcircuits, and
wherein a second input of the second selector circuit of the mth one of the M selector subcircuits is in communication with an output of a first selector circuit of the nth one of the N CRC subcircuits; and
a third selector circuit,
wherein a first input of the third selector circuit of the mth one of the M selector subcircuits is in communication with an output of the second selector circuit of the mth one of the M selector subcircuits, and
wherein a second input of the third selector circuit of the mth one of the M selector subcircuits is in communication with an input signal,
wherein the second and third selector circuits of one of the M selector subcircuits receive a second selection signal to select the second input of the respective second and third selector circuits for output; and
an output selector circuit,
wherein inputs of the output selector circuit are in communication with outputs of each storage element of the N CRC subcircuits, and
wherein the output selector circuit receives the second selection signal to select the output of one storage element of the subset of the N CRC subcircuits corresponding to a length of the pre-selected CRC polynomial keyword.
68. The CRC generator of
wherein an output of an Nth CRC subcircuit is in communication with the first input of the second selector circuit of the Mth selector subcircuit.
69. The CRC generator of
70. The CRC generator of
71. The CRC generator of
wherein each of the first, second and third selector circuits comprises a multiplexer.
72. A cyclic redundancy check (CRC) generator for generating CRC codes, comprising:
N CRC subcircuit means,
wherein each of the N CRC subcircuit means comprises:
a means for storing data;
a logic circuit means in communication with the data storing means;
a first means for signal selecting in communication with an output of the data storing means and an output of the logic circuit means,
wherein an input of a data storing means of an nth one of the N CRC subcircuit means is in communication with an output of a first signal selecting means of an n−1th one of the N CRC subcircuit means,
wherein a first selection signal is configured to select a subset of the N CRC subcircuit means, and
wherein each data storing means of the subset of the N CRC subcircuit means corresponds to a term of a pre-selected CRC polynomial keyword;
M selector subcircuit means,
wherein each of the M selector subcircuit means comprises:
a second means for signal selecting,
wherein a first input of the second signal selecting means of an mth one of the M selector subcircuit means is in communication with an output of a second signal selecting means of an m+1th one of the M selector subcircuit means, and
wherein a second input of the second signal selecting means of the mth one of the M selector subcircuit means is in communication with an output of a first signal selecting means of the nth one of the N CRC subcircuit means; and
a third means for signal selecting,
wherein a first input of the third signal selecting means of the mth one of the M selector subcircuit means is in communication with an output of the second signal selecting means of the mth one of the M selector subcircuit means, and
wherein a second input of the third signal selecting means of the mth one of the M selector subcircuit means is in communication with an input signal,
wherein the second and third signal selecting means of one of the M selector subcircuit means receive a second selection signal to select the second input of the respective second and third signal selecting means for output; and
an output means for signal selecting,
wherein inputs of the output signal selecting means are in communication with outputs of each data storing means of the N CRC subcircuit means, and
wherein the output signal selecting means receives the second selection signal to select the output of one data storing means of the subset of the N CRC subcircuit means corresponding to a length of the pre-selected CRC polynomial keyword.
73. The CRC generator of
wherein an output of an Nth CRC subcircuit means is in communication with the first input of the second signal selecting means of the Mth selector subcircuit means.
74. The CRC generator of
75. The CRC generator of
76. The CRC generator of
wherein each of the first, second and third signal selecting means comprises a multiplexer means.
77. A method of generating cyclic redundancy check (CRC) codes, comprising the steps of:
a.) shifting a first signal N times,
b.) exclusive or'ing each shifted first signal with one of an input signal and a selected signal M times;
c.) selecting one of an output of a corresponding one of the M exclusive or'ing steps and an output of a corresponding one of the N storing steps, in response to a first selection signal,
wherein an input of an nth one of the N shifting steps is in communication with an output of an n−1th one of the N selecting steps of step (c);
d.) selecting, M times, one of an output of a first subset of the N storing steps and an output of a second subset of the N storing steps, in response to a second selection signal,
wherein a first input of an mth one of the selecting steps of step (d) is in communication with an output of an m+1th one of the selecting steps of step (d), and
wherein a second input of the mth one of the selecting steps of step (d) is in communication with an output of an nth one of the selecting steps of step (c);
e.) selecting, M times, one of an output of step (d) and an input signal to form the selected signal, in response to the second selection signal;
f.) selecting a subset of the N storing steps in response to the first selection signal,
wherein each storing step of the subset of the N storing steps corresponds to a term of a pre-selected CRC polynomial; and
g.) selecting an output of one storing step of the subset of N storing steps corresponding to a length of the pre-selected CRC polynomial keyword as the output of the pre-selected CRC polynomial keyword, in response to the second selection signal.
78. The method of
wherein an output of an Nth selecting step of step (c) is in communication with the first input of an Mth selecting step of step (d).
79. A computer program for generating cyclic redundancy check (CRC) codes, wherein the computer program performs the steps of:
a.) controlling shifting of a first signal N times,
b.) exclusive or'ing each shifted first signal with one of an input signal and a selected signal M times;
c.) providing a first selection signal to select one of an output of a corresponding one of the M exclusive or'ing steps and an output of a corresponding one of the N storing steps,
wherein an input of an nth one of the N shifting steps is in communication with an output of an n−1th one of the N selectings of step (c);
d.) providing a second selection signal to select, M times, one of an output of a first subset of the N storing steps and an output of a second subset of the N storing steps,
wherein a first input of an mth one of the selectings of step (d) is in communication with an output of an m+1th one of the selectings of step (d), and
wherein a second input of the mth one of the selectings of step (d) is in communication with an output of an nth one of the selectings of step (c);
e.) providing the second selection signal to select, M times, one of an output of the selecting of step (d) and an input signal to form the selected signal;
f.) providing the first selection signal to select a subset of the N storing steps,
wherein each storing step of the subset of the N storing steps corresponds to a term of a pre-selected CRC polynomial; and
g.) providing the second selection signal to select an output of one storing step of the subset of N storing steps corresponding to a length of the pre-selected CRC polynomial keyword as the output of the pre-selected CRC polynomial keyword.
80. The method of
wherein an output of an Nth selecting of step (c) is in communication with the first input of an Mth selecting of step (d).
Description This application claims the priority benefit of U.S. Provisional Patent Application Ser. No. 60/338,137, filed Nov. 9, 2001, entitled, SYSTEM AND METHOD FOR GENERATING A CYCLIC REDUNDANCY CHECK. The invention generally relates to electronic systems. The invention relates more specifically to systems and methods for generating cyclic redundancy check. A popular method for error detection for digital signals is the Cyclic Redundancy Check (CRC). CRC works by treating the message string that is sent between a transmitter and a receiver as a single binary word. The single binary word is divided by a key word that is agreed upon by both the transmitter and the receiver ahead of time. The remainder that is left after dividing the single binary word by the key word is known as a check word. The transmitter sends both the message string and the check word to the receiver. The receiver then verifies the data by dividing the data by the key word. If the remainder, obtained by dividing the data by the key word, matches the check word, then the receiver can be sure that the data is indeed the correct message string from the transmitter. In the context of CRC, key words are usually numbers and are presented in the form of polynomials whose coefficients are in the form of the binary bits of the key word. A popular key word is X CRC is often implemented in hardware that is specific to a given polynomial key word. A CRC that is implemented in hardware is herein referred to as a CRC generator. Thus, a system that has to verify data using various different polynomial key words will need a separate CRC generator that is dedicated to each distinct polynomial key word. For example, In A system with multiple CRC generators can be unwieldy and inefficient. Based on the foregoing, it is clearly desirable to reduce the number of CRC generators in a given system. It is further desirable to have a programmable CRC generator so that the CRC generator can be dynamically changed to accommodate different applications. Techniques are provided for creating a Cyclic Redundancy Check generator in a system. According to one aspect of the invention, a universal N-bit capable CRC generator is created and programmed to adapt to any given polynomial key word. According to one feature, the N-bit capable CRC generator comprises N shift registers that are associated with corresponding exclusive OR gates (XOR gates). Each of the shift registers corresponds to a term of a general N In other aspects, the invention encompasses a computer apparatus, a computer readable medium, and a carrier wave configured to carry out the foregoing steps. An advantage of using an N-bit capable CRC generator is that it can dynamically programmed to accommodate a new polynomial key word rather than having build a new CRC generator for each new polynomial key word. The present invention is illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings and in which like reference numerals refer to similar elements and in which: A system and method for generating a cyclic redundancy check is described. In the following description, for the purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the present invention. It will be apparent, however, to one skilled in the art that the present invention may be practiced without these specific details. In other instances, well-known structures and devices are shown in block diagram form in order to avoid unnecessarily obscuring the present invention. Embodiments are described herein according to the following outline: -
- 1.0 OPERATIONAL CONTEXT AND FUNCTIONAL OVERVIEW
- 2.0 N-BIT CAPABLE CRC GENERATOR
- 3.0 ILLUSTRATIVE EXAMPLE OF THE FLEXIBILITY OF AN N-BIT CAPABLE CRC GENERATOR
- 5.0 EXTENSIONS AND ALTERNATIVES
1.0 Operational Context and Functional Overview
In certain embodiments of the present invention, a universal CRC generator is used in a system that receives digital signals. The universal CRC generator can be programmed to be a specific polynomial key word CRC generator. Thus, one set of hardware can be adapted for any given polynomial key word. For example, for purposes of explanation, assume that a transmitter of a bitstream and a receiver of the same bitstream agree upon a key word that can be represented by the polynomial, X Thus, in certain embodiments of the present invention, the universal CRC generator is a CRC generator that is capable of being a N-bit CRC generator, where N is a positive integer that is selected corresponding to the highest order polynomial key word that the universal CRC generator is expected to use. A universal generator that is capable of being an N-bit CRC generator is herein referred to as an N-bit capable CRC generator. According to certain embodiments of the present invention, the universal CRC generator can be re-programmed to correspond to a new polynomial key word by programming the values of certain programmable registers that are part of the universal CRC generator and by programming certain selection inputs for multiplexers that are also part of the universal CRC generator. The programming of the registers and selection inputs for the multiplexers are explained in greater detail herein. 2.0 N-Bit Capable CRC Generator According to certain embodiments of invention, List A: 1) N+1 number of shift registers, namely, X 2) N+1 number of exclusive-OR gates, namely, XOR 3) 3N+1 number of multiplexers, namely, M 4) N+1 programmable registers, namely, Y The broken line List B: 1) shift registers X 2) exclusive-OR gates XOR 3) multiplexes M 4) programmable registers Y Each of the shift registers X is communicatively coupled to a corresponding exclusive-OR gate (XOR gate) and to adjacent multiplexers M. For example, in Further, each of the shift registers X in Similarly, shift register X Shift register X Further, all shift registers X Each XOR gate is additionally communicatively coupled to corresponding adjacent multiplexers. For example, in Similarly, XOR gate XOR Programmable registers Y For simplicity, programmable registers Y The Y registers are programmed based on the given polynomial key word. To explain, each Y register in the N-bit capable CRC generator is associated with one term in the general N Each Y register corresponds to one coefficient of the general N The Y registers that correspond to coefficients that have a value of zero are programmed to have a bit value of zero. The Y registers that correspond to coefficients that have a value of 1 are programmed to have a bit value of 1. The value of each bit in the Y register determines which input is selected at the corresponding multiplexer to be an output. For example, if programmable register Y For ease of explanation, multiplexers with the same superscript as illustrated in Selection inputs such as, Last-X Further, all selection inputs, namely, Last-X For simplicity in explaining the function of the components in Generally, selection inputs such as, Last-X In Since the given polynomial key word is a q The value of each selection input, such as Last-X For example, if selection input Last-X As explained herein, there is no Last-X In Even though there is no Last-X Additionally, multiplexers with the subscript b, such as M Multiplexers with the subscript c each receive a primary input, P All multiplexers in the N-bit capable CRC generator have 2 input lines. One input line is labeled 1 and the other input line is labeled 0 as indicated in The arrangement of the components in List B, i.e. the components that not shown in 3.0 Illustrative Example of the Flexibility of an N-Bit Capable CRC Generator Typically, N is equal to 64 or larger for the universal CRC generator. However, for simplicity of explanation, assume that that N=3 for the N-bit capable CRC generator. In Further, shift register X Similarly, shift register X Shift register X Shift register X Further, all shift registers X Each XOR gate is additionally communicatively coupled to either one or two corresponding adjacent multiplexers. In Similarly, XOR gate, XOR XOR gate, XOR XOR gate, XOR Programmable registers Y For example, programmable register Y For ease of explanation, multiplexers with the same superscript as illustrated in Similarly, M M However, M Inputs Last-X Additionally, multiplexers with the subscript b, such as M As a first illustration, assume that a CRC generator is needed to implement a given The 3-bit capable CRC described with reference to Referring to Similarly, programmable register Y Programmable register Y Programmable register Y The Last-X selection inputs are programmed to be a specific value based on the most significant bit (MSB). Similarly, bit Since the first occurring 1 bit corresponds to the value of the Y The value of each Last-X selection input determines which input is selected at the corresponding multiplexers to be output from said multiplexers. For example, since selection input Last-X In Thus, by programming the Y registers and the Last-X selection inputs as described above, the 3-bit capable CRC generator is equivalent to the CRC generator as described in Further, the same 3-bit capable CRC generator can be programmed to implement a given polynomial key word that is of an order that is lower than 3. Assume that the given polynomial is as follows:
For purposes of explanation, the given polynomial key word, X In Similarly, programmable register Y Programmable register Y Programmable register Y The Last-X selection inputs are programmed to be a specific value based on the most significant bit (MSB) of the Y registers. Bit Since the first occurring 1 bit corresponds to the value of register Y The value of each Last-X selection input determines which input is selected at the corresponding multiplexers to be output from said multiplexers. Referring back to In contrast, since selection input Last-X In Thus, by programming the Y registers and the Last-X selection inputs as described above, the 3-bit capable CRC generator 5.0 Extensions and Alternatives In the foregoing specification, the invention has been described with reference to specific embodiments thereof. It will, however, be evident that various modifications and changes may be made thereto without departing from the broader spirit and scope of the invention. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense. Patent Citations
Referenced by
Classifications
Legal Events
Rotate |