Back to EveryPatent.com



United States Patent 5,719,888
Tanzawa ,   et al. February 17, 1998

Memory system

Abstract

According to the present invention, a memory system comprises storing section having a plurality of memory elements each of which stores one of n-value storage states corresponding to data "0", "1", . . . , "n-1", and including a plurality of information memory elements for storing n-value information data and a plurality of check memory elements for storing check data, converting section for respectively converting the information data and the check data stored in the memory elements into binary codes having a plurality of bits each constituted by 0 or 1, the binary codes corresponding to the information data and the check data, and detecting/correcting section for detecting and correcting an error on the basis of the binary codes corresponding to the check data and the information data.


Inventors: Tanzawa; Toru (Ebina, JP); Tanaka; Tomoharu (Yokohama, JP)
Assignee: Kabushiki Kaisha Toshiba (Kawasaki, JP)
Appl. No.: 786142
Filed: January 21, 1997
Foreign Application Priority Data

Dec 28, 1993[JP]5-354152
Dec 27, 1994[JP]6-326344

Current U.S. Class: 714/764; 714/761
Intern'l Class: G11C 029/00
Field of Search: 371/40.1,39.1,38.1


References Cited
U.S. Patent Documents
4959812Sep., 1990McModomi et al.365/185.
5043940Aug., 1991Harari365/185.
5179560Jan., 1993Yamagishi et al.371/38.
5457702Oct., 1995Williams et al.371/37.
Foreign Patent Documents
5-60199Sep., 1993JP.


Other References

IEEE Journal of Solid-State Circuits, "An Experimental Large-Capacity Semiconductor File Memory Using 16-Levels/Cell Storage." by Masashi Horiguchi, et al., vol. 23, No. 1, Feb. 1988, pp. 27-32.

Primary Examiner: Baker; Stephen M.
Attorney, Agent or Firm: Oblon, Spivak, McClelland, Maier & Neustadt, P.C.

Parent Case Text



This is Division of application Ser. No. 08/364,997 filed on Dec. 28, 1994 now U.S. Pat. No. 5,621,682.
Claims



What is claimed is:

1. A memory system comprising:

storing means for storing data including information data and check data in a plurality of memory elements;

error detecting means for detecting an error of the information data on the basis of a relationship between the information data and the check data;

error correcting means for correcting an error of the information data on the basis of the relationship between the information data and the check data;

burst error position detecting means for detecting a position at which a burst error occurs in data stored in said plurality of memory elements; and

data changing means for changing data at which burst error occurs.

2. A system according to claim 1, further comprising repeat means for changing data until all possible data patterns are tried out.

3. A system according to claim 1, further comprising:

error flag output means for outputting an error flag which represents that read-out data includes error, when a number of burst errors is greater than a predetermined number of bit error, when the number of bit errors is greater than a predetermined number of bit errors, or when a number of correctable errors is greater than a predetermined number of correctable errors.

4. A system according to claim 1, wherein each of said plurality of memory elements stores one of N-levels, where N is an integer of more than 1.

5. A system according to claim 4, wherein said one of N-levels is given by a magnitude of charge amount.

6. A system according to claim 5, wherein each of said plurality of memory elements comprises nonvolatile memory cell obtained by stacking and forming a charge storage layer and a control gate on a semiconductor layer.

7. A memory system comprising:

storing means for storing data in a plurality of memory elements including information data and check data;

burst error position detecting means for detecting a position at which burst error occurs in said plurality of memory elements;

data changing means for changing data at which burst error occurs;

error detecting means for detecting an error of the data changed by said data changing means on the basis of a relationship between the information data and the check data; and

error correcting means for correcting said error of the data changed by said data changing means on the basis of a relationship between the information data and the check data.

8. A system according to claim 7, wherein each of said plurality of memory elements stores one of N-levels, where N is an integer greater than 1.

9. A system according to claim 7, further comprising

error flag output means for outputting an error flag which represents that read-out data includes error, when a number of burst errors is greater than a predetermined number of bit errors, when then a number of bit errors is greater than a predetermined number of bit errors, or when a number of correctable errors is greater than a predetermined number of correctable error.

10. A system according to claim 8, wherein said one of N-levels is given by a magnitude of charge amount.

11. A system according to claim 10, wherein each of said plurality of memory elements is an nonvolatile memory cell obtained by stacking and forming a charge storage layer and a control gate on a semiconductor layer .
Description



BACKGROUND OF THE INVENTION

1. Field of the Invention

The present invention relates to a memory system and, more particularly, to a multi-value memory system using a nonvolatile semiconductor memory which is electrically erasable and programmable.

2. Description of the Related Art

In recent years, as a memory system, a semiconductor memory device using a semiconductor memory is popularly used. In the semiconductor memory device, degradation of reliability caused by various influences with a high degree of integration and a high integration density is posed as a problem.

For this reason, an error detection/correction code for performing error detection/correction is often applied to a semiconductor memory device. In practice, this error detection/correction code must satisfy all the following conditions.

(1) An error frequency is lower than a permissible error frequency unique to a semiconductor memory device.

(2) Coding and decoding can be performed at a high speed with a high-speed reading/writing operation.

(3) In code structure, the redundancy of the code is minimum.

For the above practical viewpoints, an SEC-DED code for correcting a 1-bit error and detecting a 2-bit error has been popularly used at present.

In order to obtain higher reliability, a DEC code for correcting a 2-bit error is applied. In particular, a byte error detection/correction code for detecting/correcting errors in units of memory packages or units of multi-bit outputting/storing elements. In order to practically use a device for processing data in units of bytes, an SbEC-DbED code for not only correcting a single-byte error but also having high capability of detecting a 2-byte error is required.

As available means for high integration, a method of multi-value storage has been considered.

In an example of multi-value dynamic semiconductor memory, a memory cell performs a multi-value storage by having three or more dispersed charge distribution stored in the memory cell. In this case, since data stored in one memory cell will be destroyed by one soft error, error correction code (e.g., byte error correction code which treats one cell data as one byte) capable of correcting the above error is required.

On the other hand, in a case of a non-volatile semiconductor multi-value memory device which is electrically erasable and programmable, a memory cell having three or more disperse threshold voltage distribution is used. For example, a multi-value ROM (read only memory) of 3-bit which is constructed by two ternary memory cells is known (Jpn. Pat. Appln KOKOKU Publication No. 5-60199), a multi-value EEPROM can construct the same as the multi-value ROM. For example, 3-bit information can be stored for two memory cells by using eight values from nine values (i.e., 3.times.3=9), as cell group constructed by adjacent memory cells sharing their control gates is a fundamental element. In this case, the multi-value EEPROM differs from the multi-value dynamic semiconductor memory device and has not a problem of soft error. However, charge amount stored in a charge storage layer shifts to a threshold voltage of the memory cell whose charge amount is 0, whereby data error will be raised.

