Error processing for non-volatile memories

Information

  • Patent Grant
  • 12147303
  • Patent Number
    12,147,303
  • Date Filed
    Wednesday, January 25, 2023
    a year ago
  • Date Issued
    Tuesday, November 19, 2024
    a month ago
Abstract
A solution is proposed for error processing, wherein n byte error positions of n byte errors are predefined (where n is a positive integer), wherein this involves determining whether there is a further byte error position on the basis of the n byte error positions and on the basis of n+1 error syndrome components of a first error code.
Description
TECHNICAL FIELD

The present disclosure relates to semiconductor components, in particular to memories and semiconductor components containing memories.


BACKGROUND OF INVENTION

There is an ongoing need to store ever-increasing amounts of data in semiconductor memories. For example, non -volatile memories (NVM) retain stored data even after being powered off.


Errors can occur in the stored data and in many applications it is necessary to identify and if possible correct such errors.


Data present in the form of bytes may be detected byte by byte and corrected byte by byte. In this case, a byte can comprise at least two bits. At least one error in at least one bit of a byte is referred to as a byte error. If at least one bit of a byte is erroneous, a byte error is present. If only at least one bit of a single byte is erroneous, this corresponds to a 1-byte error.


The correction of 1-byte errors is described for example in [Bossen, D.: b-Adjacent Error Correction, IBM J. Res. Dev., July 1970, pages 402 to 408].


If bits of two different bytes are erroneous, this corresponds to a 2-byte error. Accordingly it holds true that a k-byte error is present if bits in k bytes are erroneous (i.e. at least one bit in each of the k bytes has an error).


The byte error correction can be effected by means of a Reed-Solomon code, for example.


A circuit arrangement for correcting two-byte errors using a Reed-Solomon code is described in OKANO [Okano, H., Imai, H.: A Construction Method of High-Speed Decoders Using ROM's for Bose-Chaudhuri-Hocquengiem and Reed-Solomon Codes, IEEE TRANSACTIONS ON COMPUTERS, VOL. C-36, NO. 10, October 1987, pages 1165 to 1171]. In this case, it is disadvantageous that the correction of 2-byte errors described in OKANO is comparatively slow.





BRIEF DESCRIPTION OF DRAWINGS


FIGS. 1 to 3 show a memory.



FIG. 4 shows one example of the use of a first and a second error code, wherein the second error code is used to provide at least one byte error position which can be used by the first error code for correcting at least one further byte error;



FIG. 5 shows a symbolic circuit diagram for determining α12 and α1·α2;



FIG. 6 shows a symbolic circuit diagram for determining a further byte error position α3.





DETAILED DESCRIPTION

An error code may in general be used to correct bytes. For example, 43 data bytes may be stored together with 3 bytes of error code. Should a failure occur and the data become corrupted in one of the data bytes the data in the error code may be used to identify which of the data bytes are incorrect and to correct that data byte. Such an error code will be referred to as a first error code in the following.


A further code, referred to as a second error code may also be provided. Such a second error code may be linked to the physical structure of the memory which accordingly will now be further described, purely by way of example.


In an embodiment, a memory 100 includes a plurality of physical storage bytes 102 each of 8 bits 104. Note that in this example the term “byte” is used for a data size. In other examples, the byte may be 6 or 10 bits for example, or indeed any desired number of bits.


The memory may be a resistive random access memory, RRAM, in which each bit of data is stored using a material that can exist in a plurality of different resistance states. For example, a high resistance may indicate a 0 bit and a low resistance a 1 bit.



FIG. 1 illustrates a single bit 104 having storage element 110 connected to a corresponding bit line 106 which is in turn connected to node 122. The storage element 110 is connected through select transistor 112 and a source line to ground. The bit line 106 is connected to a plurality of storage elements 110 (not shown in FIG. 1) each of which has a respective select transistor connected to a respective word line 114.


Node 122 is connected to one input of a read-out comparator 108 and also to capacitor 116. The other input of comparator 108 is connected to a voltage reference at voltage VREF. One PMOS transistor 118 connects node 122 to a positive precharge voltage VPRE, and NMOS transistor 120 connects node 122 to the bit line 106. Thus, single bit 104 is coupled to the one input of the read-out comparator 108.


In use, a signal on word line 114 selects a specific bit 104 using the respective select transistor 112.


Capacitor 116 is charged to precharge voltage VPRE by switching transistor 118 on. Then, transistor 118 is switched off and the capacitor discharges through transistor 120, storage element 110 and select transistor 112 towards ground.


In the event that the storage element 110 is in a low resistance state the capacitor 116 will discharge faster than if the storage element 110 is in the high resistance state. This means that the voltage will fall below voltage VREF more quickly and so comparator 108 will be triggered more quickly.


The data stored in the byte 102 is stored using a second code in which all data is represented by a byte with four bits having the value 1 and four bits having the value 0. In this example, with 8 bits in each byte, this means that 6 bits of input data may be stored. For example, input data 000000 may be represented by 11110000, input data 000001 by 11100001, and so on, so that each possible 6 bit input data value has a different value in the second code. This allows the data to be read as will now be described.



FIG. 2 illustrates a plurality of bits 104 making up byte 102. The respective outputs from respective comparators 108 of the respective bytes are fed into decoder 130).


The circuit of decoder 130 is illustrated in FIG. 3. A plurality of NAND gates 602, 603, 604, 605, are used as an input stage 610. Each of these triggers when the four inputs all rise to the value 1. An output stage 620 includes a plurality of further NAND gates 606, 607, 610, 611 and NOR gates 608, 609612, including output NOR gate 612 arranged such that output 601 of the circuit triggers when one of the input stage NOR gates 602, 603, 604, 605 is triggered. This means that output 601 will be triggered as soon as the capacitors 116 of exactly four respective bits 104 have all discharged to the voltage VREF. The output then stops the read operation in this state, with the outputs of four comparators being in the “1” state and the other four comparators of the eight bit byte being in the “0” state.


