This application is based on and claims the benefit of priority from the prior Japanese Patent Application No. 2007-210659, filed on Aug. 13, 2007, the entire contents of which are incorporated herein by reference. U.S. Pat. No. 7,369,433 is incorporated herein by reference in its entirety.
1. Field of the Invention
This invention relates to a memory device with an error correction system configured to be 4-bit error correctable.
2. Description of the Related Art
As a memory device is miniaturized and has a great capacity, the data retention characteristic (i.e., data reliability) is reduced. Specifically, in case a multi-level data storage scheme is adapted to the memory device, the data retention property will become a large problem. In a phase change memory and a resistance change memory, which are expected to succeed a conventional NAND-type flash memory, there is such a problem that a data state is not stable, and it is difficult to secure the data retention reliability.
Therefore, it becomes a material technology to form an ECC (Error Correcting Code) system in a memory chip for error-detecting and correcting read data prior to data outputting.
There has already been proposed such a technology that an ECC circuit is built in a flash memory chip or memory controller thereof (for example, JP-A-2000-173289).
If error location search in a BCH-ECC system, which is constituted by use of Galois field (finite field) GF(2n) to perform error-correction for 2-bit or more errors, is performed in such a manner as to substitute elements of the Galois field one by one and select them as solutions satisfying an error location searching equation, thereby searching an error location, the arithmetic operation time will be very long.
Even if the ECC system is formed as on-chip type one, this leads to great reduction of the read/write performance.
Therefore, it is required of us to achieve a high speed ECC system, which does not sacrifice the performance of a conventional flash memory without the above-described one by one searching.
According to an aspect of the present invention, there is provided a memory device with an error detection and correction system formed therein, the error detection and correction system being configured to detect and correct errors in read out data by use of a BCH code, wherein
the error detection and correction system is 4-bit error correctable, and searches error locations in such a way as to: divide an error location searching biquadratic equation into two or more factor equations; convert the factor equations to have unknown parts and syndrome parts separated from each other for solving them; and compare indexes of the solution candidates with those of the syndromes, the corresponding relationships being previously obtained as a table, thereby obtaining error locations.
According to another aspect of the present invention, there is provided a method of testing a memory device with an error detection and correction system formed therein, the error detection and correction system being configured to detect and correct errors in read out data by use of a BCH code, including:
adding an error data pattern to an information data code to be input to the memory device;
passing the information data code with the error data pattern added through the error detection and correction system without writing it into a memory core; and
testing whether the information data code with the error data pattern added is corrected or not.
According to still another aspect of the present invention, there is provided a memory system including:
a memory device;
an error detection and correction system installed in the memory device to detect and correct errors in read out data by use of a BCH code, the error detection and correction system having such a function as to generate a non-correctable signal for non correctable errors; and
a contents addressable memory configured to store the corresponding relationship between a bad block address of the memory device and a to-be-replaced block address in accordance with the non-correctable signal, and send the to-be-replaced block address to the memory device in place of the bad block address when it is accessed.
To make a memory equipped with an ECC system, high speed calculation processing is required because it is in need of performing real time data correction. It is well known that ECC with BCH code is effective against random error generation. However, in the prior arts, it has not been known high speed and 4-bit error correctable ECC. Therefore, in the present invention, there will be provided an on-chip and high speed 4-bit error correctable ECC system to be installed in a memory device.
To perform error detecting operation at a high rate with a BCH code, a solution table is previously formed, and syndromes calculated from the read data are compared with the table, so that a solution will be obtained. A key technology for the above-described data comparison is in that a to-be-solved polynomial may be divided into an unknown quantity part (variable part) and a syndrome part by use of variable conversion.
In a 4-bit error correctable BCH code system, an error searching equation is expressed as a biquadratic equation, in which unknown numbers and syndromes are mixed. Therefore, translate the biquadratic equation to the product of quadratic equations by use of certain parameters, and the method of solving the equation results in that factor equations with lower degrees (for example, second and third degrees) are subjected to the solution processing.
By use of this conversion scheme, it is possible to separate the variables and syndromes from each other. Further, when comparing finite field elements of BCH code with the solution table, a so-called “expression index” is put in, so that error searching may be done as parallel operations with short calculation times at a high rate.
Equipping the ECC system described above in a memory device, there will be provided a memory system, which has been improved apparently in the data retention reliability without reducing the memory performance.
The outline of the embodiments to be described below is follows:
[Explanation of the Principle of 4EC-EW(4 Error Correction-Error Warning)-BCH System]
Data Encoding
The system principle will be explained with respect to a general case of Galois field GF(2n), and then an application system with GF(256) will be explained in detail.
Assume here that a primitive irreducible polynomial on GF(2) is referred to as m1(x), and its root (primitive root) is α. In consideration of finite field GF(2n), m1(x) becomes an n-th degree polynomial. Using this α, there are 2n elements of GF(2n) as follows: 0, α0, α1, . . . , αh−2 and αh−1 (where h=2n−1).
To do 4-bit error detection and correction, as shown in the following expression, Exp. 1, m1(x), m3(x), m5(x) and m7(x) are selected as four primitive irreducible polynomials having roots of α1, α3, α5 and α7.
α1:m1(α1)=0
α3:m3(α3)=0
α5:m5(α5)=0
α7:m7(α7)=0 [Exp. 1]
Based on these irreducible polynomials, 4n-th degree code generation polynomial g(x) is obtained as shown in the following expression Exp. 2.
g(x)=m1(x)m3(x)m5(x)m7(x) [Exp. 2]
Since the number of elements constituting the code of ECC system is “h” except zero factors, coefficients of (h−1)th degree polynomial constitute data. That is, information polynomial f(x) is expressed as follows.
f(x)=ah−1xh−1−4n+ahxh−2−4n+ . . . +a4n+2x2+a4n+1x+a4n [Exp. 3]
Assigning the information bits in data bits to the coefficients a4n to ah−1, and dividing the 4n-th degree polynomial f(x)x4n by g(x), surplus r(x) is obtained as shown in the following expression Exp. 4.
f(x)x4n=q(x)g(x)+r(x)
r(x)=b4n−1x4n−1+b4n−2x4n−2+ . . . +b1x+b0 [Exp. 4]
As described above, r(x) is a (4n−1)th degree polynomial, and coefficients thereof serve as check bits b4n−1 to b0, which constitute data to be stored together with the information bits a4n to ah−1.
Data Decoding
Errors generated on the data bits are expressed by (h−1)th degree error polynomial e(x). Data polynomial ν(x) corresponding to the read out data of the memory is expressed together with the error polynomial e(x) as follows.
The terms with coefficient “1” in the error polynomial e(x) are error bits, and to search the error bits becomes error detection.
At a first stage, divide ν(x) by m1(x), m3(x), m5(x) and m7(x), and obtain surplus or remainder polynomials S1(x), S3(x), S5(x) and S7(x), respectively. These also are surplus of e(x), and referred to as syndrome polynomials as shown in the following expression Exp. 6.
ν(x)≡S1(x)mod m1(x)→e(x)≡S1(x)mod m1(x)
ν(x)≡S3(x)mod m3(x)→e(x)≡S3(x)mod m3(x)
ν(x)≡S5(x)mod m5(x)→e(x)≡S5(x)mod m5(x)
ν(x)≡S7(x)mod m7(x)→e(x)≡S7(x)mod m7(x) [Exp. 6]
If 4-bit errors are located at the degree numbers “i”, “j”, “k” and “l”, the error polynomial e(x) will be expressed by the following expression Exp. 7.
e(x)=xi+xj+xk+xl [Exp. 7]
Searching the degree numbers “i”, “j”, “k” and “l”, error locations are obtained, i.e., error bits in data are determined. Therefore, perform index calculation with respect to the roots of m1(x)=0 on Galois field GF(2n), and “i”, “j;”, “k” and “l” will be obtained.
For this purpose, assume that the remainder obtained by dividing xn by m1(x) is referred to as pn(x). Since αn=pn(α) on this assumption, define the following X1, X2, X3 and X4, and syndromes S1, S3, S5 and S7 are shown in the expression Exp. 8.
X1=pi(α)=αi
S1=S1(α)=ασ1
X2=pj(α)=αj
S3=S3(α3)=ασ3
X3=pk(α)=αk
S5=S5(α5)=ασ5
X4=pl(α)=αl
S7=S7(α7)=ασ7 [Exp. 8]
Based on the above-described definition, the following relationships will be obtained.
e(α)=X1+X2+X3+X4=S1
e(α3)=X13+X23+X33+X43=S3
e(α5)=X15+X25+X35+X45=S5
e(α7)=X17+X27+X37+X47=S7 [Exp. 9]
As shown in Exp. 8, indexes of X1, X2, X3 and X4 are “i”, “j”, “k” and “l”, respectively, and indexes of S1, S3, S5 and S7 are σ1(=σ), σ3, σ5 and σ7, respectively.
As a second stage, consider a polynomial ΛR(x) on GF(2n) that has unknown quantities X1, X2, X3 and X4 as shown in the following expression Exp. 10.
The respective coefficient parameters “S”, “D”, “T” and “Q” are, as shown in the expression Exp. 11, expressed by basic symmetric polynomials with respect to X1, X2, X3 and X4.
S=S1=X1+X2+X3+X4
D=X1X2+X2X3+X3X4+X4X1+X1X3+X2X4
T=X1X2X3+X2X3X4+X4X1X2
Q=X1X2X3X4 [Exp. 11]
There are relationships between the above-described coefficients and syndromes (i.e., symmetric polynomials) S1=S, S3, S5 and S7. These relationships are as shown in the following expression Exp. 12, and constitute simultaneous equations.
SD+T=ζ
(ζ+S3)D+S2T+SQ=η
(η+S5)D+S4T+(ζ+S3)Q=θ [Exp. 12]
To express “D”, “T” and “Q” with syndromes, solve the above-described ternary simultaneous equations. With determinant ┌, the simultaneous equations will be solved as follows.
┌=S3ζ+Sη+ζ2
┌D=S3η+S2ζ2+Sθ+ζη
┌T=S4η+S2θ+ζ3
┌Q=S4ζ+S2ζη+ζθ+η2 [Exp. 13]
If ┌≠0, “D”, “T” and “Q” are decided, and then go to the successive stage for solving the error location searching equation shown in the expression Exp. 14.
(x)=x4+Sx3+Dx2+Tx+Q=0 [Exp. 14]
In case of ┌=0, as known as solving method of simultaneous equations, substituting an optional value for one of the unknown quantities, “Q”, it is possible to look for “D” and “T”. However, if just four errors are generated, there are no optional relationships between “S”, “D” and “T”. Therefore, this case designates either five or more errors, or three or less error.
In case of three errors, X4=0, then Q=0, thereby resulting in the following quadratic simultaneous equations, and “D” and “T” may be solved.
SD+T=ζ
(ζ+S3)D+S2T=η [Exp. 15]
In case of Sζ≠0, D=ζ/S, and T=0, then it designates that there are two errors.
In case of Sζ=0, since ζ is a coefficient determinant of quadratic simultaneous equations, if S≠0 and ζ=0, then it is possible to obtain “D” by substituting an optional value for “T”. If there are generated three errors, there is not an optional relationship between “S”, “D” and “T”. Therefore, this case designates either five errors or two or less error.
In case of two or less error, X3=0, then “D” will be obtained by substituting T=0.
In case of ┌=0, ζ=0 and T=0, the above-described simultaneous equations result in SD=0. Since “S” is not zero, D=0, i.e., it designates one error (X1=S). In this case, ζ=η=θ=0 is brought out, then Q=0 is obtained. This excludes the possibility of five or more errors.
In case of S=0, since ζ=0, then T=0, and this designates two or less error. From S=X1+X2=0, the possibility of one error is excluded, it results in zero error (no error).
In the above description, all solution methods of the simultaneous equations have been explained briefly, and in case there is not obtained a solution in the error searching branches, it designates that there are five or more errors.
Next, with respect to the branched cases (1) to (9), the solution method of the biquadratic equation will be explained in detail in accordance with the quantity relationship defined by the syndromes. The biquadratic equation to be solved is shown in the expression Exp. 14.
(1) In case of S≠0, ┌≠0, b≠0 and c≠0:
Note here that a=D/S, b=D2+ST, c=S2Q+SDT+T2 and B=a4+Ta+Q.
As shown in the expression Exp. 16, the error location searching biquadratic equation is subjected to variable conversion of X=x+a, and factorized to be expressed as the product of two quadratic equations.
Based on the relationships between the coefficients α0, α1, β0, β1 of the factorized quadratic equations and the quantities brought out syndromes, and using unknown quantity δ=α0+β0, a cubic equation is obtained to be satisfied with δ as shown in the expression Exp. 17. Note here that α0+β0=δ, α0β0=B, β1α0+α1β0=b/S, δ+α1β1=0 and α1+β1=S.
(δ/b1/2)3+(δ/b1/2)+c/b3/2=0 [Exp. 17]
Solve this equation, and select one root δ, and two quadratic equations are obtained as shown in the following expression Exp. 18, which are satisfied with the factorization coefficients.
(ε/δ)2+(ε/δ)+B/δ2=0
(ε/S)2+(ε/S)+δ/S2=0 [Exp. 18]
Solve these equations, and coefficients α0, α1, β0 and β1 are obtained. By use of these coefficients, the following factor equations, two quadratic equations, are obtained to be solved as shown in the expression Exp. 19.
(x/α1)2+(x/α1)+α0/α12=0
(x/β1)2+(x/β1)+β0/β12=0 [Exp. 19]
Solve these equations to look for the unknown quantity, and four solutions of the error searching biquadratic equation will be obtained by use of X=x+a.
Note here that when solving the respective equations, to be able to use solution tables, coefficients of the unknown quantities are converted to be elements on GF(2). That is, the unknown quantities are set as follows: δ/b1/2 in the cubic equation (Exp. 17) for looking for δ; ε/δ in the quadratic equation (Exp. 18) for looking for α0, β0; ε/S in the quadratic equation (Exp. 18) for looking for α1, β1; and x/α1, x/β1 in the quadratic factor equations (Exp. 19).
(2) In case of S≠0, ┌≠0, b≠0 and c=0:
Note here that a=D/S, b=D2+ST, B=a4+Ta+Q, and S2Q+SDT+T2=0, S4B=b2.
Subjected to the variable conversion of X=x+a, the term of the second degree is removed from the error location searching equation, and the resultant is factorized into a product of two quadratic equations as shown in Exp. 20.
Based on the relationships between the coefficients α0, α1, β0, β1 of the factorized quadratic equations and the quantities brought out syndromes, and using unknown quantity δ=α0+β0, a cubic equation is obtained to be satisfied with δ as shown in the expression Exp. 21. Note here that α0+β0=δ, α0β0=B, β1α0+α1β0=b/S, δ+α1β1=0 and α1+β1=S.
δ3+bδ=0 [Exp. 21]
Solve this equation, and select one root δ (≠0), i.e., b1/2, and two quadratic equations are obtained as shown in the following expression Exp. 22, which are satisfied with the factorization coefficients.
(ε/δ)2+(ε/δ)+B/δ2=0
(ε/S)2+(ε/S)+δ/S2=0 [Exp. 22]
Solve these equations, and coefficients α0, α1, β0 and β1 are obtained. Note here that since B/δ2=(δ/S2)2, α0/δ=(α1/S)2 and β0/δ=(β1/S)2 are obtained. The following factor equations, two quadratic equations, with the coefficients are to be solved as shown in the expression Exp. 23.
(x/α1)2+(x/α1)+α0/α12=0
(x/β1)2+(x/β1)+β0/β12=0 [Exp. 23]
Solve these equations to look for the unknown quantity “x”. As a result, solutions of the error searching biquadratic equation will be obtained by use of X=x+a. As expressed above, since α0/α12=β0/β12=δ/S2, four roots of the biquadratic equation are obtained with the relationships of u1=α1/S, u2=β1/S, as shown in the expression Exp. 24.
X1=α1u1+a=α12/S+a
X2=α1u2+a=α1β1/S+a=δ/S+a
X3=β1u1+a=α1β1/S+a=δ/S+a
X4=β1u2+a=β12/S+a [Exp. 24]
As expressed in Exp. 24, X2=X3, then it results in that three errors are searched.
Note here that δ=0 also satisfies the condition for solving the equation. However, the calculation process becomes different from the above-described one, and the calculation process explained in the above-described condition (1) is not adaptable. Therefore, this case is not selected here.
As similar to the case (1), to use solution tables, coefficients of the unknown quantities are converted to be elements on GF(2). That is, the unknown quantities are set as follows: ε/δ in the quadratic equation (Exp. 22) for looking for α0, β0; ε/S in the quadratic equation (Exp. 22) for looking for α1, β1; and x/α1, x/β1 in the quadratic factor equations (Exp. 23).
(3) In case of S≠0, ┌≠0, b=0 and c≠0:
Note here that a=D/S, c=S2Q+SDT+T2, B=a4+Ta+Q, and D2+ST=0, S2B=c.
Subjected to the variable conversion X=x+a, the term of the second degree is eliminated from the error search equation, and the resultant is factorized into a product of two quadratic equations as shown in Exp. 25.
Based on the relationships between the coefficients α0, α1, β0, β1 of the factorized quadratic equations and the quantities brought out syndromes, and using unknown quantity δ=α0+β0, a cubic equation is obtained to be satisfied with δ as shown in the expression Exp. 26. Note here that α0+β0=δ, α0β0=B, β1α0+α1β0=0, δ+α1β1=0 and α1+β1=S.
δ3+c=0 [Exp. 26]
By use of δ=c1/3, two quadratic equations to be satisfied with the factorization coefficient are obtained as shown in the following expression Exp. 27.
(ε/δ)2+(ε/δ)+B/δ2=0
(ε/S)2+(ε/S)+δ/S2=0 [Exp. 27]
Solve these equations, and coefficients α0, α1, β0 and β1 are obtained. Since, in this case, B/δ2=δ/S2 is obtained from the condition shown in Exp. 26, the root of a quadratic equation for solving α1 and β1 is the same as that of another quadratic equation for solving α0 and β0, i.e., u1=α0/δ=α1/S and u2=β0/δ=β1/S, and two quadratic equations become substantially identical with each other. That is, to-be-solved equations are expressed as the following expression Exp. 28.
(x/α1)2+(x/α1)+α0/α12=0
(x/β1)2+(x/β1)+β0/β12=0 [Exp. 28]
When the unknown quantity “x” is obtained from the equations, the solution of the biquadratic error search equation will be solved by use of X=x+a. At this time, in accordance with α0/α12=δ/(S2u1) and β0/β12=/(S2u2) obtained from the above-described relationships, four solutions are obtained.
Like the case (1), to be able to use a solution table when solving the respective equations, coefficients of the unknown quantities are converted to elements on GF(2). That is, the unknown quantities are replaced as follows: ε/δ in the quadratic equation for looking for α0, β0; ε/S in the quadratic equation for looking for α1, β1; and x/α1, x/β1 in the quadratic factor equations.
(4) In case of S≠0, ┌≠0, b=0 and c=0:
Note here, a=D/S, B=a4+Ta+Q, D2+ST=0, S2Q+SDT+T2=0 and S2B=0.
Subjected to the variable conversion X=x+a, and eliminate the term of the second degree, the following expression Exp. 29 is obtained.
x4+Sx3=0. [Exp. 29]
Two solutions, X1=a and X2=S+a, will be obtained from this equation.
(5) In case of S≠0, ζ≠0 and ┌=0:
Only when Q=0, there are four errors or less. If there is not a solution in the above-described case, there are five or more errors, and D=ζ/S and T=0 are obtained.
The error location searching biquadratic equation results in the following quadratic equation.
X2+SX+ζ/S=0 [Exp. 30]
Solve this equation, and two solutions will be obtained. To be able to use a solution table when solving the equation, coefficients of the unknown quantities are converted to elements on GF(2). That is, X/S is dealt with the unknown quantity.
(6) In case of S≠0, ┌=0 and ζ=0:
T=0, and D=0 from SD+T=ζ, and further Q=0. Therefore, the error searching equation will be expressed as follows.
X4+SX3=0 [Exp. 31]
From this equation, as one solution except zero, X1=S is obtained.
(7) In case of ┌≠0, D≠0 and S=0:
ζ≠0 and η≠0 from ┌D≠0, and ┌=ζ2, D=η/ζ, T=ζ, Q=η2/ζ2+θ/ζ, b=D2 and c=T2.
As expressed in Exp. 32, the term of the third degree is removed from the error searching equation, and it is factorized to a product of quadratic equations.
Based on the relationships between the coefficients α0, α1, β0, β1 of the factorized quadratic equations and the quantities brought out syndromes, using unknown quantity δ=α0+β0, and α0β0=Q, β1α0+α1β0=T, δ+α1β1=D and α1+β1=0, a cubic equation is obtained to be satisfied with δ/D+1 as shown in the expression Exp. 33.
(δ/D+1)3+(δ/D+1)+c/b3/2=0 [Exp. 33]
This is a cubic equation without the secondary term, which is similar to that used in other cases. Solve this equation to look for a root as δ, and two quadratic equations are obtained to be satisfied with the factorized coefficient as shown in the following expression Exp. 34.
(ε/δ)2+(ε/δ)+Q/δ2=0
ε2+δ+D=0 [Exp. 34]
Solve these equations, and coefficients α0, α1, β0 and β1 are obtained. The equation with roots of α1 and β1 is easily solved, and α1=β1=(δ+D)1/2 is obtained.
Next, solve the following quadratic equations with the above-described coefficients shown in Exp. 35.
(X/α1)2+(X/α1)+α0/α12=0
(X/α1)2+(X/α1)+β0/α12=0 [Exp. 35]
As a result, the unknown quantity “X” will be obtained as four solutions of the error searching equation.
Like the case (1), to be able to use a solution table when solving the respective equations, coefficients of the unknown quantities are converted to elements on GF(2). That is, the unknown quantities are replaced as follows: ε/δ in the quadratic equation for looking for α0, β0; and X/α1 in the quadratic factor equation.
(8) In case of ┌=0, S=0 and D=0:
ζ≠0 from ┌≠0, η=0 from S=D=0, and ┌=ζ2, D=η/ζ, T=ζ, c=T2, D=0 and Q=θ/ζ. The error searching equation becomes one without the second term and the third term, as follows.
Based on the relationships between the coefficients α0, α1, β0, β1 of the factorized quadratic equations and the quantities brought out syndromes, using unknown quantity δ=α0+β0 and α0β0=Q, β1α0+α1β0=T, δ+α1β1=D and α1+β1=0, a cubic equation is obtained to be satisfied with δ as shown in the expression Exp. 37.
δ3+c=0 [Exp. 37]
This equation is easily solved, and δ=c1/3 is obtained. Based on this δ, the following two quadratic equations are obtained to be satisfied with factorization coefficients.
(ε/δ)2+(ε/δ)+Q/δ2=0
ε2+δ=0 [Exp. 38]
Next, solve the following quadratic equations with the above-described coefficients shown in Exp. 39.
(X/α1)2+(X/α1)+α0/α12=0
(X/α1)2+(X/α1)+β0/α12=0 [Exp. 39]
As a result, the unknown quantity “X” will be obtained as four solutions of the error searching equation.
Like the case (1), to be able to use a solution table when solving the respective equations, coefficients of the unknown quantities are converted to elements on GF(2). That is, the unknown quantities are set as follows: ε/δ in the quadratic equation for looking for α0, β0; and X/α1 in the quadratic factor equation.
(9) In case of ┌=0 and S=0:
In this case, ┌=ζ2=0 and T=ζ=0. Further, η=θ=0, D=0
and Q=0 based on the relationship with respect to the syndrome quantities in the case of four or more errors. Therefore, the error searching equation will be expressed as follows.
X4=0 [Exp. 40]
This means “no error”. If there are five or more errors, the equation of Exp. 40 is not realized because of η≠0 or θ≠0. That is, this case means that error correction is impossible, i.e., “non correctable”.
The above-described error-detection calculation processes will be expressed only with quantities and equations required for the calculation procedure in the actual system as follows.
Calculation procedure (a)—In case of S=0 and ζ=0, i.e., corresponding to the above-described case (9):
If η=0 and θ=0, it results in “no error”. If η≠0 or θ≠0, it becomes “non correctable”.
Calculation procedure (b)—In case of S=0, ζ≠0 and η=0, i.e., corresponding to the above-described case (8):
Replace δ=ζ2/3 and Q=θ/ζ, and solve equation u2+u=Q/δ2, thereby getting solutions u1 and u2. Replace α0=δu1, β0=δu2 and α1=β1=δ1/2, and solve equations y2+y=α0/α12, z2+z=β0/β12, thereby getting y1, y2 and z1, z2. X1=α1y1, X2=α1y2, X3=β1z1 and X4=β1z2 are solutions that designate error locations.
Calculation procedure (c)—In case of S=0, ζ≠0 and η≠0, i.e., corresponding to the above-described case (7):
Replace b=η2/ζ2, c=ζ2 and Q=η2/ζ2+θ2/ζ, solve equation of w3+w=c/b3/2, and select one root “w”. Form equation δ=b1/2(w+1) by use of “w”, solve equation u2+u=Q/δ2, and get roots u1 and u2. Replace α0=δu1, β0=δu2 and α1=β1=(δ+b1/2)1/2, and solve equations y2+y=α0/α12, z2+z=β0/β12, thereby getting y1, y2 and z1, z2. X1=α0y1, X2=α1y2, X3=β1z1 and X4=β1z2 are solutions that designate error locations.
Calculation procedure (d)—In case of S=0, ζ=0 and ┌=0, i.e., corresponding to the above-described case (6):
This case designates that there is one error defined by X1=S.
Calculation procedure (e)—In case of S≠0, ζ≠0 and ┌=0, i.e., corresponding to the above-described case (5):
Replace D=ζ/S and α0=D, α1=S, solve equation y2+y=α0/α12, and get roots y1 and y2. X1=α1y1 and X2=α1y2 are solutions that designate two error locations.
Calculation procedure (f)—In case of S≠0, ┌≠0, b≠0 and c≠0, i.e., corresponding to the above-described case (1):
Solve equation of w3+w=c/b3/2, and select one root “w”. Form equation δ=b1/2w by use of “w”, and solve equations u2+u=B/δ2 and v2+v=δ/S2, thereby getting roots u1, u2 and v1, v2. Replace α0=δu1, β0=δu2, α1=Sv1 and β1=Sv2, and solve equations y2+Y=α0/α12, z2+z=β0/β12, thereby getting y1, y2 and z1, Z2. X1=α1y1+a, X2=α1y2+a, X3=β1z1+a and X4=β1z2+a are solutions that designate error locations.
Calculation procedure (g)—In case of S≠0, ┌≠0, b≠0 and c=0, i.e., corresponding to the above-described case (2):
Replace δ=b1/2, solve the equations u2+u=B/δ2 and v1+v=δ/S 2, thereby getting roots u1, u2 and v1, v2. Note here that the relationship of u=v2 is satisfied due to the condition. Replace α0=δu1, β0=δu2, α1=Sv1 and β1=Sv2, and solve equations y2+y=α0/α12, z2+z=β0/β12, thereby getting y1, y2 and z1, z2. There is also here a relationship of y=x satisfied due to the condition. X1=α1y1+a, X2=α1y2+a, X3=β1z1+a and X4=β1z2+a are solutions that designate error locations. Note here that X2=X3=δ/S+a due to the condition.
Calculation procedure (h)—In case of S≠0, ┌≠0, c≠0 and b=0, i.e., corresponding to the above-described case (3):
Replace δ=c1/3, and solve equations u2+u=B/δ2 and v2+v=δ/S2, thereby getting solutions u1, u2 and v1, v2. Note here that the relationship of u=v is satisfied due to the condition. Replace α0=δu1, β0=δu2, α1=Sv1 and β1=Sv2, and solve equations y2+y=α0/α12, z2+z=β0/β12, thereby getting y1, y2 and z1, z2. X1=α1y1+a, X2=α1y2+a, X3=β1z1+a and X4=β1z2+a are solutions that designate error locations.
Calculation procedure (i) —In case of S≠0, ┌≠0, c≠0 and c=0, i.e., corresponding to the above-described case (4):
Although solutions X1=a and X2=S+a are directly obtained from the case (4), to use the same calculation process as the procedure (h) as possible, the following procedures are used. Replace α0=β0=0, and α1=β1=S, solve the equations y2+y=α0/α12 and z2+z=β0/β12, thereby getting solutions y1, y2 and z1, z2. Here, one of the solutions y1 and y2 is “0” and the other is “1”; similarly, one of the solutions z1 and Z2 is “0” and the other is “1”. For example, y1=0, y2=1, z1=0 and z2=1. At this time, X1=α1y1+a, X2=α1y2+a, X3=β1z1+a and X4=β1z2+a are solutions that designate error locations.
While in the above-described procedures for solving the error search equation, many quantities are used in the calculation branches and calculation steps, these quantities are ones calculated from the syndromes. Syndromes S(=S1), S3, S5 and S7 are quantities directly calculated from the stored data, and other quantities are obtained by arithmetical product, involution and addition thereof.
At step 2, many kinds of products and quotients of involutions are calculated from the result at step 1. Required quantities are thirteen, and product and sum thereof are calculated at the next step 3. That is, four quantities, ┌, ┌D, ┌T and S2ζη, are calculated at step 3.
At step 4, based on the quotient arithmetic at the last step and the sum of previously obtained quantities, “D”, “T” and ┌Q are calculated. At the next step 5, “a”, “ST”, “DT” and “Q” are calculated based on the product and quotient of the obtained quantities.
At step 5, “b”, S2Q, SDT and “Ta” are calculated through addition, product and quotient arithmetic, and “c” and “B” are calculated at the final step 7.
Calculation steps after syndromes are 7 steps described above. Involution arithmetic may be performed with multiplexing, i.e., arrangement of codes expressing quantities; addition may be performed by a parity checker; and product and quotient may be performed with adders for codes expressing quantities. The detail will be explained later.
[Constitution of the 4EC-EW-BCH System]
Encode part 21 is disposed to obtain surplus polynomial r(x) used for generating check bit based on information polynomial f(x) corresponding to the to-be-stored data. As information bits, only coefficients of required degree numbers are used in accordance with the constitution of data bits while unused coefficients are fixed to be dealt with “0” or “1” data. As a result, a suitable system adaptable to the memory capacity will be constituted without storing the fixed bits in the memory.
The degree numbers constituting the information bits are so selected as to make the calculation scale and system scale minimum. Generally speaking, (h-1-4n)th degree polynomial with coefficients as being information bits ai is dealt with information polynomial f(x).
As described above, surplus r(x) is obtained by dividing f(x)x4n by code generation polynomial g(x), and coefficients of polynomial f(x)x4n+r(x) are written into memory core 22 as data bits. This memory core 22 includes a memory cell array, decoder circuits and sense amplifier circuits. Used in detail in this embodiment is a memory, in which error bits are not avoidable, such as a NAND-type flash memory (for example, refer to U.S. Pat. No. 7,369,433, or JP-A-2007-35124), a resistance change memory, a phase change memory and the like.
With respect to data reading, h-bit data read out the memory core 22 are dealt with coefficients of (h−1)th degree polynomial ν(x).
Syndrome calculation part 23 is prepared for calculating syndromes S(=S1), S3, S5 and S7 based on the read out polynomial ν(x). At this part 23, syndromes S, S3, S5 and S7 are obtained as surpluses by dividing ν(x) by m1(x), m3(x), m5(x) and m7(x), and indexes thereof are decomposed by factorization.
Indexes expressed as components are referred to as “expression indexes” hereinafter. In the following calculations, syndromes S, S3, S5 and S7 are expressed as the expression indexes; binary number addition is performed; the expression indexes are decoded in the parity checker to be expressed as (n−1)-degree polynomial as finite field elements; coefficients of polynomial as addition elements as a result of parity checking for coefficients of the respective degrees; and then they are decoded to expression indexes.
After having obtained the syndromes, at syndrome element calculation (SEC) part 24, quantities required in the steps shown in
Error search (ES) part 25 is prepared for performing error location search based on the quantities obtained at the SEC part 24. All data stored in these parts 24 and 25 are expression indexes. Clock generator 27 is for generating clocks used for controlling the calculating processes, in which clocks ck1 to ck16 are divided from the external clock CL and used. In the drawing, there are shown clock dispersions used for mainly controlling the calculation blocks.
Note here that since syndrome element calculating part 24 and error search part 25 do not reciprocate data, circuit blocks are multiplexed and the circuit scale is made small. Therefore, syndrome element calculating part 24 and error search part 25 are coupled with bi-directional arrow.
The result of the error search part 25 is input to error correction (EC) part 26 to be used for error-correcting read out data of this memory. At this error correction part 26, externally input information data polynomial f(x) is restored and output as information data.
Clocks ck1 to ck16 are clock pulses with a pulse width of several [ns], which are sequentially and cyclically generated in a cascade manner without overlaps therebetween. Further, clocks attached with dashes are generated in response to the above-described clocks used as triggers for holding states until the successive cycle starts. For example, clocks ck8′ and cl10′ are generated based on clock 8 and clock 10, respectively.
There are shown the relationship between the respective circuit groups and control clocks thereof. The calculation steps correspond to the above-described seven calculation steps.
Syndrome calculation part 23 is controlled with clock ck1. In response to the calculation, in SEC part 24, three 2-input parity checkers 401 to 403 are activated with clock ck2 to perform calculations corresponding to step 1, and then adders 411 to 416, 421 to 427 are activated with clock ck3 to perform thirteen calculations corresponding to step 2.
Addition and product corresponding to the following step 3 are performed in one adder 431 and three 4-input parity checkers 451, 461 and 462 activated with clock ck4. Product and addition corresponding to the following step 4 are performed in two adders 441 and 442, and one 4-input parity checker 471 activated with clock ck5.
Product corresponding to step 5 are performed in four adders 422 to 425 activated with clock ck6, which are subjected to multiplex use. Product and addition corresponding to step 6 are performed in three adders 421, 426 and 427, and one 4-input parity checkers 451 activated with clock ck7. Addition corresponding to step 7 is performed in two 4-input parity checkers 461 and 462 activated with clock ck8.
Fifteen calculation results obtained through the above-described calculation processes are stored in register group activated with clocks with dash.
The detail of the respective circuits will be explained later.
CUBE part 500 includes: one adder 501 for calculating quantity “H” obtained from syndromes, for which unknown quantity parts of the cubic equation is substituted; decoder circuit 502 for searching “w” in the cubic equation of w3+w=H; and another adder 503 for calculating a desirable quantity δ from “w” as a product of “w” or “w+1” by b1/2.
SQUARE part 510 includes: two adders 511a and 512a for calculating quantities “J” and “K” obtained from δ, for which unknown quantity parts of the quadratic equations are substituted, the quadratic equations being prepared for searching roots of biquadratic error search equation; decoder circuits 513a and 514a for searching “u” and “v” in the quadratic equations u2+u=J and v2+v=K, respectively; and four adders 515a to 518a for calculating factorization coefficients α0, β0, α1 and β1, which are prepared for factorizing the biquadratic equation into quadratic equations, based on “u” and “v”.
SQUARE part 510 further includes: two adders 511b and 512b for calculating quantities “L” and “M” to be substituted for unknown quantity parts of the quadratic equations, which are prepared for searching roots of biquadratic error search equation; decoder circuits 513b and 514b for searching “y” and “z” in the quadratic equations y2+y=L and z2+z=M, respectively; and four adders 515b to 518b for calculating the solutions of the biquadratic equation based on “y” and “z”.
Note here that in SQUARE part 510, the same circuit systems will be used in the latter half as those in the former half. Therefore, as the calculation circuit parts 511b to 518b, which are shown in parentheses and used in the latter half, the calculation circuit parts 511a to 518a used in the former half serve as multiplex use. For this purpose, to hold the calculation result in the former half, there are prepared a group of registers (α0, β0, α1, β1), 530.
The calculation results in SQUARE part 510 are added to quantities obtained from the syndromes, and it becomes the real error searched results. To perform the additional calculation, there are prepared four 2-input parity checkers 520 to 523, and a register group (X1, X2, X3, X4), 531, are disposed for holding the calculation results.
Within the four parity checkers 520 to 523, three checkers 520 to 522 are the same as three parity checkers 401 to 403 used in SEC part 24, i.e., these serve as multiplex use.
Next, with respect to ES part 25, the calculation process will be explained in accordance with detailed calculation cases. The calculation processes of eight cases, case 1 to case 8, will be explained with reference to
In the circuit block (i.e., CUBE part) 500, the product of “b −3/2” by “c” is calculated at adder 501 with clock ck9; the solution of the cubic equation w3+w=H is decoded at decoder 502 with clock ck10; and the product of “w(w+1)” by “b1/2” is calculated at adder 503, so that result δ is output.
In the circuit (i.e., SQUARE part) 510, the product of “B” by δ−2 is calculated at adder 511a, and the product of δ by S−2 is calculated at adder 512a with clock ck11; the solutions of quadratic equations u2+u=J and v2+v=K are calculated at decoders 513a and 514a with clock ck12; the products of the respective solutions by the involutions of δ and “S” are calculated at adders 515a to 518a to output α0, β0, α1 and β1. These outputs are stored in the data register group 530 with clock ck13.
This circuit block 510 serves for the successive calculation in a multiplex use. That is, with clock ck13, the product of α0 by α1−2 and the product of β0 by β1−2 are calculated at adder 511b and 512b, respectively; with clock ck14, the solutions of quadratic equations y2+y=L and z2+z=M are calculated at decoders 513b and 514b, respectively; and the products of the respective solutions by the involutions of α1 and β1 are calculated at adder groups 515b to 518b, whereby α1y1, α1y2, β1z1 and β1z2 are output.
The above-described results are added to “a” in the two-input parity checker groups 520 to 523 with clock ck15, whereby outputs X1, X2, X3 and X4 are obtained. These outputs are stored in register group 531 with clock 16.
In the circuit block 510, with clock ck5, the product of ζ−1θ by δ is calculated at adder 511a, and “0” is input to another adder 512a; the solutions of quadratic equations u2+u=J and v2+v=K are calculated at decoders 513a and 514a with clock ck6; and the products of the respective solutions by δ are calculated at adders 515a and 516a, and α0 and β0 are output. Further, α1=β1=ζ1/2 is set. These outputs are stored in the data register group 530 with clock ck7.
This circuit block 510 serves for the successive calculation in a multiplex use. That is, with clock ck7, the product of α0 by α1−2 is calculated at adder 511b, and the product of β0 by β1−2 is calculated at adder 512b; and with clock ck8, the solutions of quadratic equations y2+y=L and z2+z=M are calculated at decoders 513b and 514b, respectively; and the products of the respective solutions by α1 and β1 are calculated at adder groups 515b to 518b, whereby X1, X2, X3 and X4 are output. These outputs are stored in the register group 531 with clock ck9.
Replacing c=ζ2 and b=(ζ−1η)2, in the circuit block 500, based on “b” and “c”, the product of involutions thereof is calculated with clock ck7 (adder 501); cubic equation is solved with clock ck8 (decode circuit 502); and the product of “w+1” by the involution of “b” is calculated (adder 503), whereby result δ is gotten.
In the circuit block 510, the product of “Q” by the involution of δ is calculated at adder 511a with clock ck9 while zero input in another adder 512a because it is not used; quadratic equation is solved at decode circuits 513a and 514a with clock ck10; and the products of the solutions by δ are calculated at adders 515a and 516a, so that α0 and β0 are gotten. Further, replacing α1=β1=(δ+ζ−1η)1/2, obtained data are stored in register group 530 with clock ck11.
At the timing of clock ck9, addition of δ and ζ−1η is calculated in one of two-input parity checker 523, and it is used in α1 and β1. The circuit block 510 is used again. That is, the product of α0 by the involution of α1 is calculated at one adder 511b, and the product of β0 by the involution of β1 is calculated at another adder 512b with clock ck11; quadratic equations are solved at decode circuits 513b and 514b with clock ck12; and the products of the solutions by α1 an dβ1 are calculated at four adders 515b-518b, so that X1, X2, X3 and X4 are gotten. These resultant data are stored in register group 531 with clock ck13.
The case 5 shown in the lower portion in
There is no need of calculation in the circuit block 500 and the former calculation in the circuit block 510. Replace α0=S−1 and α1=S, and store them in the register group 503 with clock ck6.
In the circuit block 510, the product of α0 by the involution of α1 is calculated at adder 511b with clock ck6, and zero is input to another adder 512b because it is not used. The solutions of quadratic equations are decoded at decode circuits 513b and 514b with clock ck7, and the product of the solutions by α1 are calculated at adders 515b and 516b, whereby X1 and X2 are output. These outputs are stored in register group 531.
Calculations in circuit block 510 are as follows: the product of “B” by the involution of δ is calculated at adder 511a, and the product of δ by the involution of “S” is calculated at another adder 512a with clock ck9; solutions of the quadratic equations are decoded at decode circuits 513a and 514a with clock ck10; and the products of the respective solutions by δ and “S” are calculated at four adders 515a to 518a, whereby α0, β0, α1 and β1 are obtained. These results are stored in register group 530 with clock ck11.
Next, the circuit block 510 is activated again as the multiplex use. That is, the product of α0by the involution of α1 is calculated at adder 511b, and the product of β0 by the involution of β1 is calculated at adder 512b with clock ck11; Solutions of quadratic equations are decoded at decode circuits 513b and 514b with clock ck12; and the products of the solutions by α1 and β1 are calculated at adders 515b to 518b, whereby α1y1, α1y2, β1z1 and β1z2 are gotten.
These results are added to “a” at parity checkers 520 to 523 with clock ck13, so that X1, X2, X3 and X4 are output. These are stored in register group 531 with clock ck14.
Calculations in circuit block 510 are as follows: the product of “B” by the involution of δ is calculated at adder 511a, and the product of δ by the involution of “S” is calculated at another adder 512a with clock ck9; solutions of the quadratic equations are decoded at decode circuits 513a and 514a with clock ck10; and the products of the respective solutions by δ and “S” are calculated at four adders 515a to 518a, whereby α0, β0, α1 and β1 are obtained. These results are stored in register group 530 with clock ck11.
Next, the circuit block 510 is activated again as the multiplex use. That is, the product of α0 by the involution of α1 is calculated at adder 511b, and the product of β0 by the involution of β1 is calculated at adder 512b with clock ck11; Solutions of quadratic equations are decoded at decode circuits 513b and 514b with clock ck12; and the products of the solutions by α1 and β1 are calculated at adders 515b to 518b, whereby α1y1, α1y2, β1z1 and β1z2 are gotten.
These results are added to “a” at parity checkers 520 to 523 with clock ck13, so that X1, X2, X3 and X4 are output. These are stored in register group 531 with clock ck14.
Calculations in circuit block 510 are as follows: the product of α0 by the involution of α1 is calculated at adder 511b, and the product of β0 by the involution of β1 is calculated at another adder 512b with clock ck9; solutions of the quadratic equations are decoded at decode circuits 513b and 514b with clock ck10; and the products of the respective solutions by α1 and β1 are calculated at four adders 515b to 518b, whereby α1y1, α1y2, β1z1 and β1z2 are obtained.
These results are added to “a” at parity checkers 520 to 523 with clock ck11, so that X1, X2, X3 and X4 are output. These are stored in register group 531 with clock ck12.
So far, the principle of the 4-bit error search and correction system has been explained in a general description. Next, more detailed embodiment of the circuit system will be explained below with respect to the case of GF(256) with 256 elements. The reason why GF(256) is used is in that the practical data quantity to be dealt with in a memory in a lump is in a rage from 128 bits to 256 bits.
Data Encoding
The basic irreducible polynomial m1(x) is expressed by the following expression Exp. 41, and root thereof is α.
α: m1(x)=x8+x4+x3+x2+1 [Exp. 41]
In case of GF(256), the irreducible polynomial on GF(2) is defined as 8th-degree one. With this root, elements of GF(256) are 256, i.e., 0, α0, α1, . . . , α253 and α254.
As irreducible polynomials with roots of α3, α5 and α7, m3(x), m5(x) and m7(x) are selected as follows:
α3:m3(x)=x8+x6+x5+x4+x2+x+1
α5:m5(x)=x8+x7+x6+x5+x4+x+1
α7:m3(x)=x8+x6+x5+x3+1 [Exp. 42]
Based on these irreducible polynomials, code generation polynomial g(x)=m1(x)m3(x)m5(x)m7(x) may be constituted as the following 32nd-degree polynomial.
The elements for constituting the code of the ECC system are 255 excepting zero factor of the finite field. Therefore, data is expressed by coefficients of 254th degree polynomial. Assign the information bits in data bits to coefficients a32 to a254, and divide polynomial f(x)x32 that starts from 32nd degree by g(x), and obtained remainder is referred to as r(x). This becomes 31st degree polynomial as shown in the following expression Exp. 44.
f(x)x32=q(x)g(x)+r(x)
r(x)=b31x31+b30x30+ . . . +b1x+b0 [Exp. 44]
Coefficients b31, b30, . . . , b1 and b0 of r(x) serve as 32-check bits to be accompanied with the information bits, and constitute data to be stored in the memory together with the information bits.
It is desirable that the information bits to be dealt with are expressed by a power of 2. Supposing that 128 bits are used as information bits, the number of data bits is 160. How to assign 128-information bits to the degree numbers of the polynomial on GF(256) is determined in consideration of the calculation efficiency. This method will be explained later.
The degree is selected in such a way as to make the calculation scale or system scale minimum. Assuming that 128 information bits are referred to as ai(1) to ai(128), and [i(128)-1]th degree polynomial with the information bits as coefficients is expressed as f(x), which serves as input data. Selected 128-bit degree numbers are expressed as i(1), i(2), . . . , i(128) in the increasing order.
Explaining in detail, the degree selection is performed in consideration of the number of coefficient “1” of pn(x), which corresponds to a surplus obtained by dividing xn by m1(x), m3(x), m5(x) or m7(x) and expressed by finite elements, p3n(x) (the third power of pn(x)), p5n(x)(the fifth power of pn(x)) and p7n(x)(the seventh power of pn(x)). Since 0 to 31st degrees are used as check bits, these are fixed bits. In
Previously divide a single term xi by the code generation polynomial g(x) to get surplus ri(x) that is 31st-degree polynomial. Since selected 160 data are assigned to coefficients of the respective degrees of 254th degree polynomial, data “1” designates that there is xi, the degree number “i” of which corresponds to the data position.
Therefore, selecting ri(x) with “i” of data “1”, and calculating addition of coefficients of the respective degrees of ri(x) as defined by mod 2, there is obtained a remainder as defined by dividing data polynomial by g(x). Note here that since ri(x) with coefficient “0” at the respective degrees does not contribute to the calculation, such ri(x) may be previously eliminated.
With respect to the respective degrees “m” of ri(x), collect “i” with coefficient “1”, and the tables shown in
The method of employing these tables is as follows. For example, “i” of ri(x) satisfying that the coefficient of x15 is “1” are 33, 34, 38, . . . , 227, 249 and 253 shown in a row of m=15, and in 1st to 65th columns of PCL input number. Check bit “b15” corresponding to the coefficient of x15 is obtained as a result of parity check for i=“1” of bit positions with data “1” in the selected i-th degree terms in the information data polynomial f(x)x32. Explaining in other words, the check bit will be obtained as a remainder of mod 2 with respect to the number of “i” with data “1” in these tables.
4-bit PCL 152 is a set of XOR circuits, which calculates coefficient values of the respective degrees of a polynomial expressing the check bits. In detail, this circuit selects inputs in accordance with the remainder table of xi obtained by the code generation polynomial, and calculates parity.
Input selection circuit 151 is for selecting the connection between first signal wirings, on which input signals, i.e., coefficient signals ai(1) to ai(128) of the information data polynomial are inverted and supplied, and second wirings, which serve as PCL input wirings, in accordance with the table. There are 128×2026 cross points between the first and second wirings, which are defined by addition of total of inputs and total of m=0 to 32. Necessary cross points are selected in accordance with the table, and wiring contacts are formed at the selected cross points.
In case of m=17, as shown in the tables shown in
With respect to other “m”, PCLs may be formed like the above-described example.
Syndrome Calculation Part 23
Previously divide a single term xi by the polynomial m1(x) to get 7th-surplus polynomial pi(x). Since 255 data correspond to coefficients of the respective degrees of 254th-polymomial, data “1” designates that there is xi term corresponding to the data position, and the remainder obtained by m1(x) constitutes pi(x). Therefore, selecting pi(x) with “i” of data “1”, and calculating addition of coefficients of the respective degrees of pi(x) as defined by mod 2, there is obtained a remainder as defined by dividing data polynomial by m1(x).
Note here that since pi(x) with coefficient “0” at the respective degrees does not contribute to the calculation, such pi(x) may be previously eliminated.
With respect to the respective degrees “m” of pi(x), collect “i” with coefficient “1”, and the tables shown in FIGS. 19A to 19C are obtained.
For example, “i” of pi(x) satisfying that the coefficient of x7 is “1” are 7, 11, 12, . . . , 237, 242, 254 shown in a row of m=7, and in 1st to 71st columns of PCL input number. (s)7, which corresponds to the coefficient of x7 of S1(x), is obtained as a result of parity check of the coefficients in the selected i-th degree terms.
Previously divide a single term xi by the polynomial m3(x) to get 7th-surplus polynomial ti(x). While ti(x) contributes to S3(x), ti(x3) contributes to S3 because S3=S3 (x3). Since ti(x3)≡x3i mod m3(x3) and m3(x3)≡0 mod m1(x) based on xi≡ti(x)mod m3(x), it is obtained ti(X3)≡x3i≡p3i(x)mod m1(x).
Since elements of GF(256) are irreducible remainders of mod m1(x), the contribution of xi term of ν(x) to S3 is the same as that of p3i(x). Therefore, previously get polynomial p3i(x). Since 255 data correspond to coefficients of the respective degrees of 254th-polymomial, data “1” designates that there is xi term corresponding to the data position, and the remainder ti(x) obtained by m3(x) constitutes p3i(x) contributing to S3=S3(x3).
Therefore, selecting p3i(x) with “i” of data “1”, and calculating addition of coefficients of the respective degrees “m” of p3i(x) as defined by mod 2, there is directly obtained S3(x3) without dividing data polynomial by m3(x). Since p3i(x) with coefficient “0” at the respective degrees does not contribute to the calculation, such p3i(x) may be previously eliminated. With respect to the respective degrees “m”s of p3i(x), collect “i” with coefficient “1”, and the tables shown in
For example, “i” of p3i(x) satisfying that the coefficient of x7 is “1” are 4, 8, 14, . . . , 242, 249, 254 shown in a row of m=7, and in 1st to 73rd columns of PCL input number. (s3)7, which corresponds to the coefficient of x7 of S3(x3), is obtained as a result of parity check of the coefficients in the selected i-th degree terms. With respect to other “m”s, necessary coefficients will be obtained like this.
Previously divide a single term xi by the polynomial m5(x) to get 7th-surplus polynomial qi(x). While qi(x) contributes to S5(x), qi(x5) contributes to S5 because S5=S5(x5). Since qi(X5)≡x5i mod m5(x5) and m5(x5)≡0 mod m1(x) based on xi≡=qi(x)mod m5(x), it is obtained qi(X5)≡x5i≡p5i(x) mod m1(x).
Since elements of GF(256) are irreducible remainders of mod m1(x), the contribution of xi term of ν(x) to S5 is the same as that of p5i(x). Therefore, previously get polynomial p5i(x). Since 255 data correspond to coefficients of the respective degrees of 254th-polymomial, data “1” designates that there is xi term corresponding to the data position, and the remainder qi(x) obtained by m5(x) constitutes p5i(x) contributing to S5=S5(x5).
Therefore, selecting p5i(x) with “i” of data “1”, and calculating addition of coefficients of the respective degrees “m” of p5i(x) as defined by mod 2, there is directly obtained S5(x5) without dividing data polynomial by m5(x). Since p5i(x) with coefficient “0” at the respective degrees does not contribute to the calculation, such p5i(x) may be previously eliminated. With respect to the respective degrees “m”s of p5i(x), collect “i” with coefficient “1”, and the tables shown in
For example, “i” of p5i(x) satisfying that the coefficient of x7 is “1” are 4, 7, 9, . . . , 242, 250 and 253 shown in a row of m=7, and in 1st to 64th columns of PCL input number. (s5)7, which corresponds to the coefficient of x7 of S5(X5), is obtained as a result of parity check of the coefficients in the selected i-th degree terms. With respect to other “m”s, necessary coefficients will be obtained like this.
Previously divide a single term xi by the polynomial m7(x) to get 7th-surplus polynomial sei(x). While sei(x) contributes to S7(x), sei(x7) contributes to S7 because S7=S7(x7). Since sei(x7)≡x7i mod m7(x7) and m7(x7)≡0 mod m1(x) based on xi≡sei(x)mod m7(x), it is obtained sei(x7)≡x7i≡p7i(x) mod m1(x).
Since elements of GF(256) are irreducible remainders of mod m1(x), the contribution of xi term of ν(x) to S7 is the same as that of p7i(x). Therefore, previously get polynomial p7i(x). Since 255 data correspond to coefficients of the respective degrees of 254th-polymomial, data “1” designates that there is xi term corresponding to the data position, and the remainder sei(x) obtained by m7(x) constitutes p7i(x) contributing to S7=S7(x7).
Therefore, selecting p7i(x) with “i” of data “1”, and calculating addition of coefficients of the respective degrees “m” of p7i(x) as defined by mod 2, there is directly obtained S7(x7) without dividing data polynomial by m7(x). Since p7i(x) with coefficient “0” at the respective degrees does not contribute to the calculation, such p7i(x) may be previously eliminated. With respect to the respective degrees “m”s of p7i(x), collect “i” with coefficient “1”, and the tables shown in
For example, “i”s of p7i(x) satisfying that the coefficient of x7 is “1” are 1, 5, 6, . . . , 242, 249 and 250 shown in a row of m=7, and in 1st to 81st columns of PCL input number. (s7)7, which corresponds to the coefficient of x7 of S7(x7), is obtained as a result of parity check of the coefficients in the selected i-th degree terms. With respect to other “m”s, necessary coefficients will be obtained like this.
4-bit PCL is a set of XOR circuits for calculating a coefficient value of each degree of a polynomial expressing the syndromes. Inputs are selected at the respective degrees in accordance with the table of remainder pi(x), p3i(x), p5i(x) and p7i(x), and the parity is calculated.
In the input circuit portion 231, 160 coefficients of data polynomial, d0, d1, d31, di(1), . . . , di(128) are inverted and input on the cross points of signal wirings in accordance with the table, and then inverted again to be input to PCLs 232.
the cross points of the input wirings are 160×575 in case of “S”, 160×618 in case of “S3”, 160×571 in case of “S5” and 160×578 in case of “S7” defined as additions of input data and the total of m=0 to 7 in the table. That is, necessary cross points are selected based on the table, and contacts are formed at the respective cross points, so that the input wirings are connected to each other.
In case of m=5 of xi, the number of bits to be parity-checked is the maximum, 77, as shown in the table.
With respect to other “m”s, and other syndromes, PCLs may be constituted like the above described example. The detailed explanation will be omitted.
Syndromes S, S3, S5 and S7 are obtained as 7th-degree polynomials, and are coincident with either one of pin(x) defined as elements of GF(256). Therefore, the index of root α obtained by diving the polynomial by m1(x) is transformed to an “expression index” expressed as a pair of irreducible remainders of mod 17 and mod 15 of the index mod 255, and it will be used in the successive calculations.
8-bit binary numbers are grouped by two bits from the lowermost side, and expressed as quaternary numbers Ai, Bi, Ci and Di. Further, the lower signal E[0;15] and the upper signal F[0;15] of a hexadecimal number are constituted by A and B, and C and D, respectively. By use of this pre-decoder, the number of transistors used in the following decoder circuit may be reduced to two from eight in comparison with the case without such the pre-decoder.
Index (17), (15) decoder shown in
In case of pi(x)=0, it will not be obtained an index number of α. That is, since E[0]=1 and F[0]=1 in this case, index will not be output. With respect to syndrome S, zero element judgment is performed for judging that it is a zero component. Therefore, to easily judge that it is a zero element, zero element judgment circuit shown in
Each the hexadecimal number is expressed by “jk” that designates a pair of F[j]E[k] in the circuit. That is, “01” shows a pair of F[0] and E[1]. Although Ai, Bi, Ci and Di are not shown in the table, these are obtained as quaternary numbers based on the coefficients of the respective degrees “m” of the corresponding pi(x).
Selecting the hexadecimal numbers E[0;15] and F[0;15] of the indexes corresponding to the respective expression indexes based on this table, signal wiring connection of the transistor gates will be determined in the decoder shown in
Each the hexadecimal number is expressed by “jk” that designates a pair of F[j]E[k] in the circuit. That is, “01” shows a pair of F[0] and E[1]. Although Ai, Bi, Ci and Di are not shown in the table, these are obtained as quaternary numbers based on the coefficients of the respective degrees “m” of the corresponding pi(x).
Selecting the hexadecimal numbers E[0;15] and F[0;15] of the indexes corresponding to the respective expression indexes based on this table, signal wiring connection of the transistor gates will be determined in the decoder shown in
The power of finite field element may often appear in the calculation processes. However the power relationship corresponds to a certain transformation between elements in case the expression index is used. Therefore, there is no need of calculating, but it may be achieved by signal connection changes.
The power of element is expressed as a multiplier of the expression index component. Component indexes of the expression indexes {i(17), i(15)} are multiplied by “m” to become new expression indexes {i×m (17), i×m (15)}, which are shown in the column of “×m” in
For example, −3/2 power of the element of expression index {3, 8} corresponds to such a new expression index that is obtained by multiplying the index component by −3/2. Explaining detail, the first index component is i(17)=3, and this is transformed to “14” shown in the sub-column −i(17) in the column ×(−1); this becomes a new index component of i(17), and is transformed to “8” shown in the sub-column 3i(17) in the column ×3; and then this becomes a new index component of i(17), and is transformed to “4” shown in the sub-column i/2 (17) in the column ×(1/2).
The order of the above-described transformations is not material, and the result is the same without regard to the order. The second index component is i(15)=8, and this is transformed to “7” shown in the sub-column −i(15) in the column ×(−1); this becomes a new index component of i(15), and is transformed to “6” shown in the sub-column 3i(15) in the column “×3”; and then this becomes a new index component of i(15), and is transformed to “3” shown in the sub-column i/2(15) in the column “×(1/2)”. As a result, the element of the expression index {3 ,8} becomes to correspond to that of the expression index {4, 3} by multiplying the component by −3/2.
As described above, it is able to obtain expression indexes necessary for the calculation. Next, it will be explained in detail the circuits used for searching ζ, η and θ defined as additions of syndromes.
Input signals are expression indexes of Sk and Sk (k=3, 5, 7), respectively. For these inputs, there are prepared nodes Na and Nb corresponding to m-degree coefficients of the addition polynomials, and precharge circuit 311 for precharging the nodes. Make the precharge circuit 311 off by clock ck2, and the decoders 312a and 312b are activated.
Connections between the expression index signals at the nodes of the respective signals and gates of transistors are determined by a table described below, and are not dependent on the signals. With respect to the respective “m”s, parity checks of the respective two nodes Na and Nb are taken at the respective 2-bit PCs 313, coefficients of the polynomial expressions of additions of the input signals will be obtained.
The addition of the finite field elements is performed as that of mod 2 with respect to the coefficients of irreducible polynomial corresponding to the finite field elements.
Therefore, it will be explained a method of searching the coefficients used for adding the finite element polynomial pi(x) expressed by the expression indexes.
pi(x) and the expression index {i(17), i(15)} correspond to each other one to one. Therefore, when an expression index is applied, the contribution for addition of coefficients of the degree numbers “m”s of polynomial pi(x) may be decoded based on these tables.
Next, based on a calculation example of ζ=S3+S3, it will be explained a method of dealing with the tables showing the relationship between the expression indexes and the coefficients of the polynomial expression. As shown in
Similar connections are formed for the respective components i(15)'s based on the tables shown in
For example, m=7 is expressed by a common node defined by a NOR connection of discharge paths formed of: a NOR connection of i(17)=5, 9, 10, 11, 12 and 16 under i(15)=0; a NOR connection of i(17)=6, 7, 9, 12, 14 and 15 under i(15)=1; a NOR connection of i(17)=0, 1, 3, 4, 6, 10, 11 and 15 under i(15)=2; a NOR connection of i(17)=0, 4, 6, 8, 9, 12, 13 and 15 under i(15)=3; a NOR connection of i(17)=5, 6, 7, 10, 11, 14, 15 and 16 under i(15)=4; a NOR connection of i(17)=0, 1, 3, 4, 7, 9, 10, 11, 12 and 14 under i(15)=5; a NOR connection of i(17)=1, 3, 8, 9, 10, 11, 12 and 13 under i(15)=6; a NOR connection of i(17)=0, 4, 5, 7, 8, 9, 10, 11, 12, 13, 14 and 16 under i(15)=7; a NOR connection of i(17)=0, 1, 3, 4, 5, 6, 9, 12, 15 and 16 under i(15)=8; a NOR connection of i(17)=0, 4, 7, 8, 13 and 14 under i(15)=9; a NOR connection of i(17)=0, 1, 3, 4, 5, 7, 14 and 16 under i(15)=10; a NOR connection of i(17)=1, 3, 6, 7, 8, 10, 11, 13, 14 and 15 under i(15)=11; a NOR connection of i(17)=1, 3, 5, 6, 7, 8, 9, 12, 13, 14, 15 and 16 under i(15)=12; a NOR connection of i(17)=1, 3, 5, 8, 13 and 16 under i(15)=13 and a NOR connection of i(17)=0, 4, 5, 6, 8, 10, 11, 13, 15 and 16 under i(15)=14.
For example, {i(17), i(15)}={11, 4} is decoded as that the coefficient of m=7 is “1” as a result of discharging the nodes Na and Nb via the NOR connection of i(17)=5, 6, 7, 11, 14, and 16 under i(15)=4. The information data at the nodes Na and Nb of the degree number “m” of the inputs S3 and S3 are subjected to parity checking with 2-bit PC 313. Although the nodes Na and Nb are inverted by discharging, the result as an addition is the same as the case of no inversion.
As described above, the coefficients under the polynomial expression of the finite field element ζ will be obtained. In case of the input is zero element, expression index is not generated, and the signal is set at Vss, so that the discharge path is not formed, thereby resulting in that the node is “1”. Therefore, the calculation at this stage becomes correct even if including the case of zero element.
ζ, η and θ defined as the sums of syndromes are obtained as 7th-degree polynomials to be coincident with anyone of pi(x) as being elements of GF(256). Therefore, the index of root α obtained by dividing the polynomial by m1(x) is transformed to an expression index expressed as a pair of mod 17 and mod 15, and the expression index will be used in the following calculation process.
Pre-decoders used in the above-described transformation may be formed as the same as that used in the syndrome calculation as shown in
Index (17), (15) decoders generate mod 17 and mod 15 components of the expression index belonging to the remainder classes based on the pre-decoded signals, and latch them. That is, combining signals E[0;15] and F[0;15] with NAND connections expressing components of the remainder classes and NOR connections thereof; discharging the pre-charged nodes with clocks ck3 and ck3′; and inverting them, remainder class index “i” is output. The decoder circuits are necessary up to the number of the remainder classes. These indexes are formed for mod 17 and mod 15 to be pairs of expression indexes.
When pi(x)=0, it is not expressed as an index of α, i.e., indexes are not searched. In this case, E[0]=1 and F[0]=1, and indexes are not output. With respect to ζ, η and θ, since the judgment of zero element is used, it is possible to monitor the index state. However, to simply judge the zero element, it will be prepared decoders shown in
Next, error location searching will be explained below.
Syndrome Element Calculation (SEC) part 24
The calculation required for searching an error location is to define indexes based on congruences between the expression indexes. The calculation carried by clock ck3 in the syndrome element calculation part 24 will be explained below.
A product operation between the finite field elements is carried out as a congruence calculation. All congruences are in GF(256), i.e., expressed by mod 255. Therefore, if straightly calculating it, it corresponds to do comparing operations with a scale of 255×255, and the circuit scale becomes great. In consideration of this, in this embodiment, the calculation is divided into two parts that are processed in parallel. Explaining in detail, 255 is divided into two factors that are prime to each other, and the congruence is divided into two congruences with the prime factors as modulus, whereby it is used such a property that a number satisfying the two congruences satisfies the original congruence too.
In detail, in case the congruence of mod 255 is solved, using 255=17×15, solve two congruences of mod 17 and mod 15.
The following expression Exp. 45 shows congruences used for searching index σ(S4η) of S4ηAssuming that the index of “S” is σ, the fourth power of “S” is transformed to expression index of 4σ in accordance with above-described transformation table. Combining it with index σ(η), the following congruences will be obtained.
σ(S4η)≡4σ+σ(η) (mod 17)
σ(S4η)≡4σ+σ(η) (mod 15)
→σ(S4η)≡4σ+σ(η) (mod 17·15) [Exp. 45]
The following Exp. 46 shows congruences used for searching index σ(S4ζ2) of S4ζ2.
σ(S4ζ2)≡4σ+2σ(ζ) (mod 17)
σ(S4ζ2)≡4σ+2σ(ζ) (mod 15)
→σ(S4ζ2)≡4σ+2σ(ζ) (mod 17·15) [Exp. 46]
Similarly, Exp. 47 is a case of searching index σ(S3ζ) of S3ζ; Exp. 48 is a case of searching index σ(S3η) of S3η; Exp. 49 is a case of searching index σ(S2ζ2) of S2ζ2; and Exp. 50 is a case of searching index σ(ζθ) of ζθ;
σ(S3ζ)≡3σ+σ(ζ) (mod 17)
σ(S3ζ)≡3σ+σ(ζ) (mod 15)
→σ(S3ζ)≡3σ+σ(ζ) (mod 17·15) [Exp. 47]
σ(S3η)≡3σ+σ(η) (mod 17)
σ(S3η)≡3σ+σ(η) (mod 15)
→σ(S3η)≡3σ+σ(η) (mod 17·15) [Exp. 48]
σ(S2ζ2)≡2σ+2σ(ζ) (mod 17)
σ(S2ζ2)≡2σ+2σ(ζ) (mod 15)
→σ(S2ζ2)≡2σ+2σ(ζ) (mod 17·15) [Exp. 49]
σ(ζθ)≡σ(ζ)+σ(θ) (mod 17)
σ(ζθ)≡σ(ζ)+σ(θ) (mod 15)
→σ(ζθ)≡σ(ζ)+σ(θ) (mod 17·15) [Exp. 50]
To search the sum of the expression indexes in the congruence calculation, it is in need of transforming a power of a required element to an expression index. Required here are fourth, third and second powers. In accordance with the above-described transformation table, elements of the expression index of σ and σ(ζ) are transformed and output with index multiplexer circuits 351 and 352 shown in
Further, to convert the expression indexes to binary numbers, as shown in
It will be explained general adders used for searching the sum of the expression indexes. Assuming that it is searched expression index components of a product of α-power of finite field element A and β-power of finite field element B. Index of the product is σ(AαBβ), which may be searched as a remainder of the sum of σ(A) multiplied by α and σ(B) multiplied by β, where σ(A) and σ(B) are indexes of the factors of the product. α-multiplying and β-multiplying may be obtained in accordance with the above-described table while the sum is obtained with an adder used for adding binary numbers. It is in need of preparing adders for the respective expression indexes, i.e., adders of mod 17 and mod 15 are necessary.
To search remainders of the sum, 5-bit (17) adder shown in
As shown in
This adder has 4-bit first stage adder circuit 1011; carry correction circuit 1012 for detecting that the sum is equal to 15 or more to carry; and second stage adder circuit 1013 for adding a complement of 15, i.e., 1(=16-15), together with the carry correction circuit 1012 when the sum is 15 or more.
It is not required of the adders shown in
The result obtained in the adder is binary number of the expression index component. Therefore, it is required of this to be decoded to the expression index component itself.
Such a decode circuit will be constituted by pre-decoders shown in
These pre-decoded signals are input to the index (17), (15) & latch circuit shown in
Next, the calculation part of adders 422 to 452, which are multiplexed by clocks ck3 and ck6 in the calculation block (SEC part) 24, will be explained below.
Exp. 51 shows congruences used for searching indexes σ(Sη) and σ(ST) of Sη and ST, respectively. Assuming that index of “S” is σ, the following congruences are obtained.
σ(Sη)≡σ+σ(η) (mod 17)
σ(Sη)≡σ+σ(η) (mod 15)
→σ(Sη)≡σ+σ(η) (mod 17·15)
σ(ST)≡σ+σ(T) (mod 17)
σ(ST)≡σ+σ(T) (mod 15)
→σ(ST)≡σ+σ(T) (mod 17·15) [Exp. 51]
Exp. 52 shows congruences used for searching indexes σ(S−1ζ) and σ(a) of S−1ζ and a=D/S, respectively. Assuming that index of “S” is σ, expression index −σ is obtained from S−1 in accordance with the above-described table, and the following congruences are obtained with σ(ζ) and σ(D).
σ(S−1ζ)≡−σ+σ(ζ) (mod 17)
σ(S−1ζ)≡−σ+σ(ζ) (mod 15)
→σ(S−1ζ)≡−σ+σ(ζ) (mod 17·15)
σ(a)≡−σ+σ(D) (mod 17)
σ(a)≡−σ+σ(D) (mod 15)
→σ(a)≡−σ+σ(D) (mod 17·15) [Exp. 52]
Exp. 53 shows congruences used for searching indexes σ (ζη) and σ(DT) of ζη and DT, respectively. Assuming that index of ζ is σ(ζ) and index of “D” is a (D), the following congruences are obtained with σ(η) and σ(T).
σ(ζη)≡σ(ζ)+σ(η) (mod 17)
σ(ζη)≡σ(ζ)+σ(η) (mod 15)
→σ(ζη)≡σ(ζ)+σ(η) (mod 17·15)
σ(DT)≡σ(D)+σ(T) (mod 17)
σ(DT)≡σ(D)+σ(T) (mod 15)
→σ(DT)≡σ(D)+σ(T) (mod 17·15) [Exp. 53]
Exp. 54 shows congruences used for searching indexes σ (S−1η) and σ(Q) of S−1η and Q=┌Q/┌, respectively. Assuming that index of ζ is σ(ζ), and index of ┌ is σ(┌), each −1 power thereof is obtained from the above-described table, and the following congruences are obtained with σ(η) and σ(┌Q).
σ(S−1η)≡−σ(ζ)+σ(η) (mod 17)
σ(S−1η)≡−σ(ζ)+σ(η) (mod 15)
→σ(S−1η)≡−σ(ζ)+σ(η) (mod 17·15)
σ(Q)≡−σ(┌)+σ(┌Q) (mod 17)
σ(Q)≡−σ(┌)+σ(┌Q) (mod 15)
→σ(Q)≡−σ(┌)+σ(┌Q) (mod 17·15) [Exp. 54]
In the above-described congruence calculations, a power of an element necessary for searching the sum of expression indexes is transformed to an expression index. Required is −1 power, and multiplexing with a clock is added to it. The transformation of the power to the expression index and the multiplexer circuit will be explained below with reference to
The expression indexes obtained as described above are input to the index/binary conversion circuit 1032, which is activated by clock ck3 or ck6, so that indexes (17) or (15) are converted to 5-binary or 4-binary numbers. These binary data are input to adders at the respective timings.
The result of the adders expresses a binary number of an expression index. Therefore, to decode this to the expression index component itself, per-decoders shown in
These pre-decoded signals are input to the index (17), (15) & latch circuit 1035 shown in
It is in need of preparing two systems of latch in accordance with different timings because the circuit is multiplexed. As finite field elements required later, there are expression indexes of S−1ζ and S−1η to be latched by clock ck4′, and expression indexes of “a” and “Q” to be latched by clock ck7′.
Next, it will be explained another calculation part (adders 421, 426 and 427) multiplexed by clocks ck3 and ck7 in the calculation block (SEC) 24.
Exp. 55 shows congruences used for searching indexes σ (S2θ) and σ(S2Q) of S2 and S2Q, respectively. Assuming that index of “S” is σ, expression index 2σ is obtained from the second power of “S” based on the above-described table, and the following congruences are obtained with σ(θ) and σ(Q).
σ(S2θ)≡2σ+σ(θ) (mod 17)
σ(S2θ)≡2σ+σ(θ) (mod 15)
→σ(S2θ)≡2σ+σ(θ) (mod 17·15)
σ(S2Q)≡2σ+σ(Q) (mod 17)
σ(S2Q)≡2σ+σ(Q) (mod 15)
→σ(S2Q)≡2σ+σ(Q) (mod 17·15) [Exp. 55]
Exp. 56 shows congruences used for searching indexes σ(Sθ) and σ(SDT) of Sθ and SDT, respectively. Assuming that index of “S” is σ, the following congruences are obtained with σ(θ) and σ(DT).
σ(Sθ)≡σ+σ(θ) (mod 17)
σ(Sθ)≡σ+σ(θ) (mod 15)
→σ(Sθ)≡σ+σ(θ) (mod 17·15)
σ(SDT)≡σ+σ(DT) (mod 17)
σ(SDT)≡σ+σ(DT) (mod 15)
→σ(SDT)≡σ+σ(DT) (mod 17·15) [Exp. 56]
Exp. 57 shows congruences used for searching indexes σ (ζ−1θ) and σ(Ta) of ζ−1θ and Ta=S−1DT, respectively. Assuming that index of S−1 is −σ, the following congruences are obtained with σ(θ) and σ(DT).
σ(ζ−1θ)≡−σ+σ(θ) (mod 17)
σ(ζ−1θ)≡−σ+σ(θ) (mod 15)
→σ(ζ−1θ)≡−σ+σ(θ) (mod 17·15)
σ(Ta)≡−σ+σ(DT) (mod 17)
σ(Ta)≡−σ+σ(DT) (mod 15)
→σ(Ta)≡−σ+σ(DT) (mod 17·15) [Exp. 57]
In the above-described congruence calculations, a power of an element necessary for searching the sum of expression indexes is transformed to an expression index. Required are the second power and −1 power, and multiplexing with a clock is added to them. The transformation of the power to the expression index and the multiplexer circuit will be explained below with reference to
The expression indexes obtained as described above are input to the index/binary conversion circuit 1042, which is activated by clock ck3 or ck7, so that indexes (17) or (15) are converted to 5-binary or 4-binary numbers. These binary data are input to adders at the respective timings.
The result of the adders expresses a binary number of an expression index. Therefore, to decode this to the expression index component itself, pre-decoders described above are used. That is, the binary number is divided two bits by two bits into quaternary number, and in addition, such a signal will be formed that corresponds to zero of four bits octal number.
These pre-decoded signals are input to the index (17), (15) & latch circuit 1043 shown in
This circuit is activated by clocks ck4 and ck8, and the output is latched by clocks ck4′ and ck8′. It is in need of preparing two systems of latch in accordance with different timings because the circuit is multiplexed. As finite field elements required later, there is an expression index of S2θ to be latched by clock ck4′.
It will be explained still another calculation part (i.e., PC circuits 451, 461 and 462), which are multiplexed with clocks ck4 and ck7 or ck8 in the calculation block (SEC) 24. In this part, product and sum of the expression index elements are taken. First, the product calculation will be explained, in which there is no clock multiplex.
Exp. 58 shows congruences used for searching index a (S2ζη) of S2ζη. Assuming that the index of “S” is σ, the second power of “S” becomes expression index 2σ in accordance with the above-described table. Therefore, assume that index of ζη is σ(ζη), and the following congruences are obtained.
σ(S2ζη)≡2σ+σ(ζη) (mod 17)
σ(S2ζη)≡2σ+σ(ζη) (mod 15)
→σ(S2ζη)≡2σ+σ(ζη) (mod 17·15) [Exp. 58]
Index/binary conversion circuit (i.e., circuit for converting index(17) and index(15) to 5-binary and 4-binary, respectively), which is activated by clock ck4, has already been formed as the same circuit activated by clock ck3 because the expression index of the second power of “S” has been obtained. Therefore the detailed circuit is not shown here.
The result obtained with adders is binary data. To decode this binary data, there are prepared pre-decoders for decoding it to the expression index component itself. This has already been explained. The pre-decoders divide the binary data two bits by two bits and convert it into quaternary number, and in addition, form a signal corresponding to zero of four bits octal number.
Index (17), (15) & latch circuit 1051 shown in
To search the sum of the finite field elements based on expression indexes thereof, the polynomial expression of the elements is obtained from the expression index, and it is required of the coefficients to be subjected to parity check. Therefore, the circuit has decoder portion 1061 for converting the expression index to the polynomial expression, and parity checker (PC) 1062.
The decoder portion 1061 is the same as described as the circuit for searching η and the like except that input numbers are four. Therefore, PC circuit 1062 becomes a 4-input circuit.
At the timing of the clock ck4, input signals are expression indexes such as S3η, S2ζ2, Sθ and ζη. Some of them have been multiplexed in the previous stage, and Sθ=FF and ζη=CC. At the clock ck7, input signals are the expression indexes of D2, ST and zero. ST has been multiplexed in the previous stage, and ST=AA.
Each decoder portion 1061 has a node corresponding to coefficients of “m” degree of the polynomial-expressed sum of the input signals, which is precharged by precharge circuit 1063, and the decoder portion 1061 is activated by clock ck4 or ck7. The connections between the respective expression indexes and the transistor gates are performed as similar to the above-described calculation example.
For each degree number “m”, 4-bit PC 1062 performs parity check for four nodes, and outputs coefficients (┌D)m, (b) m, which are the polynomial-expressed sum of the input signals. Although the input of the PC circuit is an inverted input signal, the result of the 4-bit parity check is not different from the case where the input is not inverted.
The number of inputs is three in practice. Therefore, PC circuit 1072 is used in such a manner that one of four inputs is set at Vss. At the timing of clock ck4, input signals are expression indexes of S3ζ, Sη and ζ2. At the timing of clock ck8, input signals are expression indexes of S2Q, SDT and T2, where S2 Q=EE and SDT=FF because these are multiplexed at the previous stage.
With respect to the second power of ζ and T, connection transformation is performed in the index multiplexer (17), (15) in accordance with the table prepared for transforming the expression index of the power of finite field elements. For the respective signals, nodes are prepared to correspond to the coefficients of the m-th degree of polynomial expression of the sum to be precharged by precharge circuit 1073, and decoder 1071 is activated by clock ck4 or ck8. Parity checking the three nodes of the respective elements for the respective “m”s with 4-bit PC 1072, polynomial expressed coefficients (┌)m and (c)m are obtained as the sums of inputs.
The number of inputs is three, and PC circuit 1082 is used in such a manner that one of four inputs is set at Vss.
At the timing of clock ck4, input signals are expression indexes of S4η, S2θ and ζ3. At the timing of clock ck8, input signals are expression indexes of Q, Ta and a4, where Q=DD, Ta=GG and a=BB because these are multiplexed at the previous stage.
With respect to the second and third powers of ζ and BB, respectively, connection transformation is performed in the index multiplexer (17), (15) in accordance with the table prepared for transforming the expression index of the power of finite field elements. For the respective signals, nodes are prepared to correspond to the coefficients of the m-th degree of polynomial expression of the sum to be precharged by precharge circuit 1083, and decoder 1081 is activated by clock ck4 or ck8. Parity checking the three nodes of the respective elements for the respective “m”s with 4-bit PC 1082, polynomial expressed coefficients (┌T)m and (B)m are obtained as the sums of inputs.
The output of 4-bit PC circuit is obtained as a seventh polynomial, which coincides with either one of elements pi(x) of GF(256). Therefore, the polynomial expression is converted to the expression index, which is used in the following calculation. The decoder circuit performing the conversion is the same as that used in the syndrome calculation, which generates hexadecimal number E[0;15] and F[0;15] from 8-bit coefficients of the polynomial expression. The detailed explanation of this decoder is omitted here.
When pi(x)=0, it may not be expressed as an index of α. In this case, E[0]=1 and F[0]=1, and no indexes are output. With respect to “b”, it is used for judging zero element. To simply judge the zero element without monitoring the index state, zero element judging circuit 1092 shown in
In the circuit multiplexed by clocks ck5 and ck9 as shown in
When pi(x)=0, it may not be expressed as an index of α. In this case, E[0]=1 and F[0]=1, and no indexes are output. With respect to ┌ and “c”, it is used for judging zero element. To simply judge the zero element, zero element judging circuits 1095 and 1096 shown in
Next, another calculation portion (including adders 441, 442 and PC circuit 471) in the calculation block (SEC part) 24 will be explained. Here, two products of elements and one sum of elements are calculated. The product calculation portion will be initially explained. At this portion, clock multiplex is not used.
Exp. 59 shows congruences used for searching index σ(D) of ┌−1┌D. Assuming that the index of ┌ is σ(┌), 1−power of ┌ becomes the expression index −σ(┌) in accordance with the above-described table. Further, assuming that the index of ┌D is σ(┌D), the following congruences will be obtained.
σ(D)≡−σ(┌)+σ(┌D) (mod 17)
σ(D)≡−σ(┌)+σ(┌D) (mod 15)
→σ(D)≡−σ(┌)+σ(┌D) (mod 17·15) [Exp. 59]
The following expression, Exp. 60, shows congruences used for searching index σ(T) of ┌−1┌T. Assuming that the index of ┌ is σ(┌) 1−power of ┌ becomes the expression index −σ(┌) in accordance with the above-described table. Further, assuming that the index of ┌T is σ(┌T), the following congruences will be obtained.
σ(T)≡−σ(┌)+σ(┌T) (mod 17)
σ(T)≡−σ(┌)+σ(┌T) (mod 15)
→σ(T)≡−σ(┌)+σ(┌T) (mod 17·15) [Exp. 60]
When searching the sums of expression indexes in the congruence calculations shown in Exps. 59 and 60, a necessary power of element is converted to the expression index. The necessary power is −1 power, and the expression index components of the index σ(┌) are output with the index multiplexers 1010 and 1011 shown in
In addition, to convert the expression index to binary data, it will be input to index/binary converting circuit 1012. This circuit is activated by clock ck5, the expression index components of mod 17 and mod 15 (i.e., index (17) and index (15)) are converted to 5 binary and 4 binary, respectively, and then input to adders.
The result obtained by the adder is binary data of the expression index component. Therefore, to decode the binary data to the expression index component itself, pre-decoders and index (17), (15) & latch circuit are used. These circuits are the same as above-described ones except that the circuits are activated by clock ck6 and output thereof is latched by clock ck6′. Therefore, the detailed explanation will be omitted here.
Input signals are the expression indexes of S4ζ2, S2ζη, ζσ and η2S. The circuit has nodes corresponding to the m-degree coefficients of the polynomial expression of the sum of the respective signals. These nodes are precharged by precharge circuit 1023. Decoders 1021 are activated by clock ck5. With respect to each “m”, parity check is performed for four nodes corresponding to the respective elements with each 4-bit PC 1022. As a result, coefficient (┌Q)m of the polynomial-expressed sum of inputs will be obtained.
The outputs of the 4-bit PCs 1022 constitute 7th-degree polynomial, which coincides with either one of pi(x) as elements of FG(256). Therefore, the polynomial expression is converted to the expression index, and it will be used in the successive calculation. The decoder circuit used for the conversion is the same as that used in the syndrome calculation, in which hexadecimal signals E[0;15] and F[0;15] are generated from 8-bit coefficients of the polynomial expression.
Pre-decoded signals are divided into the remainder class groups with an index (17), (15) & latch circuit, and expression index components of mod 17 and mod 15 are generated and latched. Since this circuit is the same as that described above except that clocks ck6 and ck6′ are used, the detailed explanation is omitted here. With respect to ┌Q, it is not used that it is zero, and there is no need of preparing a zero judgment circuit.
Error Searching (ES) Part 25
The calculation result in the SEC part 24 is used in the following error searching (ES) part 25. The calculation process of the ES part branches in accordance with cases. To generate signals used for judging the branches, as shown in
CUBE portion 500 in the calculation block (ES part) 25 is multiplexed by signals “case 1” and “case 3”. Therefore, first, the calculation with “case 1” will be explained.
In case of searching index σ(H) of cb−3/2, assuming that index of “b” is σ(b), and index of “c” is σ(c), −3/2 power of “b” is expressed as expression index −3/2σ(b) based on the above-described table, so that the following congruences, Exp. 61, are obtained.
σ(H)≡σ(c)−(3/2)σ(b) (mod 17)
σ(H)≡σ(c)−(3/2)σ(b) (mod 15)
→σ(H)≡σ(c)−(3/2)σ(b) (mod 17·15) [Exp. 61]
The following expression, Exp. 62, is a case of solving cubic equation w3+w=H to obtain “w”, thereby searching wb1/2. Substituting element of GF(256) for “w”, index σ(w3+W) is previously obtained. This index σ(w3+w) is compared with σ(H), and index σ(w) is obtained from “w”, then index σ(δ) of wb1/2 is calculated.
Assuming that index of “b” is σ(b), 1/2 power of “b” becomes expression index (1/2)σ(b) in accordance with the above-described table, the following congruences will be obtained.
σ(δ)≡σ(w)+(1/2)σ(b) (mod 17)
σ(δ)≡σ(w)+(1/2)σ(b) (mod 15)
→σ(δ)≡σ(w)+(1/2)σ(b) (mod 17·15) [Exp. 62]
The calculation with “case 3” in the CUBE portion 500 is as follows. Exp. 63 shows congruences used in case of searching index σ(H) of ζ2(ζ−1η)−3. Assuming that index of ζ is σ(ζ), the second power of ζ becomes expression index 2σ(ζ) in accordance with the above-described table. In addition, assuming that index of ζ−1η is σ(ζ−1η), −3 power of ζ−1η becomes expression index −3(ζ−1η) in accordance with the above-described table. Therefore, the following expression, Ex. 63, is obtained.
σ(H)≡2σ(ζ)−3σ(ζ−1η) (mod 17)
σ(H)≡2σ(ζ)−3σ(ζ−1η) (mod 15)
→σ(H)≡2σ(ζ)−3σ(ζ−1η) (mod 17·15) [Exp. 63]
The following expression, Exp. 64, is a case of solving cubic equation w3+w=H to obtain “w”, thereby searching (w+1)b1/2. Substituting element of GF(256) for “w”, index σ(w3+w) is previously obtained. This index σ(w3+w) is compared with σ(H), and index σ(w+1) is obtained from “w”, then index or σ(δ) of (w+1)b1/2 is calculated.
Assuming that index of “b” is σ(b), 1/2 power of “b” becomes expression index (1/2)σ(b) in accordance with the above-described table, the following congruences will be obtained.
σ(δ)≡σ(w+1)+(1/2)σ(b) (mod 17)
σ(δ)≡σ(w+1)+(1/2)σ(b) (mod 15)
→σ(δ)≡σ(w+1)+(1/2)σ(b) (mod 17·15) [Exp. 64]
The CUBE portion 500, which calculates the above-described congruences, is constituted as shown in
CUBE body 500b receives “x”, “y” and “z” with index/binary conversion circuits 1031a to 1031c, which convert these signals to binary numbers of expression indexes. “x” and “y” are converted via adder 1032 to binary number expression index of the product of elements. This is converted to expression index via pre-decoder 1033 and binary/index converter 1034, and then the cubic equation is solved by decoder 1035.
The solution is converted again to the binary number via index/binary converter 1036, and this is input to adder 1037 together with the binary number of “z”, so that the product is obtained. The result is processed via pre-decoder 1038 and binary/index converter 1039, the expression index of “δ ” may be obtained.
At the timing of “case 3”, in multiplexers 1043 and 1044 corresponding to mod 17 and mod 15, expression index components of signals “ζ” and “ζ−1η” are subjected to connection switching in accordance with these powers, and “x”, “y” and “z” are generated, respectively.
To convert the expression indexes to binary number data, index/binary converter 1051 shown in
The results obtained through the adders are binary data of the expression index components. Therefore, to convert them to the expression index components, pre-decoders will be used. The explanation of these pre-decoders is omitted here because there have already been explained above. The pre-decoders divide the binary data two bits by two bits and convert it into quaternary number, and in addition, form a 4-bit signals corresponding to zero of octal number.
These signals, i.e., expression index components, index (17) and index (15), are input to index (17), (15) & latch circuit 1052 in such a way that these are coupled to transistor gates “a” and “b” with the combinations shown in tables in
Since the equation is cubic, the solution is a maximum three elements. For example, in cases of σ(w)=51, 58 and 163, σ(H)=17 is obtained, and σ(w+1)=107, 182 and 238, respectively. In case of “H” is zero element, “w” is σ(w)=0 or w=0, and in that case w+1=0 or σ(w+1)=0.
These tables are arranged in order of σ(H), and in case there are three σ(w)'s at the same σ(H), these are sorted into three columns. Further, when “H” is zero element, “w” is “1” or zero element, so that the index of “w” or “w+1” is “0”.
In tables shown in
In tables shown in
In tables shown in
In tables shown in
The decoder circuit (i.e., σ(w), σ(w+1)(17)(15) decoder) 1061, which expresses the solution method of the cubic equation, has NAND connections, to which expression index components of σ(H) are input. The NAND connections are combined as a NOR connection for the respective groups of σ(w) or σ(w+1) in accordance with the tables. This circuit is activated by timing clock ck10 in “case 1”, and timing clock ck8 in “case 3”, and output thereof are latched by clock ck10′ and ck8′, respectively.
The expression index components of product wb1/2 and factor b1/2 of (w+1)b1/2 may be obtained wiring connection switching in the index multiplexer 1062.
To convert the decoder output to binary data for supplying it to adders, there is prepared index/binary converting circuit 1063. If the input is zero element, all bits of this circuit are kept “1”. By use of this, it will be judged that there is no “w” as a solution. This judgment is performed with “no index” judgment circuit 1064.
The result obtained by adders is binary data of the expression index component, which is to be decoded to the expression index component itself. This is achieved with the above-described pre-decoders. The pre-decoders divide the binary data two bits by two bits and convert it into quaternary number, and in addition, form 4-bit signal corresponding to zero of octal number.
These signals are coupled to the transistor's gates “a”, “b” in the index & latch circuit shown in
Next, the calculation of SQUARE portion 510 in the calculation block (ES part) 25 will be explained below. Calculations are different from each other in accordance with cases. First, the calculations in “case 1” will be explained.
The following expression, Exp. 65, shows such a case where σ(J) is searched as the index of Bδ−2. Assuming that the index of δ is σ(δ), −2 power of δ brings the expression index −2 σ(δ) in accordance with the above-described tables. Therefore, the following congruences are obtained.
σ(J)≡σ(B)−2σ(δ) (mod 17)
σ(J)≡σ(B)−2σ(δ) (mod 15)
→σ(J)≡σ(B)−2σ(δ) (mod 17·15) [Exp. 65]
The following expression, Exp. 66, shows such a case that quadratic equation u2+u=J is solved, and α0, β0=δu is searched based on two outputs “u”s. Substituting element of GF(256) for “u”, the index σ(u2+U) of u2+u is previously searched. Comparing this index σ(u2+u) with σ(J) to decode it in accordance with tables, so that index σ(u) is searched. Indexes σ(α0) and σ(β0) of δu are obtained in accordance with the following congruences.
σ(α0), σ(β0)≡σ(δ)+σ(u) (mod 17)
σ(α0), σ(β0)≡σ(δ)+σ(u) (mod 15)
→σ(α0), σ(β0)≡σ(δ)+σ(u) (mod 17·15) [Exp. 66]
Exp. 67 shows a case of searching index σ(K) of δS−2. The index of δ being σ(δ), and that of “S” being σ, −2 power of “S” becomes the expression index −2σ based on the above-described tables, and the following congruences are obtained.
σ(K)≡σ(δ)−2σ(mod 17)
σ(K)≡σ(δ)−2σ(mod 15)
→σ(K)≡σ(δ)−2σ(mod 17·15) [Exp. 67]
The following expression, Exp. 68, shows such a case that quadratic equation v2+v=K is solved, and α1, β1=Sv is searched based on two outputs “v”s. Substituting element of GF(256) for “v”, the index σ(v2+v) of v2+v is previously searched. Comparing this index a (v2+v) with σ(K) to decode it in accordance with tables, so that index σ(v) is searched. Indexes σ(α1) and σ(β1) of “Sv” are obtained in accordance with the following congruences.
σ(α1), σ(β1)≡σ(S)+σ(v) (mod 17)
σ(α1), σ(β1)≡σ(S)+σ(v) (mod 15)
→σ(α1), σ(β1)≡σ(S)+σ(v) (mod 17·15) [Exp. 68]
Exp. 69 shows a case of searching index σ(L) of α0α1−2. The index of α0 being σ(α0), and that of a1 being σ(α1), −2 power of α1 becomes the expression index −2σ(α1) based on the above-described tables, and the following congruences are obtained.
σ(L)≡σ(α0)−2σ(α1) (mod 17)
σ(L)≡σ(α0)−2σ(α1) (mod 15)
σ(L)≡σ(α0)−2σ(α1) (mod 17·15) [Exp. 69]
The following expression, Exp. 70, shows such a case that quadratic equation y2+y=L is solved, and α1y is searched based on two outputs “y”s. Substituting element of GF(256) for “y”, the index σ(y2+y) of y2+y is previously searched. Comparing this index σ(y2+y) with σ(L) to decode it in accordance with tables, so that index σ(y) is searched. Index σ(α1y) of α1y is obtained in accordance with the following congruences.
σ(α1y)≡σ(α1)+σ(y) (mod 17)
σ(α1y)≡σ(α1)+σ(y) (mod 15)
σ(α1y)≡σ(α1)+σ(y) (mod 17·15) [Exp. 70]
Exp. 71 shows a case of searching index σ(M) of β0β1−2. The index of β0 being σ(β0), and that of β1 being σ(β1), −2 power of β1 becomes the expression index −2σ(β1) based on the above-described tables, and the following congruences are obtained.
σ(M)≡σ(β0)−2σ(β1) (mod 17)
σ(M)≡σ(β0)−2σ(β1) (mod 15)
→σ(M)≡σ(β0)−2σ(β1) (mod 17·15) [Exp. 71]
The following expression, Exp. 72, shows such a case that quadratic equation z2+z=M is solved, and β1z is searched based on two outputs “z”s. Substituting element of GF(256) for “z”, the index σ(z2+z) of z2+z is previously searched. Comparing this index σ(z2+z) with σ(M) to decode it in accordance with tables, so that index σ(z) is searched. Index σ(β1z) of β1z is obtained in accordance with the following congruences.
σ(β1z)≡σ(β1)+σ(z) (mod 17)
σ(β1z)≡σ(β1)+σ(z) (mod 15)
→σ(β1z)≡σ(β1)+σ(z) (mod 17·15) [Exp. 72]
Next, the calculations in “case 2” are as follows.
Exp. 73 shows a case of searching index σ(J) of Bδ−2. The index of “B” being σ(B), and that of δ=ζ2/3 being σ(δ)=(2/3)σ(ζ), −2 power of δ becomes the expression index (−4/3)σ(ζ) based on the above-described tables, and the following congruences are obtained.
σ(J)≡σ(B)−(4/3)σ(ζ) (mod 17)
σ(J)≡σ(B)−(4/3)σ(ζ) (mod 15)
→σ(J)≡σ(B)−(4/3)σ(ζ) (mod 17·15) [Exp. 73]
The following expression, Exp. 74, shows such a case that quadratic equation u2+u=J is solved, and α0, β0=δu is searched based on two outputs “u”s. Substituting element of GF(256) for “u”, the index σ(u2+U) of u2+u is previously searched. Comparing this index σ(u2+u) with σ(J) to decode it in accordance with tables, so that index σ(u) is searched. Indexes σ(α0) and σ(β0) of δu are obtained in accordance with the following congruences.
σ(α0), σ(β0)≡σ(δ)+σ(u) (mod 17)
σ(α0), σ(β0)≡σ(δ)+σ(u) (mod 15)
→σ(α0), σ(β0)≡σ(δ)+σ(u) (mod 17·15) [Exp. 74]
Exp. 75 shows a case of searching index σ(L) of α0α1−2. The index of α0 being σ(α0), and that of α1=ζ1/3 being σ(α1)=(1/3)σ(ζ), −2 power of α1 becomes the expression index (−2/3)σ(ζ) based on the above-described tables, and the following congruences are obtained.
σ(L)≡σ(α0)−(2/3)σ(ζ) (mod 17)
σ(L)≡σ(α0)−(2/3)σ(ζ) (mod 15)
→σ(L)≡σ(α0)−(2/3)σ(ζ) (mod 17·15) [Exp. 75]
The following expression, Exp. 76, shows such a case that quadratic equation y2+y=L is solved, and α1y=X is searched based on two outputs “y”s. Substituting element of GF(256) for “y”, the index σ(y2+y) of y2+y is previously searched. Comparing this index σ(y2+y) with σ(L) to decode it in accordance with tables, so that index σ(y) is searched. Index σ(X) of α1y=ζ1/3y is obtained in accordance with the following congruences.
σ(X)≡(1/3)σ(ζ)+σ(y) (mod 17)
σ(X)≡(1/3)σ(ζ)+σ(y) (mod 15)
→σ(X)≡(1/3)σ(ζ)+σ(y) (mod 17·15) [Exp. 76]
Exp. 77 shows a case of searching index σ(M) of β0β1−2. The index of β0 being σ(β0), and that of β1=ζ1/3 being σ(β1)=(1/3)σ(ζ), −2 power of β1 becomes the expression index (−2/3)σ(ζ) based on the above-described tables, and the following congruences are obtained.
σ(M)≡σ(β0)−(2/3)σ(ζ) (mod 17)
σ(M)≡σ(β0)−(2/3)σ(ζ) (mod 15)
→σ(M)≡σ(β0)−(2/3)σ(ζ) (mod 17·15) [Exp. 77]
The following expression, Exp. 78, shows such a case that quadratic equation z2+z=M is solved, and β1z=X is searched based on two outputs “z”s. Substituting element of GF(256) for “z”, the index σ(z2+z) of z2+z is previously searched. Comparing this index a (z2+z) with σ(M) to decode it in accordance with tables, so that index σ(z) is searched. Index σ(X) of β1z=ζ1/3z is obtained in accordance with the following congruences.
σ(X)≡(1/3)σ(ζ)+σ(z) (mod 17)
σ(X)≡(1/3)σ(ζ)+σ(z) (mod 15)
→σ(X)≡(1/3)σ(ζ)+σ(z) (mod 17·15) [Exp. 78]
Next, the calculations in “case 3” will be explained below.
The following expressions, Exp. 79 and Exp. 80, are the same as Exp. 65 and Exp. 66, respectively. Therefore, the detailed description will be omitted.
σ(J)≡σ(B)−2σ(δ) (mod 17)
σ(J)≡σ(B)−2σ(δ) (mod 15)
→σ(J)≡σ(B)−2σ(δ) (mod 17·15) [Exp. 79]
σ(α0), σ(β0)≡σ(δ)+σ(u) (mod 17)
σ(α0), σ(β0)≡σ(δ)+σ(u) (mod 15)
→σ(α0), σ(β0)≡σ(δ)+σ(u) (mod 17·15) [Exp. 80]
Exp. 81 shows a case of searching index σ(L) of α0α1−2. The index of α0 being σ(α0), and that of α1=(δ+ζ−1η)1/2 being σ(α1)=(1/2)σ(δ+ζ−1ηζ), −2 power of α0 becomes the expression index −σ(δ+ζ−1ηζ) based on the above-described tables, and the following congruences are obtained.
σ(L)≡σ(α0)−σ(δ+ζ−1η) (mod 17)
σ(L)≡σ(α0)−σ(δ+ζ−1η) (mod 15)
→σ(L)≡σ(α0)−σ(δ+ζ−1η) (mod 17·15) [Exp. 81]
The following expression, Exp. 82, shows such a case that quadratic equation y2+y=L is solved, and α1y=X is searched based on two outputs “y”s. Substituting element of GF(256) for “y”, the index σ(y2+y) of y2+y is previously searched. Comparing this index σ(y2+y) with σ(L) to decode it in accordance with tables, so that index σ(y) is searched. Index σ(X) of α1y=(δ+ζ−1η)1/2y=X is obtained in accordance with the following congruences.
σ(X)≡(1/2)σ(δ+ζ−1η)+σ(y) (mod 17)
σ(X)≡(1/2)σ(δ+ζ−1η)+σ(y) (mod 15)
→σ(X)≡(1/2)σ(δ+ζ−1η)+σ(y) (mod 17·15) [Exp. 82]
Exp. 83 shows a case of searching index σ(M) of β0β1−2. The index of β0 being σ(β0), and that of β1=(δ+ζ−1η)1/2 being σ(β1)=(1/2)σ(δ+ζ−1ηζ), −2 power of β1 becomes the expression index −σ(δ+ζ−1ηζ) based on the above-described tables, and the following congruences are obtained.
σ(M)≡σ(β0)−σ(δ+ζ−1η) (mod 17)
σ(M)≡σ(β0)−σ(δ+ζ−1η) (mod 15)
→σ(M)≡σ(β0)−σ(δ+ζ−1η) (mod 17·15) [Exp. 83]
The following expression, Exp. 84, shows such a case that quadratic equation z2+z=M is solved, and β1z=X is searched based on two outputs “z”s. Substituting element of GF(256) for “z”, the index σ(z2+z) of z2+z is previously searched. Comparing this index σ(z2+z) with σ(M) to decode it in accordance with tables, so that index σ(z) is searched. Index σ(X) of β1z=(δ+ζ−1η)1/2z=X is obtained in accordance with the following congruences.
σ(X)≡(1/2)σ(δ+ζ−1η)+σ(z) (mod 17)
σ(X)≡(1/2)σ(δ+ζ−1η)+σ(z) (mod 15)
→σ(X)≡(1/2)σ(δ+ζ−1η)+σ(z) (mod 17·15) [Exp. 84]
Next, the calculations in “case 5” will be explained below.
Exp. 85 shows a case of searching index σ(L) of α0α1−2. The index of α0=S−1 being σ(α0)=σ(S−1ζ), and that of α1=S being σ(α1)=σ(S), −2 power of α1 becomes the expression index −2α(S) based on the above-described tables, and the following congruences are obtained.
σ(L)≡σ(S−1ζ)−2σ(S) (mod 17)
σ(L)≡σ(S−1ζ)−2σ(S) (mod 15)
→σ(L)≡σ(S−1ζ)−2σ(S) (mod 17·15) [Exp. 85]
The following expression, Exp. 86, shows such a case that quadratic equation z2+z=M is solved, and α1z=X is searched based on two outputs “z”s. Substituting element of GF(256) for “z”, the index σ(z2+z) of z2+z is previously searched. Comparing this index σ(z2+z) with σ(M) to decode it in accordance with tables, so that index σ(z) is searched. Index σ(X) of α1z=Sz=X is obtained in accordance with the following congruences.
σ(X)≡σ(S)+σ(z) (mod 17)
σ(X)≡σ(S)+σ(z) (mod 15)
→σ(X)≡σ(S)+σ(z) (mod 17·15) [Exp. 86]
In “case 6”, δ=b1/2, and the successive calculations are the same as in “case 1”. Note here that σ(δ) is replaced with (1/2)σ(b).
In “case 7”, δ=c1/3, and the successive calculations are the same as in “case 1”. Note here that σ(δ) is replaced with (1/3)σ(c).
The calculations in “case 8” are as follows.
The following expression, Exp. 87, shows such a case that quadratic equation y2+y=L is solved with α1=S and L=0, and α1y=X is searched based on two outputs “y”s, i.e., y=0 and y=1. Substituting element of GF(256) for “y”, the index σ(y2+y) of y2+y is previously searched. Comparing this index σ(y2+y) with σ(L) to decode it in accordance with tables, so that index σ(y) is searched. Index σ(X) of α1y=Sy=X is obtained in accordance with the following congruences.
σ(α1y)≡σ(S)+σ(y) (mod 17)
σ(α1y)≡σ(S)+σ(y) (mod 15)
→σ(α1y)≡σ(S)+σ(y) (mod 17·15) [Exp. 87]
The following expression, Exp. 88, shows such a case that quadratic equation z2+z=M is solved with β1=S and M=0, and β1z is searched. This is the same as Exp. 87 except that α1, L and “y” are replaced with β1, M and “z”, respectively.
σ(β1z)≡σ(S)+σ(z) (mod 17)
σ(β1z)≡σ(S)+σ(z) (mod 15)
→σ(β1z)≡σ(S)+σ(z) (mod 17·15) [Exp. 88]
The circuit configuration of SQUARE portion 510, which is used to calculate the above-described congruences, is formed as shown in
Multiplex circuit 510a multiplexes signals B, δ, S, α0, α1, β0, β1, ζ−1θ, ζ, “0”, Q, δ+ζ−1, “b” and “c” in accordance with cases, and passes signals to SQUARE portion body 510b such as “j”, “k”, “l”, “m”, “p” and “q”.
SQUARE portion body 510 has index/binary converters 1061a to 1061f, which receive the signals “j”, “k”, “l”, “m”, “p” and “q” to convert them to binary numbers of the expression indexes. “j”, “k”, “l” and “m” are converted to binary numbers of the expression indexes of the products of elements via adders 1062a and 1062b, and the binary data are converted to expression indexes via pre-decoders 1063a, 1063b and binary/index converters 1064a, 1064b, and then solutions of quadratic equations, i.e., σ(J) to σ(u), σ(K) to σ(v), are searched at decoders 1065a, 1065b.
The decoded solutions are converted to binary data again in the index/binary converters 1066a to 1066d. These binary data and other binary data of “p” and “q”, which are obtained by index/binary converters 1061e and 1061f, are input to adders 1067a to 1067d, so that products are searched.
These products are processed in pre-decoders 1068a to 1068d and index/binary converters 1069a to 1069d, and outputs “e”, “f”, “g” and “h” are obtained as expression indexes. These outputs “e”, “f”, “g” and “h” become error searching results directly or via other calculation processes.
Next, a series of index multiplexers (17), (15) constituting the multiplex circuit 510a will be explained with reference to
These switching signals are generated from clocks with dashes because these become activated ones after certain timing clocks necessary for the respective cases. In the drawing, switching signals as outputs of switching signal generating circuits 1071 and 1072 are expressed as combinations of case numbers “ci” (i=1 to 8) and clock names “ckj′” (j=6, 7, . . . ).
Index multiplexer 1073 is for switching the input expression index components to couple them to outputs “j”, “k”, “l”, “m”, “p” and “q” with the above-described switching signals as those of clocked inverters. Explaining in detail with reference to the “case 1” clocked by timing clock ck13′ shown in
To express the expression indexes of multiplexer outputs “j”, “k”, “l”, “m”, “p” and “q” by binary numbers, timing clock generating circuit 1081 and binary/index converting circuit 1082 controlled by the timing clocks are prepared as shown in
As shown in the timing clock generating circuit 1081 shown in
The index/binary converting circuit 1082 is activated by a selected timing clock, and stores binary data state of the expression index component during the clock pulse width.
The binary numbers obtained in the index/binary converting circuit 1082 are input to adders. If one input of the adder is zero element, the adder output is not determined. Therefore, zero element judgment is performed at this input stage. For the purpose, zero element judgment circuit 1083 is prepared as shown in
The results obtained at the adders are binary numbers of the expression index components. To decode them into the expression index components themselves, the above-described pre-decoders are used. The pre-decoders divide the binary data two bits by two bits and convert it into quaternary number, and in addition form zero of octal number.
The pre-decoded signals of adder's bits “s0” to “s3” are processed in the index (17), (15) & latch shown in
This circuit is multiplexed and activated by the following clocks: ck12 and ck14 in “case 1”; ck6 and ck8 in “case 2”; ck10 and ck12 in “cases 3”, “case 6” and “case 7”; ck7 in “case 5”; and ck10 in “case 8”. The latch is activated during the clock pulse width as corresponding to multiplexing. The outputs are given to the following calculation stage for solving the quadratic equation.
Next, tables used for solving the quadratic equations u2+u=J, v2+v=K, y2+y=L and z2+z=M will be explained below.
Constituting decoders with respect to the expression indexes of “L” obtained in the calculation based on the tables, expression index components of “y” will be searched. Since one “L” corresponds to two “y”, there are prepared two buses bs1 and bs2, to which decoder outputs are divided and supplied independently.
For example, σ(y)=119 and 153 corresponds to σ(L)=17. Therefore, data bus is divided into two buses, bs1 and bs2, to which σ(y)=119 and σ(y)=153 are output, respectively. In case of zero element, i.e., in case there is not generated an expression index of “L”, signal “zero element” is output (L=0). This case will be defined by: “0” is set in “bs1”; and zero (no index) state is set in “bs2”.
What is used in the practical decoding is an expression index. Therefore, the values of the expression index components σ(y)(17) of “y”, which are output to buses bs1 and bs2, are corresponded to the respective expression indexes of “L”. If there is no relationship between the expression indexes, there is not a solution.
The expression indexes are distinguished based on the NAND connections, gates of which are applied with the expression index components σ(L)(17) and σ(L)(15). In accordance with the expression index components of “y”s, the respective groups are NOR-connected. Pre-charged nodes are activated by clocks in correspondence with cases as follows: ck12 and ck14 in “case 1”; ck 6 and ck8 in “case 2”; ck10 and ck12 in “case 3”, “case 6” and “case 7”; ck7 in “case 5”; and ck10 in “case 8”. As a result, the expression index components σ(y)(17) and σ(y)(15) are generated to the respective buses.
In correspondence to zero element of “L”, based on the “zero element”, σ(y)(17)=0, σ(y)(15)=0 are output to bs1 as corresponding to σ(y)=0 while “no index” to bs2.
Index/binary converting circuit 1092 is prepared for converting the sum of the expression indexes to binary data used in the adder calculation. In this circuit, the indexes are converted to 5-binary or 4-binary data.
“no index” generating circuit 1093 is prepared for designating the case where two solutions are not searched. If there is no output index, the outputs of the index/binary converting circuit 1092 become all “1” bits. “no index” generating circuit 1093 is formed of NAND circuits, each of which is able to detect all “1” state. This circuit monitors the data state of “bs1” because there are output binary data to “bs1” when there are indexes.
The adders for searching the sums of expression indexes are formed to search the expression index components of the product of α-power of finite field element “A” and β-power of finite field element “B”. It is in need of preparing adders for the respective expression indexes. Therefore, in this embodiment, mod 17-use adders and mod 15-use adders are necessary.
As shown in
The results of adders are binary data of the expression index components, which are decoded to the expression indexes themselves. This is performed with pre-decoders as described above. The pre-decoders divide the adder's output bits “s0” to “s3” two bits by two bits and convert it into quaternary number, and in addition form a signal corresponding to zero of 4-bit octal number.
Based on the pre-decoded signals, the index (17), (15) & latch shown in
The first timing is defined by: clock ck13 in “case 1”; ck7 in “case 2”; ck11 in “case 3”, “case 6” and “case 7”; ck 6 in “case 5”; and ck9 in “case 8”. The second timing is defined by: clock ck15 in “case 1”; ck9 in “case 2”; ck13 in “case 3”, “case 6” and “case 7”; ck8 in “case 5”; and ck11 in “case 8”. Decoders are effective in the clock pulse width and correspond to multiplexing, and outputs thereof are kept during the cycles at the respective latches.
To search error locations based of the calculation result of SQUARE part 25, there is such a case as to search the sum of finite field elements. This case will be explained with reference to
Input signals are the expression indexes of Sk and Sk (k=3, 5, 7) during the pulse width of timing clock ck2. Sk is switched with “a” by timing clock cck′ while Sk is switched with α1y1(=output “e” of SQUARE portion), α1y2 (=output “f” of SQUARE portion) and β1z1 (=output “g” of SQUARE portion) by timing clock cck′. There are nodes corresponding to “m”-degree coefficients of the polynomial expressed sum for these signals, which are pre-charged by pre-charge circuit 1110, and the decoder 1110 is activated by clock ck2 or cck′.
The connections of the expression index signals of the “m”-degree nodes to the transistor gates are defined from the tables shown above. For each “m”, two nodes of the respective elements are subjected to parity checking with 2-bit PC 1112, the polynomial expressed coefficients of the sum of input signals are obtained.
Timing signal cck′ is generated by the logic circuit shown in the drawing as follows: from clock ck15′ in “case 1”; from clock ck13′ in “case 6” and “case 7”; and from clock ck11′ in “case 8”.
As shown in
Input signals are expression indexes of ζ−1η and δ during the pulse width of timing clocks c3ck9, which are switched by β1z1(=output “h” of SQUARE portion) and “a”, respectively, by timing clock cck′. There are nodes corresponding to “m”-degree coefficients of the polynomial expressed sum for these signals, which are pre-charged by pre-charge circuit 1120, and the decoder 1121 is activated by clock ck2 or cck′.
The connections of the expression index signals of the “m”-degree nodes to the transistor gates are defined from the tables shown above. For each “m”, two nodes of the respective elements are subjected to parity checking with 2-bit PC 1123, the polynomial expressed coefficients of the sum of input signals are obtained.
The timing signal c3ck9 is generated from the logic circuit 1124 shown in the drawing based on clock ck9 in “case 3”.
ζ, η, θ and X1, X2, X3, X4 obtained as the sums of finite field elements are obtained as 7th-degree polynomials, and coincide with either one of pi(x) defined as element of GF(256). Therefore, these polynomials are converted in such a manner that the index of root α of m1(x) is converted to the expression index defined by mod 17 and mod 15, and the expression indexes will be used in the successive calculations. The pre-decoders are the same as used for decoding the expression index of syndromes, and the detailed explanation is omitted here. The pre-decoders express the 256 binary signal states, which express the coefficients of 8-bit pi(x), as the combinations of signals Ai, Bi, Ci and Di (i=0 to 3), and further convert them into sixteen signals E[i] and F[i], i.e., E[0;15] and F[0;15].
Based on the pre-decoded signals, index(17),(15) & latch circuit 1131 shown in
In case of pi(x)=0, there is no index of α. That is, since E[0;15]=1 and F[0;15]=1 in this case, indexes are not output. With respect to ζ, η and θ, to judge zero element, zero element judgment circuit 1131 is prepared as a decoder. In detail, signals ζ=0, η=0, and θ=0 are generated and latched when corresponding to zero elements.
The second timing is defined by the logic gate circuit 1133 shown in
With respect to X4, index (17), (15) & latch 1141 shown in
The first timing is defined by the logic circuit 1142 shown in
Clock CLK for activating the ELD 1151 is generated from logic circuit 1153 shown in
Connected to the signal node of X3 is as follows: expression index σ(X3) in case of c1678ckX′; expression index “g” in case of c235ckefgh′; and Vss in case of c4ck6′. Connected to the signal node of X4 is as follows: expression index σ(X4) in case of c1678ckX′; expression index “h” in case of c235ckefgh′; and Vss in case of c4ck6′.
Clocks used for connection exchanging are generated from the logic circuit 1154 shown in
Error Correction (RC) Part 26
[Method of Testing the 4EC-EW-BCH System]
A large capacitive memory stores in general such a data quantity that is fourth power of the data bit number “h” dealt in the ECC system or more. For example, in case of h=255, the memory is usually formed as 16G bit one. In consideration of this point, n case the ECC system satisfies the condition of: it does not generate errors; and it is bale to notice that there is no error or there are non correctable errors, it becomes possible to substitute an ECC system test for the memory cell test. This leads to the test cost reduction of the memory.
A test method of the ECC system will be explained with reference to
The number of test patterns of the test data e(x), i.e., test number, is h4 in case of 4EC-EW-BCH system. For example, in case of h=255, the test number becomes about 4G. This is less than that of a normal memory test, in which all bits are sequentially subjected to a test sequence by several bits in parallel. In this test, it becomes high-seed test because there is no need of read/write operation for the memory, and the test time will be greatly reduced.
Assuming that the ECC system is complete, even if memory cell test is not performed, correctable errors are corrected, and the system notices “non correctable” when there are non-correctable errors. Therefore, users may cope with the “non-correctable” state to, for example, exclude the error bit portion of data. To make this possible, it is necessary to output “non correctable” signal, which designates externally that correctable errors are generated.
File memory 1200 is formed in such a manner that the address space of the memory cell array is divided into blocks each corresponding to a data quantity used in one cycle ECC. Although the address space division is shown like the physical division, it is a logical one. Note here that it is permissible that the logical blocks correspond to the physical blocks.
In the memory cell array, there is prepared a redundant array area 1201, which includes some redundant blocks, i.e., a replacing block area used for replacing blocks, in which non correctable errors are generated at a test time or a normal busy time, with redundant blocks. The on-chip ECC circuit 1202 performs error-detection and error-correction for each block, and generates “non correctable” when error correction is impossible.
In the system, contents addressable memory (CAM) 1301 is prepared for generating address of the file memory 1200 with a key address supplied from CPU 1400 in a host device. This CAM 1301 is configured to output the input address as it is to the file memory 1200 when there is no address corresponding to the key.
There is further prepared address generating circuit 1302, which generates sequentially redundant block addresses of the redundant array area 1201 of the file memory 1200 when receiving the signal “non correctable” generated at a test time or a busy time. As described later, addresses to be replaced to the redundant block addresses within those sequentially generated from the address generating circuit 1302 will be written into CAM 1301. Thereinafter, CAM 1301 generates the stored redundant block addresses in place of the defective block addresses when they are sent from CPU 1400. Therefore, CAM 1301 and address generating circuit 1302 constitute a memory controller 1300.
The operation of this system will be explained in detail below. At an initial test time, test data is written into all blocks in the file memory 1200 from CPU 1400. This test data is, for example, all “1” data or all “0” data, or preferably set at such a data pattern that easily generates errors as being specific in this memory.
Then sequentially generate read addresses via CPU 1400, and access the file memory 1200. The read addresses are input to CAM 1301 in the memory controller 1300. At the beginning, the input addresses are passed through CAM 1301 and sent to the file memory 1200. In case there is not generated “non correctable” from the file memory 1200, i.e., in case it is error correctable even if there are errors, CAM 1301 is not written.
When an address sent from CPU coincides with an initial bad block address, and ECC circuit 1200 outputs signal “non correctable”, address generating circuit 1302 is activated to generate a redundant block address in the redundant array area 1201. The redundant block address is sent to file memory 1200 and CAM 1301 simultaneously. At this time, CPU 1400 receives the “non correctable” and temporally stop the address transmitting.
CAM 1301 stores the redundant block address sent from address generating circuit 1302 with the address sent from CPU, which is dealt with a key address. When the file memory is accessed with the redundant block address, and “non correctable” is output again, address generating circuit 1302 generates the following redundant block address to be stored in CAM 1301.
The above-described operation will be repeated in such a range that replaceable redundant block addresses are obtained. As a result, initial bad block addresses and the corresponding redundant block addresses to be replaced with the initial bad block addresses are written into CAM 1301.
For example as shown in
In case CAM 1301 is a volatile memory such as DRAM and the like, it is in need of performing the initial test at every power-on time. If the address storing portion of CAM 1301 is formed of a non-volatile memory like the file memory 1200. There is no need of performing the initial test at every power-on time. In this case, the correspondence of the key addresses and redundant block addresses obtained at the initial test time may be written into the non-volatile memory at a time after the initial test.
In case a bad block is generated during the memory is used, and “non correctable” is output, it is possible to deal with it as similar to the above-described process. That is, address generating circuit 1302 is activated to generate a redundant block address, which is written into CAM 1301 as a to-be-replaced address. Hereinafter, accessing to the bad block is switched to the redundant block address with CAM 1301. Whether newly generated bad block address data is to be output to the external or not, it is judged by the program of CPU 1400.
The above-described defect relieving scheme is not limited such a case that the redundant cell array is prepared independently of the normal accessed memory cell array. The scheme is also effective in such a case that there is not prepared a specific redundant cell array. In this case also, the correspondence between the bad block addresses and replaceable block addresses to be accesses in place of the bad block addresses is written into CAM. As a result, it becomes possible to access so as to avoid the bad block. Note here that the replaceable block address stored to be used in place of the bad block addresses will be excluded from the normal accessing.
In a field of the NAND-type flash memory, as shown in
As described above, testing fully the ECC circuit, without testing the flash memory itself, it becomes possible to such an address replacement control that the redundant blocks are used in place of bad blocks. Therefore, it becomes possible to constitute a memory system with a high reliability.
The test method explained with reference to
The maximum number of errors is four in such a range that high speed error searching is performed with decoders by use of tables. According to the embodiment described above, 4-bit error correction will be perfectly done within an operating time of several decades [ns], and the reliability of a large capacitive file memory and the like will be achieved without reducing the performance.
Additionally, if the ECC system is subjected to the operation test, it becomes possible to use only error correctable areas in the file memory. Therefore, there will be provides a large capacitive memory, which is useful to reduce the test cost.
[Outline of 4EC-EW-BCH System in this Embodiment]
(a) There has been achieved a high speed ECC system, which is installed in a memory to be 4-bit error correctable in such a manner as to perform the operation in a real time on the data read/write path. In this system, the error searching polynomial is divided into a product of low degree polynomial's factors with coefficient parameters introduced, and the coefficient parameters are searched from syndromes, and then the factor polynomials are solved. In every stage, the equation is divided into an unknown part and a syndrome part by use of a variable conversion, and the solution will be searched via a high speed matching operation process between the previously calculated solution candidate and the syndrome operation result. The high speed calculation of the matching operation is achieved by use of the relationship between the expression indexes of the finite field elements. In addition, there is provided a test method of the ECC system, in which an error pattern is added to the input data, and it is confirmed that the error correction is performed. As a result, it becomes possible to use the memory without testing the memory itself.
(b) In the 4-bit error correctable ECC system, an error location searching equation is transformed to the product of two factor equations. The dividing coefficient parameters are calculated from syndromes, and the factor equations are solved, whereby error locations are output.
(c) An ECC system is installed in a memory to be correctable up to 4-bits for each cluster of data by use of the elements of finite field GF(256). The system takes notice to the external of the memory that errors are not correctable when there are generated 5-bit errors or more.
(d) An ECC system is installed in a memory to be correctable up to a certain number of bits for each cluster of data by use of the elements of finite field GF(256). The system takes notice to the external of the memory that errors are not correctable when there are generated errors more than the certain number. In addition, there is prepared a test path, in which an error data pattern is added externally to the input code data to be written into the memory, and the error correction is confirmed without writing the code data into the memory.
(e) A cluster of memory data areas may be defined as a defective area, which is unusable. As a result, the memory data becomes highly reliable.
This invention is not limited to the above-described embodiment. It will be understood by those skilled in the art that various changes in form and detail may be made without departing from the spirit, scope, and teaching of the invention.
Number | Date | Country | Kind |
---|---|---|---|
2007-210659 | Aug 2007 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5168468 | Magome et al. | Dec 1992 | A |
6185134 | Tanaka | Feb 2001 | B1 |
6651212 | Katayama et al. | Nov 2003 | B1 |
6957378 | Koga et al. | Oct 2005 | B2 |
7076722 | Shibata | Jul 2006 | B2 |
RE40252 | Tanaka | Apr 2008 | E |
7644342 | Shibata | Jan 2010 | B2 |
7836377 | Toda | Nov 2010 | B2 |
7890843 | Toda et al. | Feb 2011 | B2 |
7941733 | Toda | May 2011 | B2 |
7962838 | Toda | Jun 2011 | B2 |
8001448 | Toda | Aug 2011 | B2 |
8194434 | Toda | Jun 2012 | B2 |
20060195766 | Shibata | Aug 2006 | A1 |
20070198902 | Toda | Aug 2007 | A1 |
20070220400 | Toda et al. | Sep 2007 | A1 |
20070266291 | Toda et al. | Nov 2007 | A1 |
20080082901 | Toda | Apr 2008 | A1 |
20090154916 | Huang et al. | Jun 2009 | A1 |
20100332942 | Wezelenburg et al. | Dec 2010 | A1 |
Number | Date | Country | |
---|---|---|---|
20090049366 A1 | Feb 2009 | US |