The structure and operation of a ternary NAND EEPROM which can be integrated at a high density will be briefly described below. FIG. 1 is a sectional view showing a NAND cell structure. A NAND cell has a p-type substrate 11, a floating gate 14, a control gate 16, an interlaminar insulating film 17, a bit line 18, and an n-type diffusion layer 19.

A plurality of memory cells are connected in series with each other such that adjacent memory cells commonly use a source and a drain, and the adjacent memory cells are connected to a bit line as one unit, thereby constituting the NAND cell. A memory cell array is integrally formed in a p-type well formed in a p-type substrate or an n-type substrate. The drain side of the NAND cell is connected to bit lines through selection gates, and, similarly, the source and drain sides of the NAND cell are connected to a source line through selection gates. The control gates of the memory cells are continuously arranged in a row direction to constitute word lines.

The operation of the ternary NAND EEPROM is as follows.

A data writing operation is performed from a memory cell located at a position farthest from the bit line. A high voltage Vpp (=about 20 V) is applied to the control gate of a selected memory cell, an intermediate voltage Vm (=about 10 V) is applied to the control gate and selection gate of a memory cell closer to the bit line than the selected memory cell, and a voltage of 0 V, a low voltage Vdd (=about 2 V), or an intermediate voltage is applied to the bit line in accordance with data. When the voltage of 0 V or the low voltage Vdd (=about 2 V) is applied to the bit line, the potential of the bit line is transmitted to the drain of the selected memory cell, and electrons are injected from the drain into the floating gate. In this manner, the threshold voltage of the selected memory cell is positively shifted. However, a shift amount obtained when the low voltage Vdd is applied to the bit line is smaller than a shift amount obtained when the voltage of 0 V is applied to the bit line. When an intermediate voltage is applied to the bit line, no electron injection occurs, and the threshold voltage does not change.

A data erasing operation is simultaneously performed for all the memory cells in the NAND cell. More specifically, all the control gates are set to be 0 V, and the bit and source lines are set in a floating state, thereby applying a high voltage Vpp (=about 20 V) to all the selection gates, a p-type well and an n-type substrate. In this manner, the electrons in the floating gates of all the memory cells are discharged into the p-type well, and the threshold voltage is negatively shifted.

A data reading operation is performed by two cycles. In the first cycle, the control gate of a selected memory cell is set to be 0 V, and the control and selection gates of the remaining memory cells are set to be a power supply voltage Vcc (=about 5 V). In this state, it is checked whether a current flows in the selected memory cell. In the second cycle, the control gate of the selected memory cell is set to be a low voltage Vdd (=about 2 V), and the control and selection gates of the remaining memory cells are set to be the power supply voltage Vcc (=about 5 V). In this state, it is checked whether a current flows in the selected memory cell. In this case, three threshold voltages Vt satisfy Vt<0 V, 0 V=<Vt<Vdd, and Vdd=<Vt<Vcc, respectively.

When i-th data obtained upon arrangement of the magnitudes of physical amounts (e.g., the threshold voltage of a memory cell of EEPROM) for determining multi-values in a descending order is defined as multi-value data "i", a case wherein read-out multi-value data is different from written multi-value data by only one in size is considered. At this time, read-out output data may be different from written input data by 2 or more bits. As a result, at least an SbEC code is required as an error correction/detection code using input/output data as information data. In addition, in order to obtain reliability almost equal to that of an SEC-DED code used in a binary storing element, an SbEC-DbED code is required. However, this SbEC-DbED code requires a complex decoding circuit.

When a burst error such as a column failure of stored data occurs, the net capability of correcting/detecting an error decreases. When such a burst error occurs, and stored data except for the stored data at an address at which the burst error occurs has an error, at least a 2-bit error correction code must be applied to correct these errors.

For example, in a electrically erasable and programmable nonvolatile semiconductor memory (EEPROM), a unique column failure may occur. This column failure occurs when current leaks from a bit line, or data in memory cells in a common column in a block are excessively written or excessively erased. When such a column failure occurs, and a memory cell except for the memory cell at the column address at which the column failure occurs has an error, these errors cannot be corrected by a single b-bit byte error correction code such as an SbEC code. In this case, for example, a double b-bit byte error correction code is required. However, this code requires a complex decoding circuit.

As described above, the conventional memory system has the following problems.

When i-th data obtained upon arrangement of the magnitudes of physical amounts for determining multi-values in a descending order is defined as multi-value data "i", and read-out multi-value data is different from written multi-value data by only one in size, read-out output data may be different from written input data by 2 or more bits. As a result, at least an SbEC code is required as an error correction/detection code using input/output data as information data. In addition, in order to obtain reliability almost equal to that of an SEC-DED code used in a binary storing element, an SbEC-DbED code is required. However, this SbEC-DbED code requires a complex decoding circuit.

In an EEPROM, a unique column failure may occur. When such a column failure occurs, and a memory cell except for the memory cell at the column address at which the column failure occurs has an error, these errors cannot be corrected by a single b-bit byte error correction code such as an SbEC code. In this case, for example, a double b-bit byte error correction code is required. However, this code requires a complex decoding circuit.

SUMMARY OF THE INVENTION

It is an object of the present invention to provide a memory system capable of using a simple decoding circuit having relatively low redundancy and completing 2-bit error detection using an error detecting/correcting means suitably used when i-th data obtained upon arrangement of the magnitudes of physical amounts for determining multi-values in a descending order is defined as multi-value data "i", and read-out multi-value data is different from written multi-value data by only one in size.

It is another object of the present invention to provide a memory system capable of, even when a burst error occurs to generate a 2-bit error in one code word, correcting a 1-bit error and having a possibility of correcting a 2-bit error using a code for detecting the 2-bit error.

According to the present invention, in order to solve the above problems, the following means are devised.

A first memory system according to the present invention is characterized by comprising: storing means having a plurality of memory elements each of which stores one of n-value storage states corresponding to data "0", "1", . . . , "n-1", the storing means including a plurality of information memory elements for storing n-value information data and a plurality of check memory elements for storing check data; converting means for respectively converting the information data and the check data stored in the memory elements into binary codes having a plurality of bits each constituted by 0 or 1, the binary codes corresponding to the information data and the check data; and detecting/correcting means for detecting and correcting an error on the basis of the binary codes corresponding to the check data and the information data. In this configuration, the converting means includes means for converting the information data and check data into binary codes including intermediate binary codes which are combinations of binary codes each of which data is stored in one of the memory elements.

Another first memory system according to the present invention is characterized by comprising: an EEPROM including a plurality of first memory cells each of which stores information data selected from at least three storage states and a plurality of second memory cells each of which stores check data selected from at least three storage states; a converter for converting the information data stored in the first memory cells and check data stored in the second memory cells into binary codes, respectively, each of the binary codes having a plurality of bits each constituted by 0 or 1; detecting/correcting means for detecting and correcting an error by using the converted binary codes of the information data and the check data. In this configuration, the binary codes including intermediate binary code and the detecting/correcting means for detecting and correcting an error by using the converted intermediate binary codes of the information data and the check data.