Since it is known that the codeword stored in byte 102 must have four 1 and four 0 values, the four bits that have discharged most quickly may be identified as the four “1” values of the codeword and the other four bits as “0”. Accordingly this value (all eight bits) may be output as the data read from the memory. If the output is correct, the eight bits will include four 1 bits and four 0 bits, for example 10101010, which is a codeword of the second code.


It takes a finite time for the output 601 to stop the read operation and it is possible therefore that a further bit triggers. In this case, the output may include a different number of 1 and 0 bits, for example 10101110. In this case, this value is not a codeword of the second code.


Note that in this way the memory may store a plurality j of physical bytes. Each physical byte in the memory includes a number k of bits, where k is a positive integer. In the example described above k=8. Each physical byte represents a logical byte with m bits, where m is a positive integer less than k. In the example m is 4. Thus, each 8 bit codeword, for example 10101010, stored as a physical byte, represents a 6 bit logical There is a one to one byte, for example 110110. correspondence between physical and logical bytes, but the difference is that because of the use of the second code the number of bits of each logical byte is lower than the number of bits of each physical byte.


The j logical bytes in this case may be selected from a first error code such as a Reed-Solomon code. Only certain combinations of j logical bytes are codewords of this first error code. If the j logical bytes read from the memory are not a codeword of the first error code, an error has occurred which may in some cases be corrected.


The additional information from the second error code which in this example is related to the physical structure of the decoder 130 of the memory may be combined with information from the first error code to improve error detection and error correction, as will now be described in more detail.


Byte-error-detecting and byte-error-correcting codes (also referred to as error code s) can be used for error correction and error detection in respect of data stored in memory cells, for example. One example of an error code is the Reed-Solomon code (in this respect, also see explanations below).


In the case of a byte error, the position of the erroneous bytes is to be determined and, if the byte error is intended to be corrected, the correct value of the byte is also to be ascertained.


The position of the erroneous byte is determined on the basis of the byte error position (also referred to as byte error position value, indicating which byte or which bytes is or are (possibly) erroneous). By way of example, a value 1 for the byte error position can indicate that the byte is erroneous, and a value 0 can indicate that the byte is not erroneous.


A byte error value indicates the value by which an erroneous byte differs from its correct value. If each byte comprises m bits, then the byte error value also comprises m bits. By way of example, a correction can be carried out by exclusive-ORing (XORing) the bits of the erroneous byte component by component with the associated bits of the byte error value.


A t-byte error states that a number of t bytes is erroneous. In order to correct a t-byte error, t byte error positions and t byte error values are required.


For a byte having m bits, the byte can be described as an element of the Galois field GF(2m). The following generally holds true: if m p-order values where p>2 form a byte and if p is a prime number, a byte can be described as an element of the Galois field GF(pm). In this case, m is for example a positive integer greater than 2.


In the present example, bytes having m bits are used. Accordingly, there are 2m different m-bit bytes.


By way of example, the intention is for a first number of N byte errors to be corrected. Accordingly, an N byte error (N≥1) is corrected.


For a second number N1 of byte errors, the corresponding byte error position at which a byte error has occurred may already have been determined. During a correction, it is then necessary only to determine the byte error value for these N1 byte errors at the known byte error positions.


For a third number N2 of byte errors, it may be necessary to determine both the byte error value and the byte error position. In this case, N1+N2=N may hold true. In this case, N2≥1 and it may hold true that N2=1.


Example: Two Error Codes

By way of example, the m-bit byte in the error-free case forms a code word of the Reed-Solomon code. The Reed -Solomon code here serves as a first error code.


In addition, the m-bit byte can be transformed into a code word of a second error code before it is stored in a memory. The second error code can be an n1 out-of-n code.


In a first example with m=4 a plurality of 4 bit bytes in the error-free case form the code word of a Reed -Solomon code, the first error code. By way of example, at least one byte of the code word may be a check byte of the Reed-Solomon code. There are 2m=24=16 different values per byte in this example.


In this example, the second error code is a 3-out-of-6 code having 20 code words. A 3-bit byte of the Reed -Solomon code can for example be transformed into a code word of the second error code and be stored in six memory cells of a memory (in this respect, cf. e.g. U.S. Pat. No. 10,903,859 B2). In this case, each 6-bit byte of the first error code is reversibly uniquely transformed into one of the 20 code words of the 3-out-of-6 code of the second error code. These code words represent the m bit logical byte. This example corresponds with the example of FIGS. 1 to 3 above.


Those skilled in the art will realise that different values of m may be used, to allow more data to be stored in each byte.


In a further example with m =6 a plurality of 6-bit bytes in the error-free case form the code word of a Reed- Solomon code. By way of example, at least one byte of the code word may be a check byte of the Reed-Solomon code. There are 2m=26=64 different values per byte in this example.


In this example, the second error code is a 4-out-of-8 code having 70 code words. A 6-bit byte of the Reed -Solomon code can for example be transformed into a code word of the second error code and be stored in eight memory cells of a memory. In this case, each 6-bit byte of the first error code is reversibly uniquely transformed into one of the 70 code words of the 4-out -of-8 code of the second error code.


In the course of reading out from the memory, in the error-free case, code words of the 4-out-of-8 code are read out and transformed back into 6-bit bytes. In the error-free case, the 6-bit bytes present after the inverse transformation once again yield a code word of the first error code.


As early as in the course of reading out from the memory, it is possible to check whether a code word of the 4-out -of-8 code is present: if 4 ones and 4 zeros have not been read, a code word of the 4-out-of-8 code is not involved. In this case, the byte read out is erroneous, i.e. a byte error position was determined for this byte by means of the 4-out-of-8 code.


The read-out non-code word of the 4-out-of-8 code is transformed back into an (erroneous) m-bit byte. A predefined value from the 64 possible values (e.g. the value 0) can be used for this purpose. It is advantageous, however, for information that this byte is erroneous to be provided with detection of a non-code word of the 4-out-of-8 code. The inverse-transformed 6-bit value then no longer occurs because it has to be assumed that this byte has to be corrected by means of the second error code. In accordance with the explanations above, only the byte error value has to be determined for this erroneous byte.


Consequently, the checking of the values of the second error code that are read out from the memory cells makes it possible to determine at least one byte error position for the bytes of the first error code. In this case, it is advantageous that the differentiability of the bytes is maintained by the transformation and the inverse transformation: each 6-bit byte is assigned an 8-bit byte, and vice versa. The byte error position thus uniquely identifies the byte, irrespective of whether it has 6 bits or 8 bits.


The fact that the first error code does not have to be used to determine this byte error position is an advantage. Check bytes can thus be saved in the first error code.



FIG. 4 illustrates one example of the use of a first and a second error code. In this example, 43 bytes of payload data are supplemented by 3 check bytes. Each byte comprises 6 bits. The (43+3=) 46 bytes yield (in the error-free case) a code word of the first code, here of a Reed-Solomon code (RS code). In this case, j=46 and m =6.


In a next step, each of the bytes of the code word of the RS code is transformed into a code word of the second code. In the present example, the second code is a 4-out -of-8 code: the code words of the 4-out-of-8 code have 4 ones and 4 zeros. Each byte is thus a physical byte with k=8 bits. 46 bytes arise once again after the transformation. These bytes are stored in the memory as j 8-bit codewords of the second error code. Each of the 46 codewords is thus stored in a physical byte of k=8 bits representing the structure of the memory.


To read data from the memory, j=46 bytes of physical bytes of 8 bits are read from the memory. In the course of this, a check is made as to whether each of the bytes read is a code word of the 4-out-of-8 code.


In accordance with one exemplary implementation, and as explained above, the individual bytes can be read from the memory using time. In this case, the read operation can advantageously already be ended when 4 bits of the same type, i.e. either 4 times the value 0 or 4 times the value 1, have been read. For the remaining bits that have not arrived, the respective other value is then assumed. This approach uses the property of the 4-out-of-8 code, in which code words have 4 ones or 4 zeros. Errors may occur here such that five instead of four identical values are read and a code word of the second code is thus no longer present. For details with regard to reading memory cells in the time domain, reference should be made to U.S. Pat. No. 9,805,771 B2, for example: in this case, a read current formed in the course of reading out depending on a resistance value stored in the memory cell is integrated in a capacitor. The memory cells that reach a specific voltage of the capacitor the fastest in the temporal order can each be assigned the value 1, and the cells that reach the specific voltage the slowest can each be assigned the value 0.


If the 8-bit byte read from the memory is a code word of the second error code, i.e. of the 4-out-of-8 code, then the inverse transformation of this code word into a 6-bit value (more generally, into m bits) is effected in accordance with the assignment mentioned above. If all 46 bits are code words of the second error code, the inverse transformation into 46 6-bit bytes takes place, which are a code word of the first error code, i.e. of the RS code, in the error-free case.


If at least one of the 8-bit bytes read is not a code word of the 4-out-of-8 code, then there is at least one byte error position, which is communicated to the subsequent correction step in order to initiate the correction of this at least one erroneous byte by means of the first error code.


The approach described here also allows the detection of the further byte error position by way of the first error code (with subsequent correction), which position is associated with a 4-out-of-8 code word that was corrupted into a further 4-out-of-8 code by means of a plurality of errors. This incorrect 4-out-of-8 code word is not detectable by the second error code and the byte error position for this code word thus also cannot be ascertained by way of the second error code. However, an additional byte error may be present which is detected by the second error code. The second error code yields the byte error position for this additional byte error. On the basis of this byte error position, the first error code can then ascertain and correct the further byte error position (corresponding to the corrupted 4-out-of -8 code word).


Alternative Second Error Codes

The invention is not restricted to the second error code being an n1-out-n code. By way of example, an m-bit byte of the first error code can be mapped onto an (m+1) -bit byte of the second error code by a parity bit additionally being formed from the m bits of the byte of the first error code and being appended to the m bits of the first error code. A code word of the second error code may be an (m+1)-bit word having an even number of ones.


In accordance with a further example, the m bits of a byte of the first error code can also be stored in duplicated fashion and thus redundantly in the memory. In the course of reading, the second error code can be used to monitor whether the same m-bit byte was obtained twice.


Moreover, different m-bit bytes of the first error code can be transformed into code words of the second error code (e.g. different error codes) according to different specifications. In this regard, for example, a first 6-bit byte can be transformed into a code word of an 4-out -of-8 code and a second 6-bit byte is transformed into a 7-bit byte (6 bits with an additional parity bit).


The second error code is not absolutely necessary for the approach described here. All that is necessary is that, for an erroneous byte, a byte error position is determinable which can be used in the determination of a further byte error position by the first error code and does not have to be determined by the latter.


By way of example, measured values that are in a specific previously known range of values can be stored for each payload data byte. The measured value can be e.g. temperature, air pressure, length of components or the like.


The payload data bytes can be stored together with check bytes in a memory, the payload data bytes and the check bytes (in the error-free case) forming a code word of the first error code. If, in the course of reading from the memory, it is found that a payload data byte is not in the known range values, then a byte error position can be detected for this byte.


The examples described here make it possible in particular to improve the error correction and error detection of a first error code. In this case, the further byte error position is intended to be determined efficiently and with low complexity.


General Description of Reed-Solomon Codes

Some terms and properties of Reed-Solomon codes are explained below.


By way of example,

    • t-byte-error-correcting codes and
    • t-byte-error-correcting and (t+1)-byte-error -detecting codes


      are considered. In particular, the cases t=2 and t=1 are taken into account.


By way of example, known Reed-Solomon codes can be used as byte-error-correcting codes. For Reed-Solomon codes reference should be made for example to [Lin, S., Costello, D.: Error Control Coding, Prentice Hall, 1983, pages 170 to 177] or [Wicker, S.: Error Control Systems for Digital Communication and Storage, Prentice Hall, 1995, pages 214 to 224].


A 1-byte-error-correcting and 2-byte-error-detecting Reed-Solomon code has an H matrix HByte* as follows:










H
Byte
*

=

(




α
0




α
1




α
2







α


2

m

-
2







α
0




α
2




α
4







α

2


(


2
m

-
2

)








α
0




α
3




α
6







α

3


(


2
m

-
2

)






)