Where, the storing means stores the n-value information data by combinations of the plurality of memory elements.

Preferable manners of the present invention are as follows.

(1) The information data storing means includes a second converting means for causing the check memory element to generate a binary code corresponding to data to be stored in one of the memory elements, and writing means for causing the memory elements to perform n-value storage on the basis of the binary code.

(2) The converting means includes means for converting storage data of a memory element into a binary code having a plurality of bits each constituted by 0 or 1, and the detecting/correcting means includes means for detecting/correcting an error on the basis of information data and check data and outputting a data code represented by combinations of data of the plurality of memory elements on the basis of the binary code.

(3) In the configuration of (2), the first memory system is characterized by further comprising means for generating a binary code corresponding to data to be stored in the memory element of the check memory element on the basis of the binary code converted from the data code and corresponding to data to be stored in the memory element of the information memory element to cause the memory elements to perform n-value storage on the basis of the binary code.

(4) The converting means includes means for converting data such that, when a size of data in the memory element changes by one, a binary code of the data has a Hamming distance of 1, for that of the data whose size in the memory element is different by one.

(5) The memory elements perform n-value storage using charge amounts stored in the memory elements and correspond to n data "0", "1", . . . , "n-1" in an order of magnitudes of the charge amounts.

(6) The memory element is a nonvolatile memory cell obtained by stacking and forming a charge storage layer and a control gate on a semiconductor layer.

(7) A storage state of the memory element is changed by one.

(8) The storing means stores n-bit (2.sup.n <N.sup.M <2.sup.n+1) information having a relation n<2.sup.M using combinations of the M (M: an integer of not less than 2) and N-value (N: an integer of not less than 3) memory elements.

According to the first memory system of the present invention, the following effect can be obtained.

When i-th data obtained upon arrangement of the magnitudes of physical amounts for determining multi-values in a descending order is defined as multi-value data "i", and read-out multi-value data is different from written multi-value data by only one in size, a 1-bit error correction code can be applicable by introducing an intermediate binary code, 1-bit of which is shifted when multi-value data is shifted only 1 (i.e., when a Hamming distance is 1). In this manner, a decoding circuit having relatively low redundancy, i.e., a simple structure, can be used. In addition, when this application extends to an application of a 2-bit error detection code having capability of detecting a 2-bit error, 2-bit error detection can be completely performed.