(
1
)







In this case, αi are elements of the Galois field GF(2m). They are present for example in an exponential representation. α can be a primitive element of the Galois field GF(2m). The exponents j of αj should be interpreted modulo 2m−1.


It is possible to derive from the H matrix in accordance with equation (1) an H matrix










H
Byte

=

(




α
0




α
0




α
0







α
0






α
0




α
1




α
2







α


2

m

-
2







α
0




α
2




α
4







α

2


(


2
m

-
2

)






)





(
2
)








by multiplying, for i=0, . . . , (2m−2) the i-th column by α−i. This changes only the shape of the H matrix, and not the code, since α−i≠0. This is also described for example in [Fujiwara, E.: Code Design for Dependable Systems, Wiley, 2006, page 65], wherein the value “1” is used for α0 since α0 is the unity of the Galois field used.


The following H matrix is used for a 2-byte-error -correcting and 3-byte-error-detecting code:










H
Byte

=

(




α
0




α
0




α
0







α
0






α
0




α
1




α
2







α


2

m

-
2







α
0




α
2




α
4







α

2


(


2
m

-
2

)








α
0




α
3




α
6







α

3


(


2
m

-
2

)








α
0




α
4




α
8







α

4


(


2
m

-
2

)






)





(
3
)







Each column of the H matrix specified in equation (3) corresponds to one byte.


If the length of the code is equal to N bytes or m·N bits (wherein each byte has m bits), only N columns of the H matrices in accordance with equation (1) or equation (3) are used. By way of example, the remaining (last) 2m−2−N columns can then be deleted.


Generally, for a t-byte-error-correcting and t+1-byte -error-detecting code, the H matrix can be specified as follows:







H
Byte

=

(




α
0




α
0




α
0







α
0






α
0




α
1




α
2







α


2

m

-
2







α
0




α
2




α
4







α

2


(


2
m

-
2

)








α
0




α
3




α
6







α

3


(


2
m

-
2

)








α
0




α
4




α
8







α

4


(


2
m

-
2

)

























a
0




a


2

t

-
1





a


2

t

-
2








a

2


t
·

(


2
m

-
2

)







)





A code that can correct 2-byte errors and detect 3-byte errors is considered by way of example below.


If an error occurs, a correct vector v=v0, . . . , vN−1 is disturbed to an erroneous vector v′=v′0, . . . , v′N−1.


The components v0, . . . , vN−1 of the vector v are bytes that each comprise m bits, such that vi=v1i, . . . , vmi holds true for i=0, . . . , N−1. The v1i, . . . , vmi are thus the m bits of the i-th byte.


An m-bit byte can also be referred to as an element of the Galois field GF(2m).


If a 1-byte error is present, only a single byte is erroneous, that is to say that for a specific i ϵ{0, . . . , N−1} the associated i-th byte is erroneous.


If the correct i-th byte is designated by vi=v1i, . . . , vmi and the erroneous i-th byte is designated by v′i=v′1i, . . . , v′mi, 1 or 2 or up to m bits of the correct i -th byte can differ from the erroneous i-th byte.


A byte error in the i-th byte can be described by

    • the erroneous byte position i and
    • a byte error value

      ei=vi⊕v′i=v1i⊕v′1i, . . . , vmi⊕v′mi.


In this case, it should be noted that “⊕” denotes the exclusive-OR operation.


The position of an i-th byte can also be designated by αi.


If the intention is to correct a byte error having the byte error value ei in the byte position i, then a byte error correction value that is equal to the byte error value is to be determined for the byte position i.


In this example, for a byte error to be corrected, the byte error value is equal to the byte error correction value; in this respect, the terms byte error value and byte error correction value can be used synonymously.


In order to avoid a confusing number of indices, hereinafter byte error values are designated by the alphabetic letters a, b, c.


A byte error correction value for the i-th byte can also be designated by a(i).


Byte positions can be designated by i, j, k, . . . or by αi, αj, αk, . . . , wherein α is a generating element of the Galois field GF(2m).


An error syndrome s has syndrome components (also referred to as components, error syndrome components, partial error syndromes or partial syndromes) s1, s2, s3, s4, s5, which are determined for the H matrix in accordance with equation (4) as:

s1=(α0, α0, α0, . . . , α0)·(v′0, . . . , v′M−1)T,
s2=(α0, α1, α2, . . . , α2m−2)·(v′0, . . . , v′M−1)T,
s3=(α0, α2, α4, . . . , α2(2m−2))·(v′0, . . . , v′M−1)T,
s4=(α0, α3, α6, . . . , α3(2m−2))·(v′0, . . . , v′M−1)T,
s5=(α0, α4, α8, . . . , α4(2m−2))·(v′0, . . . , v′M−1)T,

. . .

s2t+1=(α0, α2t, α2·(2t), . . . , α2t·(2m−2))·(v′0, . . . , v′M−1)T.


In this case,

v′=(v′0, . . . , v′M−1)T

is a column vector having a number of M components each having m bits. This column vector can also be referred to as a transposed vector of the row vector (v′0, . . . , v′M−1).


Each of the syndrome components s1, s2, . . . s2 t+1 is a byte having m bits.


If a 1-byte error is present, then it holds true that s1≠0 and










Det

(




s
1




s
2






s
2




s
3




)

=
0.




(
5
)







If a 2-byte error is present, then it holds true that










Det

(




s
1




s
2






s
2




s
3




)


0




(
6
)








and










Det

(




s
1




s
2




s
3






s
2




s
3




s
4






s
3




s
4




s
5




)

=
0.




(
7
)







If a 3-byte error is present, then it holds true that










Det

(




s
1




s
2




s
3






s
2




s
3




s
4






s
3




s
4




s
5




)


0




(
8
)








and










Det

(




s
1




s
2




s
3




s
4






s
2




s
3




s
4




s
5






s
3




s
4




s
5




s
6




)

=
0.




(
9
)







This can be correspondingly continued up to a t-byte error: in this regard, a t-byte error is present if it holds true that:










Det

(




s
1




s
2




s
3







s
t






s
2




s
3




s
4







s

t
+
1
























s
t




s

t
+
1





s

t
+
2








s


2

t

-
1





)


0




(
10
)








and










Det

(




s
1




s
2




s
3







s

t
+
1







s
2




s
3




s
4







s

t
+
2
























s
t




s

t
+
1





s

t
+
2








s

2

t





)

=
0.




(
11
)







The number of byte errors can be determined by the determination of the values of the specified determinant. This is complex as the number of possible errors increases: in this regard, for establishing whether a t -byte error is present according to equations (10) and (11), it is necessary to determine the value of a determinant having 2·t syndrome components as elements. These are to be stored in addition to the payload data bytes. Each syndrome component corresponds to a byte having m bits.


A byte error position can be determined for example as zeros of the locator polynomial.


A zero of a locator polynomial can be described as an element of the corresponding Galois field GF(2m).


In this case, a first, second, third element, etc. of the Galois field is designated by α1, α2, α3, etc. This does not stipulate which element of the Galois field is specifically involved.


If

0, α1, α2, . . . , αi, . . . , α2m−2}

is for example the set of the 2m−1 elements of the Galois field not equal to 0 in their exponential representation, then α1, α2, α3, etc. are elements of this set. By way of example,

α110,
α23,
α30

or some other assignment can hold true.


The locator polynomials result as follows for the different numbers of byte errors:

    • for a 1-byte error:

      L1(x)=(x+α1)=x+σ(1)1;  (12)
    • for a 2-byte error:

      L2(x)=(x+α1)(x2)=x2+xσ(2)1+σ(2)2;  (13)
    • for a 3-byte error:














L
3

(
x
)

=



(

x
+

α
1


)



(

x
+

α
2


)



(

x
+

α
3


)


=








=


x
3

+


x
2




σ

(
3
)

1


+


x
2




σ

(
3
)

2


+


σ

(
3
)

3



;







(
14
)









    • for a 4-byte error:

















L
n

(
x
)

=



(

x
+

α
1


)



(

x
+

α
2


)



(

x
+

α
3


)



(

x
+

α
4


)


=








=


x
4

+


x
3




σ

(
4
)

1


+


x
2




σ

(
4
)

2


+

x



σ

(
4
)

3


+


σ

(
4
)

4



;







(
15
)









    • for a n-byte error:














L
n

(
x
)

=



(

x
+

α
1


)




(

x
+

α
2


)

·

·

(

x
+

α
n


)



=


x
n

+


x

n
-
1





σ

(
n
)

1


+


x

n
-
2





σ

(
n
)

2


+

+



σ

(
n
)

n

.







(
16
)







In this case, the coefficient σ(j)i of a locator polynomial for j=1, . . . , n and i=1, . . . , n denotes a known elementary symmetric function of j variables αi to αj. This can be verified by multiplying out

(x+α1)(x+α2)·. . . ·(x+αn)


In this regard, it holds true for example that

σ(1)11
σ(2)112,
σ(2)21·α2,
σ(3)1113,
σ(3)2119 α21·α32·α3,
σ(3)31·α2·α3,
σ(4)11134,
σ(4)21·α21·α31·α42·α32·α43·α4,
σ(4)31·α2·α31·α2·α41·α3·α42·α3·α4,
σ(4)41·α2·α3·α4,

. . .


. . .

σ(n)111+. . . +αn,

. . .

σ(n)n1·α2·. . . ·αn.


In this case, as illustrated in the examples, a symmetric function σ(k)i where 1≤i≤k is dependent on k variables α1, . . . , αk. It contains all possible






(



k




i



)





different products of its variables which are combined by way of the operation “+” in the Galois field GF(2m). If i=1, the







(



k




i



)

=
k





products each consist only of one of the variables. The addition is effected in the Galois field GF(2m). It corresponds here to component-by-component addition modulo 2. The variables α1, α2, α3, etc. are used here as variables of the symmetric functions.


Between the components of the error syndromes and the components of the corresponding locator polynomials, the following relationship is known for a t-byte error:











(




s
1




s
2




s
3







s
t






s
2




s
3




s
4







s

t
+
1







s
3




s
4




s
5







s

t
+
1
























s

t
-
1





s
t




s

t
+
1








s


2

t

-
2







s
t




s

t
+
1





s

t
+
2








s


2

t

-
1





)

·

(





σ

(
t
)

t







σ

(
t
)


t
-
1








σ

(
t
)


t
-
2













σ

(
t
)

2







σ

(
t
)

1




)


=


(




-

s

t
+
1








-

s

t
+
2








-

s

t
+
3













-

s


2

t

-
1








-

s

2

t






)

.





(
17
)







This is described for example in [Wicker, S.: Error Control Systems for Digital Communication and Storage, Prentice Hall, 1995, pages 215], where the designation Si is used for the syndrome component si and the designation Λi is used for the coefficient σ(t)i.


If, by way of example, a Galois field GF(qm)where q32 2 is used, the negative signs in equation (17) can be omitted since addition and subtraction are identical in a Galois field GF(2m). By way of example, hereinafter the Galois field GF(2m) is used and the negative signs in equation (17) are omitted.


Further (Additional) Byte Error in the Case of a Byte Error at a Given Byte Error Position

An explanation is given below by way of example of how

    • a further byte error position is determined if a further byte error has occurred, or
    • it is determined that no further byte error has occurred if a number of N1 byte errors is known.


In this case, the number of byte errors N1 is greater than or equal to 1.


It is taken into account that one byte error or a plurality of byte errors has/have already occurred beforehand. The at least one further byte error may then occur in accordance with the above formulation.


If, for example, N1 byte error positions have been determined, then a further (N1+1)-th byte error position can be determined if a byte error has occurred at this position. If no further byte error position is erroneous, then no further byte error has occurred either.


It should be noted here that a byte error that has occurred is a byte error that is detectable by means of an error code. It is conceivable for a non-detectable byte error to be present, which remains undetected and in this respect is regarded as not having occurred in accordance with the present explanations.


For example, a first byte error position α1 is given. The byte error position states that an error was detected for this byte comprising a plurality of bits.