For example, in an electrically erasable and programmable nonvolatile semiconductor memory (EEPROM), as shown in FIG. 2, a memory cell obtained by stacking and forming a charge storage layer 14 and a control gate 16 on a semiconductor substrate (a p-type well 11 on an n-type substrate 11') is used, and the magnitude of an amount of charge stored in the charge storage layer 14 is made discrete, i.e., a voltage Vt observed from the control gate 16 is made discrete, so that digital information can be stored. A multi-value memory is constituted by a memory cell having three or more Vt distributions.

FIG. 3 shows the correspondence between multi-values "0", "1", and "2" and the threshold voltage levels of the cells of a ternary memory. A voltage Vt obtained when the magnitude of an amount of charge stored in the charge storage layer is 0 is called a neutral voltage Vt.sub.0. When this neutral voltage Vt.sub.0 is set in the voltage Vt distribution of data "1", after the memory is left still for a long time, information written in the memory cell may change into information corresponding to the Vt distribution including the neutral voltage Vt.sub.0. In this case, the size of an information error of is "1" at most. More specifically, an information error occurs between only data "0" and "1" and between only data "1" and "2".

FIGS. 4 and 5 are views showing the cell array portions of a NOR EEPROM and a NAND EEPROM, respectively. In a ternary memory, a basic element is constituted by a cell group constituted by, e.g., adjacent memory cells commonly using a control gate. Since one memory cell has three values, one cell group has nine values. When eight values of the nine values are used, 3-bit information can be stored per two cells.

As shown in Table 1, the correspondence relationship between ternary data and binary codes is set such that, when multi-value data are different from only one in size, a Hamming distance between the binary codes corresponding to the multi-value data is set to be one. In this manner, an error can be corrected by applying a 1-bit error correction code.

                  TABLE 1
    ______________________________________
    ternary data  binary code
    ______________________________________
    "0"           01
    "1"           00
    "2"           10
    ______________________________________


In addition, as in a case wherein 4-, 5-, or 8-value data is used, the correspondence relationship between multi-value data and binary codes is set as shown in Table 2, 3, or 4, and the above effect can be achieved.

                  TABLE 2
    ______________________________________
    4-value data  binary code
    ______________________________________
    "0"           00
    "1"           01
    "2"           11
    "3"           10
    ______________________________________


TABLE 3 ______________________________________ 5-value data binary code ______________________________________ "0" 000 "1" 001 "2" 011 "3" 111 "4" 110 ______________________________________

TABLE 4 ______________________________________ 8-value data binary code ______________________________________ "0" 000 "1" 001 "2" 011 "3" 010 "4" 110 "5" 100 "6" 101 "7" 111 ______________________________________


A second memory system according to the present invention is characterized by comprising: information memory element for storing information data; check data means for storing check data; error detecting/correcting means for performing error detection/correction of the information data on the basis of the information data and the check data; burst destruction position detecting means for detecting a burst destruction position of data stored in each of the storage sections; and data resetting means for supposing data at the burst destruction position detected by the burst destruction position detecting means to reset the data. The second memory system is characterized by further comprising means for performing error detection/correction using data at all possible burst destruction positions while the data resetting means and the error detecting/correcting means are repeatedly used.

According to the second memory system of the present invention, an electrically erasable and programmable nonvolatile semiconductor memory (EEPROM), even when a burst error such as a unique column failure occurs to generate a 2-bit error in one code word, corrects a 1-bit error and has a possibility of correcting a 2-bit error using a code for detecting the 2-bit error.

Additional objects and advantages of the present invention will be set forth in the description which follows, and in part will be obvious from the description, or may be learned by practice of the present invention. The objects and advantages of the present invention may be realized and obtained by means of the instrumentalities and combinations particularly pointed out in the appended claims.

BRIEF DESCRIPTION OF THE DRAWINGS

The accompanying drawings, which are incorporated in and constitute a part of the specification, illustrate presently preferred embodiments of the present invention and, together with the general description given above and the detailed description of the preferred embodiments given below, serve to explain the principles of the present invention in which:

FIG. 1 a sectional view showing the structure of a NAND cell;

FIG. 2 is a view showing a memory cell structure of an EEPROM;

FIG. 3 is a graph showing the corresponding relationship between data "0", "1", and "2" and the threshold voltages of the memory cells of a ternary memory;

FIG. 4 is a view showing the circuit arrangement of a ternary NOR EEPROM;

FIG. 5 is a view showing the circuit arrangement of a ternary NAND EEPROM;

FIG. 6 is a schematic view showing a memory system according to the first embodiment of the present invention;

FIG. 7 is a schematic view showing a memory system according to the second embodiment of the present invention;

FIG. 8 is a schematic view showing a memory system according to the third embodiment of the present invention;

FIG. 9 is a schematic view showing a memory system according to the fourth embodiment of the present invention;

FIG. 10 is a schematic view showing a memory system according to the fifth embodiment of the present invention;

FIG. 11 is a graph showing the correspondence between intermediate binary codes and the distributions of the threshold voltages Vt of a ternary cell;

FIG. 12 is a view showing an check matrix for error correction/detection;

FIGS. 13A and 13B are circuit diagrams of a data converting circuit;

FIGS. 14A to 14C are views showing the connecting relationships between a data converting circuit, an IO pad, an IO buffer, an error correcting/detecting circuit (ECC), and a writing/reading circuit;

FIGS. 15A and 15B are views showing arrangements the ECC;

FIG. 16 is a view showing the arrangement of the error correcting circuit;

FIG. 17 is a view showing an error informing circuit;

FIG. 18 is a view showing the connection relationship between lines I and P, which represent information data and check data, respectively, a writing/reading circuit 150, and bit lines;

FIG. 19 is a view showing a 2-input writing/reading circuit;

FIG. 20 is a view showing a 1-input writing/reading circuit;

FIG. 21 is a view showing a column decoder;

FIG. 22 is a chart showing timings of inputting write-in data;

FIG. 23 is a chart showing the timings of the control signal of a writing/reading circuit, cell selection gates SG1 and SG2, and control gates CG1 to CG8 in a writing operation;

FIG. 24 is a chart showing the timings of the control signal of a writing/reading circuit, cell selection gates SG1 and SG2, and control gates CG1 to CG8 in a reading operation;

FIG. 25 is a chart showing a timing of outputting read-out data;

FIG. 26 is a schematic view showing a memory system according to the seventh embodiment of the present invention;

FIG. 27 is a flow chart showing an error detection/correction algorithm in the seventh embodiment of the present invention; and

FIG. 28 is a block diagram showing a failure in the seventh embodiment of the present invention.

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS

Embodiments of the present invention will be described below with reference to the accompanying drawings.

FIG. 6 is a schematic view showing the arrangement of a memory system according to the first embodiment of the present invention. The memory system according to the first embodiment comprises a data converter 10, an check data calculator 20, a cell array 30, an error detector 40, an error corrector 50, and a data inverter 60.

A data writing operation is performed as follows.

The data converter 10 converts input data D10 serving as write-in data into binary code having a Hamming distance of 1 when i-th data obtained upon arrangement of the magnitudes of physical amounts for determining multi-values in a descending order is defined as multi-value data "i", and read-out multi-value data is different from written multi-value data by only one in size. Thereafter, the check data calculator 20 generates check data D30 from a binary code. At this time, a binary code converted by the data converter 10 is used as information data D20, and the information data D20 and the check data D30 are written as write-in data D40 in the cell array 30.

A data reading operation is performed as follows.

Read-out data D50 read out from the cell array 30 is input to the error detector 40 and the error corrector 50. When the data read out from the cell array 30 has errors, the error detector 40 detects errors when the number of errors falls within a permissible range, and the error detector 40 outputs the positions of the detected errors to the error corrector 50. When the number of errors detected by the error detector 40 falls within an permissible range, the error corrector 50 corrects the errors of the read-out data D50 read out from the cell array 30. At this time, the error corrector 50 outputs the multi-value information data of a binary code. The data inverter 60 inverts the information data into output data D60 serving as read-out data from the cell array 30 and outputs the output data D60.

As described above according to the first embodiment, assume that i-th data obtained upon arrangement of the magnitudes of physical amounts for determining multi-values in a descending order is defined as multi-value data "i", and read-out multi-value data is different from written multi-value data by only one in size. In this case, data are converted into binary code having a Hamming distance of 1 when multi-value information data is converted into a binary code, and the multi-value data is different from the binary code are different from each other by one in size. For this reason, a 1-bit error correction code can be applied to the memory system according to the first embodiment. Therefore, a decoding circuit having a relatively low redundancy, and a simple decoding circuit can be used. In addition, when the application of the 1-bit error detection code extends to the application of a 2-bit error detection code having a 2-bit error detection capability, 2-bit error detection can be completely performed.

FIG. 7 is a schematic view showing the arrangement of a memory system according to the second embodiment of the present invention. Referring to FIG. 7, the same reference numerals as in FIG. 6 denote the same parts in FIG. 7, and a description thereof will be omitted. The second embodiment describes that each constituent element in the first embodiment is included in either of a CPU 100 or an EEPROM 200.

According to the second embodiment, the CPU 100 has a data converter 10, an check data calculator 20, an error corrector 50, an error detector 40, and a data inverter 60, and the EEPROM 200 has only a cell array 30. In the second embodiment, data which is exchanged between the CPU 100 and the EEPROM 200 is a binary code.

FIG. 8 is a schematic view showing the arrangement of a memory system according to the third embodiment of the present invention. The same reference numerals as in FIG. 6 denote the same parts in FIG. 8, and a description thereof will be omitted.

According to the third embodiment, unlike the second embodiment, an EEPROM 200 has a data converter 10 and a data inverter 60 as in a CPU 100. In this case, data which is exchanged between the CPU 100 and the EEPROM 200 is not a binary code but normal information data. However, according to the third embodiment, a forbidden data detector 70 is arranged in the EEPROM 200 such that, when read-out data D50 has errors and is converted into an unused binary code, the error is detected and output outside the EEPROM 200 (e.g., such that the output buffer of the EEPROM 200 is set in a high-impedance state).

FIG. 9 is a schematic view showing the arrangement of a memory system according to the fourth embodiment of the present invention. The same reference numerals as in FIG. 6 denote the same parts in FIG. 9, and a description thereof will be omitted.

The fourth embodiment is obtained such that the data converter 10 and the data inverter 60 in the first embodiment of the present invention are integrated with each other. The fourth embodiment has the same basic operation as that of the first embodiment of the present invention. However, only data having a 2.sup.n value (n: an integer which is 2 or more) is used in the fourth embodiment.

A writing operation is performed as follows.

When it is assumed that i-th data obtained upon arrangement of the magnitudes of physical amounts for determining multi-values in a descending order is defined as multi-value data "i", and read-out multi-value data is different from written multi-value data by only one in size, an input/output data to/from multi-value data converter 80 converts input data D10 serving as write-in data into binary code having a Hamming distance of 1 when the multi-value data is converted into a binary code, and the multi-value data is different from the binary code by only one in size. Thereafter, an check data calculator 20 generates check data D30 from the binary code. At this time, the binary code converted by the data converter 10 is used as information data D20, and the information data D20 and the check data D30 are written as error detector 40 in a cell array 30.

A data reading operation is performed as follows.

Read-out data D50 read out from the cell array 30 is input to the error detector 40 and the error corrector 50. When the data read out from the cell array 30 has errors, the error detector 40 detects errors when the number of errors falls within a permissible range, and the error detector 40 outputs the bit position information of the detected errors to the error corrector 50. When the number of errors detected by the error detector 40 falls within a permissible range, the error corrector 50 corrects the errors of the read-out data D50 read out from the cell array 30. The error corrector 50 outputs the multi-value information data of a binary code. The input/output data to/from multi-value data converter 80 inverts the information data into output data D60 serving as read-out data and outputs the output data D60.

FIG. 10 is a schematic view showing the arrangement of a memory system according to the fifth embodiment of the present invention. The same reference numerals as in FIG. 6 denote the same parts in FIG. 10, and a description thereof will be omitted.

The fifth embodiment describes an arrangement in which hypercomplex multi-value data is used as data which is exchanged between the CPU 100 and the EEPROM 200 in the second embodiment of the present invention. The fifth embodiment has the same basic operation as that of the second embodiment of the present invention.

In a writing operation, a data converter 10 converts input data D10 serving as write-in data into binary code having a Hamming distance of 1 when i-th data obtained upon arrangement of the magnitudes of physical amounts for determining multi-values in a descending order is defined as multi-value data "i", and read-out multi-value data is different from written multi-value data by only one in size. Thereafter, the check data calculator 20 generates check data D30 from the binary code. The binary code is used as information data D20, and these data are input to a hypercomplex multi-value data converter 90. The hypercomplex multi-value data converter 90 converts the input data into hypercomplex multi-value data and outputs it.

With the above arrangement, data which is exchanged between the CPU 100 and the EEPROM 200 becomes hypercomplex multi-value data. The hypercomplex multi-value data input to the EEPROM 200 is written in a cell array 30 as write-in data D40.

In a reading operation, hypercomplex multi-value read-out data D50 read out from the cell array 30 is input to the hypercomplex multi-value data converter 90 of the CPU 100. The hypercomplex multi-value data converter 90 converts the input hypercomplex multi-value data into a binary code. Thereafter, the data is input to an error detector 40 and an error corrector 50. When the data read out from the cell array 30 has errors, the error detector 40 detects errors when the number of errors falls within a permissible range, and the error detector 40 outputs the position information of the detected errors to the error corrector 50. When the number of errors detected by the error detector 40 falls within a permissible range, the error corrector 50 corrects the errors of the read-out data D50 read out from the cell array 30. The error corrector 50 outputs the multi-value information data of a binary code. The data inverter 60 inverts the information data into output data D60 serving as read-out data and outputs the output data D60.

The sixth embodiment of the present invention describes error correction/detection of a multi-value memory system using a multi-value memory which obtains three bits by using eight combinations of the nine combinations of the states of two ternary memory cells. In each of the above embodiments, after memory information is converted into binary codes (including an intermediate binary code), error correction is performed. However, the sixth embodiment describes a practical case wherein error correction is performed using an intermediate binary code as a binary code in each of the above embodiments. The sixth embodiment will be described below.

FIG. 11 shows a case wherein the distributions ("0", "1", and "2") of threshold voltages Vt of a ternary cell respectively correspond to intermediate binary codes 00, 01, and 11. Referring to FIG. 11, the threshold voltages in each distribution respectively satisfy Vt=<-1 V, 0 V=<Vt=<1 V,2 V=<Vt=<3V. Assume that eight combinations of the intermediate binary codes of a cell 1 and a cell 2 which are two memory cells to be combined with each other are called intermediate binary codes, respectively. In this case, the relationships between combination and 8-bit intermediate binary codes corresponding to the combination are shown in Table 5. As is apparent from Table 5, when a state can be changed by "1", input/output data "1" "1" may change to four cases, "0" "1", "2" "1", "1" "0" and "1" "2", but 3-bit information changed by one bit is only three. As a result, a 2-bit error correction code is necessary for 3-bit information, while a 1-bit error correction code is sufficient for intermediate binary code.

                  TABLE 5
    ______________________________________
    combination of the
    states for the two
                    3-bit     intermediate
    memory cells    information
                              binary code
    ______________________________________
    "0""0"          000       0000
    "0""1"          001       0001
    "0""2"          011       0011
    "1""0"          100       0100
    "1""1"          101       0101
    "1""2"          111       0111
    "2""0"          010       1100
    "2""1"          110       1101
    ______________________________________


FIG. 12 shows an check matrix, for error correction/detection in which a 1-bit error of a 21-bit intermediate binary code is corrected, and a 2-bit error in 27 bits obtained by adding 6 check bits to the 21 bits of the intermediate binary code.

FIGS. 13A and 13B are circuit diagrams of a data converting circuit 110 for performing conversion from information data into an intermediate binary code and inversion therebetween. A signal WE goes to high level in a writing operation, and a signal RE goes to high level in a reading operation. Referring to FIG. 13A, a signal with a bar (e.g.,/WE) indicates a signal obtained by inverting the corresponding signal. The data converting circuit 110 converts information data into an intermediate binary code in a writing operation, and information data is inverted into information data in a reading operation. As shown in FIG. 13A, of information data IO.sub.l (l=1 to 15) of 16 bits, 15-bit data are converted into 4-bit intermediate binary codes IOO.sub.k (k=1 to 20) every three bit. The remaining information data IO.sub.16 is converted into an intermediate binary code IOO.sub.21, as shown in FIG. 13B. The 16-bit information is not directly processed, but 21-bit data of the intermediate binary codes IOO converted by the data converting circuit 110 is processed as information data of an error correction code.

FIGS. 14A to 14C show the connecting relationship between the data converting circuit 110, an IO pad 120 serving as the data input/output pins of an EEPROM 200, an IO buffer 130, an error correcting/detecting circuit (ECC) 140, and a writing/reading circuit 150.

Referring to FIG. 14A, the data converting circuit 110 is arranged on the CPU 100 side, and the EEPROM 200 receives intermediate binary codes of 21 bits. Referring to FIG. 14B, the EEPROM 200 has the data converting circuit 110, the ECC 140, and a writing/reading circuit 150, and the EEPROM 200 receives and outputs 16-bit information data. Referring to FIG. 14C, the CPU 100 has the data converting circuit 110 and the ECC 140, and the EEPROM 200 receives and outputs the intermediate binary codes of 21 bits and 6 check bits.

FIGS. 15A to 17 show arrangements of the ECC 140 which corrects a 1-bit error of 21-bit intermediate binary code and detects a 2-bit error in 27 bits obtained by adding the 6 check bits to the 21 bits of the intermediate binary code. Error detection/correction performed by the ECC 140 is realized using the detection matrix shown in FIG. 12. In a writing operation, write-in information data I.sub.k (k=1 to 21) is set to be an input O.sub.k by the circuit shown in FIG. 15A. The circuit shown in FIG. 15B is a circuit which generates check data in a write-in operation and generates a syndrome in a reading operation. This circuit has 6 combinations, and input A(i) and an input B(i) are given in Tables 6 and 7.

                  TABLE 6
    ______________________________________
           i = 1 i = 2   i = 3   i = 4 i = 5 i = 6
    ______________________________________
    A1(i)    I.sub.1 I.sub.1 I.sub.1
                                   I.sub.2
                                         I.sub.3
                                               I.sub.4
    A2(i)    I.sub.5 I.sub.2 I.sub.2
                                   I.sub.3
                                         I.sub.4
                                               I.sub.5
    A3(i)    I.sub.6 I.sub.6 I.sub.3
                                   I.sub.4
                                         I.sub.5
                                               I.sub.6
    A4(i)    I.sub.7 I.sub.8 I.sub.9
                                   I.sub.7
                                         I.sub.7
                                               I.sub.8
    A5(i)    I.sub.9 I.sub.10
                             I.sub.11
                                   I.sub.11
                                         I.sub.8
                                               I.sub.9
    A6(i)    I.sub.10
                     I.sub.11
                             I.sub.12
                                   I.sub.12
                                         I.sub.11
                                               I.sub.12
    A7(i)    I.sub.13
                     I.sub.14
                             I.sub.13
                                   I.sub.13
                                         I.sub.14
                                               I.sub.15
    A8(i)    I.sub.16
                     I.sub.17
                             I.sub.15
                                   I.sub.14
                                         I.sub.15
                                               I.sub.16
    A9(i)    I.sub.17
                     I.sub.18
                             I.sub.18
                                   I.sub.16
                                         I.sub.17
                                               I.sub.18
    A10(i)   I.sub.19
                     I.sub.19
                             I.sub.19
                                   I.sub.19
                                         I.sub.19
                                               I.sub.20
    A11(i)   I.sub.20
                     I.sub.20
                             I.sub.20
                                   I.sub.20
                                         I.sub.21
                                               I.sub.21
    A12(i)   I.sub.21
                     I.sub.21
                             I.sub.21
                                   0     0     0
    ______________________________________


TABLE 7 ______________________________________ i = 1 i = 2 i = 3 i = 4 i = 5 i = 6 ______________________________________ B1(i) O.sub.1 O.sub.1 O.sub.1 O.sub.2 O.sub.3 O.sub.4 B2(i) O.sub.5 O.sub.2 O.sub.2 O.sub.3 O.sub.4 O.sub.5 B3(i) O.sub.6 O.sub.6 O.sub.3 O.sub.4 O.sub.5 O.sub.6 B4(i) O.sub.7 O.sub.8 O.sub.9 O.sub.7 O.sub.7 O.sub.8 B5(i) O.sub.9 O.sub.10 O.sub.11 O.sub.11 O.sub.8 O.sub.9 B6(i) O.sub.10 O.sub.11 O.sub.12 O.sub.12 O.sub.11 O.sub.12 B7(i) O.sub.13 O.sub.14 O.sub.13 O.sub.13 O.sub.14 O.sub.15 B8(i) O.sub.16 O.sub.17 O.sub.15 O.sub.14 O.sub.15 O.sub.16 B9(i) O.sub.17 O.sub.18 O.sub.18 O.sub.16 O.sub.17 O.sub.18 B10(i) O.sub.19 O.sub.19 O.sub.19 O.sub.19 O.sub.19 O.sub.20 B11(i) O.sub.20 O.sub.20 O.sub.20 O.sub.20 O.sub.21 O.sub.21 B12(i) O.sub.21 O.sub.21 O.sub.21 0 0 0 ______________________________________


FIG. 16 is a view showing an arrangement of an error correcting/detecting circuit. In the error correcting circuit shown in FIG. 16, in a reading operation, the syndrome inverts read-out information data I.sub.k when a signal CRCT.sub.k for informing that an error has occurred goes to high level in the pattern of FIG. 12 to perform error correction, thereby outputting an output O.sub.k. Otherwise, this error correcting circuit directly outputs the read-out information data I.sub.k as the output O.sub.k.

The circuit in FIG. 17A is a circuit in which, when at least one of syndromes S.sub.i (i=1 to 6) goes to "1" (high), a signal ERDET is set to be "1" to inform that an error occurs. At this time, when the number of syndromes which go to "1" is an even number, the signal EVENER goes to "1", thereby informing that an even number of errors has occurred. Although errors occur, when the errors are not corrected, a signal NOTCRCT goes to "1".

FIG. 18 shows the connection relationship between signals I and P, which represent information and check data, respectively, the writing/reading circuit 150, and bit lines, and FIGS. 19 and 20 respectively shows a 2- and 1-input writing/reading circuits. FIG. 21 shows a column decoder.

Referring to FIG. 18, signals I.sub.1 and I.sub.2 are input to and output from a single writing/reading circuit 150a and connected to 1-bit line through the writing/reading circuit 150a. As shown in FIG. 18, ten 2-input writing/reading circuits 150a each shown in FIG. 19 are arranged per 20 signals I. Signals I.sub.21 and P.sub.i (i=1 to 6) are input to and output from a 1-input writing/reading circuit 150b and connected to 1-bit line through the 1-input writing/reading circuit 150b. Therefore, the number of 1-input writing/reading circuits 150b each shown in FIG. 20 is seven. FIG. 21 shows a column decoder. Referring to FIG. 21, a signal CSL.sub.n goes to high level with respect to a selected address, and the signal CSL.sub.n goes to low level with respect to a non-selected address.

The timings of control signals and data in the circuits shown in FIGS. 18 to 21 will be described below with reference to FIGS. 22 to 25.

First, a write-in operation will be described below.

FIG. 22 is a chart showing a timing of inputting write-in data.

When the write-in signal WE goes to high level, and the information data O.sub.l (l=1 to 16) for writing are output, the data converting circuit 110 outputs a intermediate binary code IOO.sub.k =IOI.sub.k =O.sub.k =I.sub.k (k=1 to 21) for writing. At the same time, check data is generated and output as data P.sub.i (i=1 to 6). These write-in data I.sub.k and P.sub.i are input to the input terminal of the writing/reading circuit 150 having a selected column address.

FIG. 23 is a timing chart showing, in a write-in operation, a control signal of the writing/reading circuit 150, cell selection gates SG1 and SG2, and cell control gates CG1 to CG8.

In the 2-input writing/reading circuit 150a, when write-in data is set to be "0", signals I.sub.21 and I.sub.21-1 are set to be 0, and internal nodes N.sub.1 and N.sub.2 are latched to 0. Signals .phi.a1, .phi.a2, .phi.pa, PBa, and VRFYa are kept at low level, and voltages VBHa, VBMa, and VBLa are set to be 8 V, 2 V, and 0 V, respectively. Therefore, in a "0" write-in operation, a voltage of 8 V is applied to a bit line BL. N.sub.1 =1 and N.sub.2 =0 are latched when the write-in data is set to be "1", and N.sub.1 =N.sub.2 =1 is latched when the Write-in data is set to be "2". For this reason, in "1" and "2" write-in operations, respectively, voltages of 2 V and 0 V are applied to the bit line BL.

When a memory cell in which data is to be written is connected to the word line CG4, a voltage of 20 V is applied to the word line CG4, a voltage of 10 V is applied to the word lines CG1 to CG3 and CG5 to CG8 and the selection line SG1, and a voltage of 0 V is applied to a selection line SG2. Voltages Vg=12 V, 18 V, and 20 V are applied across the gates and channels of memory cells in which "0", "1", and "2" are to be written, respectively. When the voltage Vg=12 V is applied, a tunnel current does not flow, and the threshold voltage of the memory cell does not move and keeps to be -1 V or less. When the voltage Vg=18 V is applied, a tunnel current flows, and the threshold voltage of the memory cell moves in the positive direction, thereby setting the threshold voltage to be 0 V or more and 1 V or less. When the voltage Vg=20 V is applied, a tunnel current larger than that obtained when the voltage of Vg=18 V is applied flows, and a threshold voltage is set to be 2 V or more and 3 V or less.

As described above, ternary intermediate binary codes 00, 01, and 11 can be written in memory cells. On the other hand, the 1-input writing/reading circuit 150b is obtained by removing a second sense amplifier from the 2-input writing/reading circuit 150a. In a writing operation, voltages of 8 V and 2 V are applied to the 1-input writing/reading circuit 150 in accordance with data 0 and 1, respectively.

A reading operation will be described below with reference to FIGS. 24 and 25.

In the two-input writing/reading circuit 150a, a reading operation is performed in two steps.

In the first step, it is checked whether data is "0".

The bit BL is kept charged to 1.8 V, and a dummy bit line BLB is kept charged to 1.5 V. Thereafter, the word lines CG1 to CG3 and CG5 to CG8 except for the word line CG4 and the selection lines SG1 and SG2 are set to be 4 V. When the read-out data is "0", the charged bit line BL is discharged, and the potential of the bit line becomes less than 1.5 V. Otherwise, the potential of the bit line is kept at 1.8 V. Finally, these voltages are input to a first sense amplifier constituted by transistors QP13, QP14, QP15, QN57, QN58, and QN59, thereby amplifying the potential differences between the voltages. An internal node N.sub.1 =0 is latched when the read-out data is "0", and an internal node N.sub.1 =1 is latched when the read-out data is "1" or "2".

In the second step, it is checked whether data is "2". The second step is different from the first step only in that the word line CG4 of a memory cell from which data is to be read out is set to be 2 V. In this case, a second sense amplifier constituted by transistors QP16, QP17, QP18, QN62, QN63, and QN64 is used. An internal node N.sub.2 =1 is latched when the read-out data is "2", and an internal node N.sub.2 =0 is latched when the read-out data is "0" or "1".

As described above, ternary intermediate binary codes 00, 01, and 11 can be read out from memory cells. The 1-input writing/reading circuit 150b is activated only in the first step, and the low and high levels of the bit line potential of the 1-input writing/reading circuit 150b correspond to 0 and 1, respectively.

FIG. 25 is a chart showing timings of outputting data for reading.

Data for reading are output from the writing/reading circuit 150 of a selected column address to data I.sub.k (k=1 to 21) and P.sub.i (i=1 to 6). A syndrome S.sub.i is calculated on the basis of these 27-bit data. If the data for reading have errors, the errors are corrected, and the data for reading (intermediate binary codes) are output as O.sub.k =IOI.sub.k =IOO.sub.k (k=1 to 21). Finally, the data IOO.sub.k for reading is inverted into information data IO.sub.l (l=1 to 16) for reading.

As described above, according to the present invention, after the information data is converted into binary codes (intermediate binary codes), error detection/correction is performed. For this reason, a 1-bit error correction code can be applied to the present invention.

In each of the first to sixth embodiments, although a ternary memory constituted by two memory cells is considered, the present invention can be applied to a memory constituted by combining M N-value memory cells. In this case, since N.sup.M states can be set, 2.sup.n (<N.sup.M) states of the N.sup.M states are used, and the 2.sup.n states correspond to n-bit data in a one-to-one correspondence.

The reason why the present invention can be applied to the memory obtained by combining the M N-value memory cells will be described below.

Each memory cell has two adjacent states except the states located at both the ends. The number of combinations of the adjacent states of the M memory cells are 2.sup.M.

For n<2.sup.M when a combination of states is changed to a adjacent combination of states, there is no corresponding relationship between the combination of the states in which informations corresponding to the adjacent combination of states are different by only 1-bit one another and this information. Therefore, with respect to the above errors, at least a 2-bit error correction code is required.

For m bits (m>=2) satisfying 2.sup.m >N>2.sup.m-1, when one of the N states is changed into an adjacent state, there is a corresponding relationship between an intermediate binary code and an N state in which an m-bit expression (i.e., intermediate binary code) must change by only 1-bit. This is because each cell has two adjacent states, and the number of intermediate binary codes which are different from each other by only 1-bit is m (>=2).

Therefore, when error detection/correction are performed with respect to an intermediate binary code, a 1-bit error correction code is satisfactorily used.

FIG. 26 is a schematic view showing the arrangement of a memory system according to the seventh embodiment of the present invention. The same reference numerals as in the first embodiment denote the same parts in the seventh embodiment, and a description thereof will be omitted.

The memory system according to the seventh embodiment comprises an information data storing section 210, an check data storing section 220, an error detector 40, an error corrector 50, a burst destruction position detection section 160, and a data reset section 170. The information data storing section 210 stores information data D20. The check data storing section 220 stores check data. The burst destruction position detection section 160 detects the burst destruction position of stored data of each of the storing sections. The data reset section 170 supposes the data of the burst destruction detected by the burst destruction position detection section 160 and resets the data. In the above arrangement, as in each of the first to sixth embodiments, a cell array 30 may have the information data storing section 210 and the check data storing section 220.

The operation of the memory system, arranged as described above, according the seventh embodiment will be described below with reference to FIG. 27. FIG. 27 is a flow chart showing an error detection/correction algorithm in the seventh embodiment of the present invention.

Before the details of the operations in the steps are described, the operations will be briefly described below.

A reading operation of stored data is started, the address of a column failure is searched. If no column failure is detected, the information data D20 and check data D30 are read out, and these data are input to the error detector 40 and the error corrector 50, respectively. If errors are detected, when the number of errors falls within the permissible range of the error detector 40, the error detector 40 detects the errors. At this time, when the number of errors falls within the permissible range of the error corrector 50, the error corrector 50 corrects the errors. When the number of errors is large than the maximum value in the permissible range of the error detector 40, the error detector 40 probabilistically detects the errors. Up to this operation, the read-out operation is ended.

When a column failure occurs, a pointer is set at the address of this failure column. Thereafter, the information data D20 and the check data D30 are read out, and these data are input to the error detector 40. When the number of errors falls within the permissible range of the error detector 40, error detection/correction is executed as in each of the above embodiments. When the number of errors falls out of the permissible range of the error detector 40, data at the address of a failure column is changed, and the changed data is input to the error detector 40 again.

In accordance with the relationship between the number of errors and the number of errors which can be detected by the error detector 40, the above algorithm is repeated until a change in data at the address of the failure column is performed for all possible patterns. In any pattern, when the number of errors falls within the permissible range of the error detector 40, and the number of errors falls outside the permissible range of the error corrector 50, an error flag for informing that errors have occurred is output.

The contents of the steps shown in FIG. 27 will be briefly described.

A reading operation is started (step S1). The address of a column failure is searched (step S2). In this case, the number of errors is set to be n.

It is checked (step S3) whether n is zero, i.e., column failures are detected. If YES in step S3, the flow advances to step S11. If NO in step S3, the flow advances to step S4.

The information data D20 and the check data D30 are read out (step S4). Error detection is performed, and the number of errors obtained at this time is set to be m (step S5).

It is checked (step S6) whether the number of errors obtained in step S5 is equal to or smaller than the number M of correctable errors. If YES in step S6, the flow advances to step S7. If NO in step S6, the flow advances to step S9.

It is checked (step S7) whether the number of errors is zero. If YES in step S7, the flow advances to step S10 to end reading (step S10). If NO in step S7, the flow advances to step S8 to correct the errors (step S8).

If NO in step S6, an error flag for informing that incorrectable errors have been detected is output (step S9), and reading is ended (step S10).

If it is determined in step S3 that column failures are detected, it is checked (step S11) whether the number of column failures is equal to or smaller than the number N of permissible column failures. If YES in step S11, the flow advances the step S12, and addresses a.sub.i of the failure column are output. If NO in step S11, the flow advances the step S20, and an error flag for informing that incorrectable errors have been detected is output (step S20), and reading is ended (step S21).

The information data D20 and the check data D30 are read out (step S13). Error detection is performed, and the number of errors obtained at this time is set to be m (step S14).

It is checked (step S15) whether the number of errors obtained in step S14 is equal to or smaller than the number L of perfectly detectable errors. If YES in step S15, the flow advances to step S16 to check whether the number of errors is equal to or smaller than the number of correctable errors (step S16). If NO in step S15, the flow advances to step S19 to output an error flag for informing that incorrectable errors have been detected (step S19). Reading is ended (step S21).

If YES in step S16, the flow advances to step S7. If NO in step S16, the flow advances to S17 to change data at the address of the failure column (step S17).

It is checked (step S18) whether a data change at the failure column address in step s17 is performed to all possible patterns. If YES in step S18, the flow advances to step S5. Otherwise, the flow is returned to step S14.

In the above flow chart, the number N of failure columns is desirably set to be the number L of perfectly detectable errors or less. N=L-M or N=1 is generally satisfied.

FIG. 28 is a block diagram showing a failure in the seventh embodiment. In FIG. 28, an error occurs in a memory cell in which a hatched portion is located, and a numerical value of each hatched portion indicates the size of the error of a corresponding one of the hatched portions. A case wherein a 1-bit error correction/2-bit error detection code is applied as an example will be described below.

In reading out data from row a, since row a has no error, the data is correctly read out from row a without any change.

In reading out data from rows b and d, since each of rows b and d has only one error, each error is corrected by the error corrector 50.

In reading out data from row c, since row c has two errors, these errors are detected by the error detector 40.

In reading out data from row e, since row e has one error on a failure column and one error outside the failure column, these errors are detected by the error detector 40. Thereafter, the data on the failure column is converted into possible data, and row e has only the error except for the failure column as an error serving as original write-in data. In this case, this data is corrected by the error corrector 50.

In reading out data from row f, since an error having a size of 2 is located on the failure column, this error is detected by the error detector 40. Thereafter, as in row e, error data is corrected by the error corrector 50.

In reading out from row g, row g has an error, having a size of 2, on the failure column and one error, having a size of 1, except for the failure column. In this case, these errors are probabilistically detected by the error detector 40. When the errors are detected, as in row f, error data are corrected by the error corrector 50.

In reading out data from row h, row h has one error, having a size of 2, on the failure column and two or more errors except for the failed column. In this case, although these errors are probabilistically detected by the error detector 40, the errors are not corrected.

Table 8 shows the relationship between the number of information bits and the number of check bits when ternary data are used.

                  TABLE 8
    ______________________________________
    Number of Inspection Data
            S3EC-D3ED is            S3EC-D3ED is
            applied to              applied to
            Binary       S3EC-D3ED is
                                    Binary
    Number of
            Expression   applied to Expression
    Information
            Multi-Value  Information
                                    Multi-Value
    Data    Data         Data       Data
    ______________________________________
    . . .   . . .        . . .      . . .
    16      10(10)       9(6)       6(6)
    32      12(12)       12(8)      7(7)
    64      12(12)       15(10)     8(8)
    128     14(14)       15(10)     9(9)
    . . .   . . .        . . .      . . .
    ______________________________________


Table 8 shows a case wherein a single 2-bit byte error correction/double 2-bit byte error detection code is applied as a binary code, and a case wherein a single 3-bit byte error correction/double 3-bit byte error correction code is applied as true data, and a 1-bit error correction/2-bit error detection code is applied as a binary code according to the present invention. As is apparent from Table 8, the number of check data can be minimized with respect to the number of information data when a 1-bit error correction/2-bit error detection code is applied as the binary code according to the present invention. Each numerical value in the parentheses in Table 8 represents the number of memory cells with respect to the number of check data.

The present invention is not limited to the above embodiments, and various changes and modifications of the present invention can be effected without departing from the spirit and scope of the present invention.

Additional advantages and modifications will readily occur to those skilled in the art. Therefore, the present invention in its broader aspects is not limited to the specific details, representative devices, and illustrated examples shown and described herein. Accordingly, various modifications may be made without departing from the spirit or scope of the general inventive concept as defined by the appended claims and their equivalents.


Top