If a further byte error has occurred in a different byte, a second byte error position α2 can be determined. Moreover, it can be determined that no further byte error position is present if no second byte error has occurred.


In the case of a 1-byte error with the predefined byte error position α1 and with a byte error value α, it holds true that

s1α,  (18)
s21·α=s1·α1.  (19)


It is not necessary for the byte error value α to be known.


In the case of a 2-byte error with

    • the known byte error position α1 with a byte error value a and
    • a further (still unknown) byte error position α2 with a byte error value b, it holds true that

      s1=a+b,  (20)
      s21·a+α2·b,  (21)
      s312·a+α22·b  (22)

      and thus

      s1·α1=(a+b)·α1=a·α1+b·α1≠s2=a·α1+b·α2.  (23)


It is not necessary for the values α2, a and b to be known.


Given a known byte error position α1, on the basis of

s1·α1+s2=0  (24)

it can be determined that no 2-byte error is present, and on the basis of

s1·α1+s2≠0  (25)

it can be established that no 1-byte error is present.


If no 1-byte error is present, rather a 2-byte error with a known byte error position α1 and a byte error position α2 to be determined is present, then it holds true that

s1σ(2)2+s2σ(2)1=s3  (26)

where

σ(2)21·α2=σ(1)1·α2 and σ(2)112=σ(1)12

and thus

s1·α1·α2+s212)=s3=s1·σ(1)1·α2+s2(σ(1)12).  (27)


Equation (27) is solvable with respect to the byte error position α2 to be determined:










α
2

=




s
3

+


s
2

·

α
1






s
1

·

α
1


+

s
2



=




s
3

+


s
2

·


σ

(
1
)

1







s
1

·


σ

(
1
)

1


+

s
2


)


.






(
28
)







The byte error position α2 is determinable from the three syndrome components s1, s2, s3 and the symmetric functions σ(1)11. As explained, the byte error position α1 is previously known. It is therefore not necessary to determine the solutions of the corresponding locator polynomial.


Further (Additional) Byte Error in the Case of Two Byte Errors at Two (Different) Given Byte Error Positions


Alternatively, a description is given of how, in the case of two known byte error positions α1 and α2, it is determined whether a third byte error is present and, if a third byte error is present, how a third byte error position can then be determined. In this case, the byte error positions α1, α2 and α3 differ from one another.


If a 2-byte error is present, it holds true that

s1·σ(2)2+s2(2)·σ(2)1+s3=0.  (29)


This results from:

s1=a+b,
s21·a+α2·b,
s312·a+α22·b,
σ(2)21·α2,
σ(2)112,


In this case, a and b are the corresponding byte error values and α1 and α1 are the byte error positions. If equation (29) holds true, then no 3-byte error is present.


If a 3-byte error with the byte error values a, b and c and the byte error positions α1, α2, α3 is present then it holds true that:

s1=a+b+c,
s21·a+α2·b+α3·c,
s312·a+α22·b+α32·c,
σ(2)21·α2,
σ(2)112,


This yields the following:









s
1

·


σ

(
2
)

2


+


s
2

·


σ

(
2
)

1


+

s
3


=


c
·

(



α
1



α
2


+


α
1



α
3


+


α
2



α
3


+

α
3
2


)


=


c
·

(


α
1

+

α
3


)

·

(


α
2

+

α
3


)


=

D
.







A value D=0 is only possible if (at least) one of the following conditions is met:

    • c=0;
    • α31 or α32 which is at odds with the fact that the byte error positions α1, α2 and α3 are different.


A 3-byte error can thus be detected from the validity of the inequality

s1=σ(2)2+s2σ(2)1+s3≠0


If a 3-byte error is present, then the third byte error position α3 can be determined using the known byte error positions α1, α2 and from the syndrome components s1, s2, s3 and s4 in accordance with the relationship

s1·σ(3)3+s2·σ(3)2+s3·σ(3)1=s4  (30)

where

σ(3)31·α2·α3,
σ(3)21·α21·α32·α3,
σ(3)1123


The byte error position α3 is the erroneous further (i.e. additional) byte error position to be determined. It follows from equation (30) that







s
4

=





s
1

·

α
1




α
2



α
3


+


s
2

·

(



α
1



α
2


+


α
1



α
3


+


α
2



α
3



)


+


s
3

·

(


α
1

+

α
2

+

α
3


)



=




s
1

·


σ

(
2
)

2




α
3


+


s
2

·

[




σ

(
2
)

1

·

α
3


+


σ

(
2
)

2


]


+


s
3

·

[



σ

(
2
)

1

+

α
3


]









and thus for the byte error position α3 to be determined:










α
3

=




s
4

+


s
3

·


σ

(
2
)

1


+


s
2

·


σ

(
2
)

2





s
3

+


s
2

·


σ

(
2
)

1


+


s
1

·


σ

(
2
)

2




=



s
4

+


s
3

·

[


α
1

+

α
2


]


+



s
2

·

α
1




α
2





s
3

+


s
2

·

[


α
1

+

α
2


]


+



s
1

·

α
1




α
2









(
31
)







The byte error position α3 is determinable from the four syndrome components s1, s2, s3, s4 and the symmetric functions σ(2)1, σ(2)2 which emerge from the known byte error positions α1 and α2. It is not necessary to ascertain the solutions of the corresponding locator polynomial (here: third degree) or to use more than four syndrome components. This reduces the complexity to a considerable extent.


Further (Additional) Byte Error in the Case of a Plurality of Byte Errors at Different Given Byte Error Positions

This approach can be extended accordingly: A further byte error position can be determined if three or more byte error positions are previously known. If k byte error positions are known, then k+2 error syndrome components are known.


For example, the following hold true for the byte error positions to be determined

    • α4, if three byte error positions α1 . . . α3 are known:











α
4

=



s
5

+


s
4




σ

(
3
)

1


+


s
3




σ

(
3
)

2


+


s
2




σ

(
3
)

3





s
4

+


s
3




σ

(
3
)

1


+


s
2




σ

(
3
)

2


+


s
1




σ

(
3
)

3





;




(
32
)









    • α5, if four byte error positions α1 . . . α4 are known:














α
5

=



s
6

+


s
5




σ

(
4
)

1


+


s
4




σ

(
4
)

2


+


s
3




σ

(
4
)

3


+


s
2




σ

(
4
)

4





s
5

+


s
4




σ

(
4
)

1


+


s
3




σ

(
4
)

2


+


s
2




σ

(
4
)

3


+


s
1




σ

(
4
)

4





;




(
33
)









    • α6, if five byte error positions α1 . . . α5 are known:














α
6

=



s
7

+


s
6




σ

(
5
)

1


+


s
5




σ

(
5
)

2


+


s
4




σ

(
5
)

3


+


s
3




σ

(
5
)

4


+


s
2




σ

(
t
)

5





s
6

+


s
5




σ

(
5
)

1


+


s
4




σ

(
5
)

2


+


s
3




σ

(
5
)

3


+


s
2




σ

(
5
)

4


+


s
1




σ

(
5
)

5





;




(
34
)









    • α7, if six byte error positions α1 . . . α6 are known:













α
7

=




s
8

+


s
7




σ

(
6
)

1


+


s
6




σ

(
6
)

2


+


s
5




σ

(
6
)

3


+


s
4




σ

(
6
)

4


+


s
3




σ

(
6
)

5


+


s
2




σ

(
6
)

6





s
7

+


s
6




σ

(
6
)

1


+


s
5




σ

(
6
)

2


+


s
4




σ

(
6
)

3


+


s
3




σ

(
6
)

4


+


s
2




σ

(
6
)

5


+


s
1




σ

(
6
)

6




.





(
35
)







In general, for N1 known byte error positions α1, . . . , αN1, the further byte error position αN1+1 results as:










α


N
1

+
1


=




s


N
1

+
2


+


s


N
1

+
1





σ

(

N
1

)

1


+


s

N
1





σ

(

N
1

)

2


+

+


s
2




σ

(

N
1

)


N
1






s


N
1

+
1


+


s

N
1





σ

(

N
1

)

1


+


s


N
1

-
1





σ

(

N
1

)

2


+

+


s
1




σ

(

N
1

)


N
1





.





(
36
)







It can be advantageous to use the following symmetric functions σ(j)i where j≥1 and i≤j: the function σ(j)i for j>1 arises from the functions σ(j−1)k where k≤j−1 and a further variable αk:

σ(2)1=σ(1)12  (37)
σ(2)2=σ(1)12  (38)
σ(3)1=σ(2)13  (39)
σ(3)2=σ(2)1·α3+σ(2)2  (40)
σ(3)3=σ(2)2·α3  (41)
σ(4)1=σ(3)14  (42)
σ(4)2=σ(3)1·α4+σ(3)2  (43)
σ(4)3=σ(3)2·α4+σ(3)3  (44)
σ(4)4=σ(4)3·α4  (45)

. . .

σ(n+1)1=σ(n)1n+1  (46)
σ(n+1)2=σ(n)1·αn+1+σ(n)2  (47)
σ(n+1)3=σ(n)2·αn+1+σ(n)3  (48)

. . .

σ(n+1)n+1=σ(n)n·αn+1  (49)


Consequently, from already ascertained symmetric functions σ(j)i and an additional variable, further symmetric functions can be determined step by step and used for ascertaining the further byte error position.


Exemplary Implementation


FIG. 2 shows a symbolic arrangement, as a realization of a circuit, for example, which makes it possible to determine the symmetric functions σ(2)i12 and σ(2)21·α2 on the basis of the byte error positions α1 and α2.


An adder 21 having two m-bit-wide inputs and an m-bit -wide output enables the component-by-component addition modulo 2 (XORing) of the byte error positions α1 and α2 present at the inputs. A Galois field multiplier 22 having two m-bit-wide inputs and an m-bit-wide output enables the multiplication α1·α2.



FIG. 3 shows an exemplary circuit arrangement for determining a byte error position as using the syndrome components s1 and s4 and two known byte error positions α1, α2 according to equation (31). In this case, the byte error positions α1, α2 were combined in accordance with the arrangement shown in FIG. 2 to form the symmetric functions σ(2)1 and σ(2)2, which are input signals of the arrangement shown in FIG. 3.



FIG. 3 has Galois field multipliers 11 to 15, having two m-bit-wide inputs and an m-bit-wide output. Furthermore, two adders 16, 17 having two m-bit-wide inputs and an m -bit-wide output for component-by-component addition modulo 2 (XORing) and an inverter 18 having an m-bit-wide input and an m-bit-wide output are illustrated. The components 11 to 18 are arranged in such a way that their circuity interconnection yields the byte error position α3 as a result.


These examples proposed herein can be based on at least one of the following solutions. In particular, combinations of the following features can be used in order to achieve a desired result. The features of the method can be combined with (any) arbitrary feature (s) of the device or of the circuit, or vice versa.


In order to achieve the object, a method for error processing is proposed,

    • wherein n byte error positions of n byte errors are predefined, wherein n is a positive integer,
    • which method involves determining whether there is a further byte error position on the basis of the n byte error positions and on the basis of n+1 error syndrome components of a first error code.


In one development, the further byte error position is determined by way of the n byte error positions and the n+1 error syndrome components of the first error code.


In one development, the first error code is a byte error code, in particular a Reed-Solomon code.


One development involves detecting that no further byte error is present if no further byte error position is determinable.


In one development, the further byte error position is determined depending on at least one symmetrical function of the n byte error positions.


In one development,

    • in the error-free case a byte of the first error code is transformed into a code word of a second error code,
    • a byte error position is determined if a non-code word of the second error code is detected.


In one development, the second error code is an n1-out -of-n code, wherein 1≤n1<n≤2 holds true.


In one development, code words of the second error code are stored in a memory.


In one development, in the error-free case code words of the second error code are read out from the memory and transformed back into bytes of the first error code. In one development, the reading out from the memory is effected taking account of a temporal order.


In one development, if a non-code word of the second error code is detected in the course of the reading out from the memory, a byte error position is determined for this byte of the first error code.


In one development, the further byte error position α2 is determinable such that the following holds true:








α
2

=



s
3

+


s
2

·

α
1






s
1

·

α
1


+

s
2




,




wherein α1 denotes the predefined byte error position and s1, s2, s3 denote syndrome components.


Moreover, a device for error processing is proposed, which is configured to determine whether there is a further byte error position on the basis of n byte error positions and on the basis of n+1 error syndrome components of a first error code, wherein the n byte error positions of n byte errors are predefined and wherein n is a positive integer.


In one development, the device is furthermore configured to determine the further byte error position by way of the n byte error positions and the n+1 error syndrome components of the first error code.


A circuit arrangement is also specified, comprising at least one of the devices described herein.


The device and/or circuit arrangement can be embodied as parts of an integrated circuits or memory chip or separately therefrom.


An method for error processing is further described, including reading a memory, the memory including a plurality of physical bytes, each physical byte containing k physical bits, the memory containing data stored in the memory in a format comprising a plurality j of logical bytes each having m bits of a first error code, wherein only certain possible values of the j bytes represent codewords of the first error code, the data of each logical byte of m bits being stored in each physical byte using a second error code, whereby only 2m codewords of the second error code are allowed values to be stored in the k bits of the physical bytes, wherein j, k and m are all integers and m<k,

    • the method comprising:
    • reading a plurality of j bytes from the memory,
    • determining n byte error positions of the j read bytes, the n byte error positions being the byte positions for which the k physical bits of the respective byte do not form a codeword of the second error codewherein n byte error positions of n byte errors are predefined, wherein n is a positive integer and n<j, and
    • which method involves determining whether there is a further byte error position on the basis of the n byte error positions and on the basis of n+1 error syndrome components of a the first error code.

Claims
  • 1. A method for error processing, reading a plurality of bytes from a memory;wherein n byte error positions of n byte errors are predetermined, wherein n is a positive integer,which method involves determining whether there is a further byte error position on the basis of the n byte error positions and on the basis of n+1 error syndrome components of a first error code, andin the event of determining a further byte error position,(a) correcting a byte of the plurality of bytes read from the memory at the further byte error position and/or(b) outputting the further byte error position.
  • 2. The method according to claim 1, wherein the further byte error position is determined by way of the n byte error positions and the n+1 error syndrome components of the first error code.
  • 3. The method according to claim 1, wherein the first error code comprises a byte error code, wherein the byte error code comprises a Reed-Solomon code.
  • 4. The method according to claim 1, which involves detecting that no further byte error is present if no further byte error position is determinable.
  • 5. The method according to claim 1, wherein the further byte error position is determined depending on at least one symmetrical function of the n byte error positions.
  • 6. The method according to claim 5, wherein, if a non-code word of the second error code is detected in the course of the reading out from the memory, a byte error position is determined for this byte of the first error code.
  • 7. The method according to claim 1, wherein in the error-free case a byte of the first error code is transformed into a code word of a second error code,a byte error position is determined if a non-code word of the second error code is detected.
  • 8. The method according to claim 7, wherein code words of the second error code are stored in a memory.
  • 9. The method according to claim 1, wherein the second error code is an n1-out-of-n2 code, wherein 1≤n1<n2≤2 holds true.
  • 10. The method according to claim 9, wherein the reading out from the memory is effected taking account of a temporal order.
  • 11. The method according to claim 1, wherein in the error-free case code words of the second error code are read out from the memory and transformed back into bytes of the first error code.
  • 12. The method according to claim 1, wherein the further byte error position az is determinable such that the following holds true:
  • 13. The memory circuit comprising: a memory for storing a plurality of memory bytes, anda device for error processing, which is configured to determine whether there is a further byte error position on the basis of n byte error positions and on the basis of n+1 error syndrome components of a first error code, wherein the n byte error positions of n byte errors are predefined and wherein n is a positive integer.
  • 14. The memory circuit according to claim 13, wherein the device is furthermore configured to determine the further byte error position by way of the n byte error positions and the n+1 error syndrome components of the first error code.
  • 15. A non-transitory computer-readable storage medium having instructions stored thereon that, when executed, cause one or more processors to: store a plurality of memory bytes; anddetermine whether there is a further byte error position on a basis of n byte error positions and on a basis of n+1 error syndrome components of a first error code, wherein the n byte error positions of the n byte errors are predefined and wherein n is a positive integer.
Priority Claims (1)
Number Date Country Kind
102022101798.2 Jan 2022 DE national
US Referenced Citations (4)
Number Name Date Kind
4358848 Patel Nov 1982 A
10903859 Kern et al. Jan 2021 B2
20110239083 Kanno Sep 2011 A1
20180083653 Khayat Mar 2018 A1
Foreign Referenced Citations (2)
Number Date Country
102017125617 May 2019 DE
102021109391 Aug 2022 DE
Non-Patent Literature Citations (6)
Entry
Bossen, “b-Adjacent Error Correction”, IBM Journal of Research and Development, vol. 14, No. 4, Jul. 1970, pp. 402-408.
Fujiwara, “Code Design for Dependable Systems”, Wiley-Interscience, Jun. 1, 2006, pp. 65-68.
Lin et al., “Error Control Coding”, Prentice Hall, Jan. 1, 1983, pp. 170-177.
Office Action from counterpart German Application No. 102022101798.2 dated Oct. 19, 2022, 8pp.
Okano et al., “A Construction Method of High-Speed Decoders Using ROM's for Bose-Chaudhuri-Hocquenghem and Reed-Solomon Codes”, IEEE Transactions on Computers, vol. C-36, No. 10, Oct. 1, 1987, pp. 1165-1171.
Wicker, “Error Control Systems for Digital Communication and Storage”, Prentice Hall, 1995, pp. 214-224, (Applicant points out, in accordance with MPEP 609.04(a), that the year of publication, 1995, is sufficiently earlier than the effective U.S. filing date, so that the particular month of publication is not an issue.).
Related Publications (1)
Number Date Country
20230267039 A1 Aug 2023 US