A method of storing data to a memory cell having n states (n being a natural number), the method including storing externally input data in a data storage circuit, executing one of shifting and holding a logic level of data which is stored in the data storage circuit in accordance with data read from the memory cell more than one time by varying a voltage supply to a gate electrode of the memory cell, and executing one of shifting and holding the states of the memory cell in accordance with the data which is stored in the data storage circuit.
|
1. A method of storing data to a memory cell having n states (n being a natural number), the method comprising:
storing externally input data in a data storage circuit; executing one of shifting and holding a logic level of data which is stored in the data storage circuit in accordance with data read from the memory cell more than one time by varying a voltage supply to a gate electrode of the memory cell; and executing one of shifting and holding the states of the memory cell in accordance with the data which is stored in the data storage circuit.
3. A method of storing data to a memory cell having n states (n being a natural number), the method comprising:
storing externally input data having one of a first logic level and second logic level in a data storage circuit; shifting a logic level of the data stored in the data storage circuit to the second logic level when data read from the memory cell is at the first logic level and the data stored in the data storage circuit is at the first logic level; shifting the logic level of the data stored in the data storage circuit to the first logic level when the data read from the memory cell is at the first logic level and the data stored in the data storage circuit is at the second logic level; holding the logic level of the data stored in the data storage circuit when the data read from the memory cell is at the second logic level; shifting a state of the memory cell when the logic level of the data stored in the data storage circuit is at the first logic level; and holding the state of the memory cell when the logic level of the data stored in the data storage circuit is at the second logic level.
2. The method according to
the first data is for setting the state of the memory cell to state "0" or state "n/2"; the second data is for setting the state of the memory cell to state "n/4 or "3n/4"; and the third data is for setting the state of the memory cell to state "n/8", "3n/8", "5n/8" or "7n/8".
4. The method according to
the first data is for setting the state of the memory cell to state "0" or state "n/2"; the second data is for setting the state of the memory cell to state "n/4" or "3n/4"; and the third data is for setting the state of the memory cell to state "n/8", "3n/8", "5n/8" or "7n/8".
|
This is a continuation of application Ser. No. 10/034,515 filed Dec. 27, 2001, now U.S. Pat. No. 6,487,122, which is a divisional of Ser. No. 09/721,385 filed Nov. 22, 2000 now U.S. Pat. No. 6,377,485, which is a continuation of Ser. No. 09/470,652 filed Dec. 22, 1999 now U.S. Pat. No. 6,178,115, which applications are hereby incorporated by reference in their entirety.
This invention relates to a non-volatile semiconductor memory device and, more particularly, it relates to a memory device adapted to store multi-valued data and also to a method of storing such data of the device.
NAND type flush memory devices comprising an EEPROM that is an electrically writable non-volatile semiconductor memory have been proposed. In such a NAND type flush memory, the sources and the drains of a plurality of adjacently arranged memory cells are connected in series and the plurality of memory cells that are connected in series are connected to a bit line as a unit. Then, a set of data are collectively written in or read from all or half of the plurality of cells arranged in a row.
In recent years, multi-valued memories that can store a plurality of data (n-bit data) written into a single cell have been developed as NAND type flush memories. Such a multi-valued memory requires the use of n latch circuits for writing data to or reading data from a single cell in order to write a plurality of data to or reading a plurality of data from the single cell because the threshold value of the cell is determined by the contents of the data latched by the latch circuits.
However, as the number of data n that can be stored in a single cell increases, the number of latch circuits that is equal to n also increases to make them occupy the chip that contains them to a large extent.
Meanwhile, when storing data in a cell, an operation is conducted to verify that the threshold value of the cell properly corresponds to the written data. The number of verifying operations increases as the number of data to be written to a cell. Then, the time required for data writing and write-verifying operations increases for each cell.
According to the invention, there is provided a method of storing data to a memory cell having n states (n being a natural number), the method including storing externally input data in a data storage circuit, executing one of shifting and holding a logic level of data which is stored in the data storage circuit in accordance with data read from the memory cell more than one time by varying a voltage supply to a gate electrode of the memory cell, and executing one of shifting and holding the states of the memory cell in accordance with the data which is stored in the data storage circuit.
According to the invention, there is also provided a method of storing data to a memory cell having n states (n being a natural number), the method including storing externally input data having one of a first logic level and second logic level in a data storage circuit, shifting a logic level of the data stored in the data storage circuit to the second logic level when data read from the memory cell is at the first logic level and the data stored in the data storage circuit is at the first logic level, shifting the logic level of the data stored in the data storage circuit to the first logic level when the data read from the memory cell is at the first logic level and the data stored in the data storage circuit is at the second logic level, holding the logic level of the data stored in the data storage circuit when the data read from the memory cell is at the second logic level, shifting a state of the memory cell when the logic level of the data stored in the data storage circuit is at the first logic level, and holding the state of the memory cell when the logic level of the data stored in the data storage circuit is at the second logic level.
Additional objects and advantages of the 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 invention. The objects and advantages of the invention may be realized and obtained by means of the instrumentalities and combinations particularly pointed out hereinafter.
The accompanying drawings, which are incorporated in and constitute a part of the specification, illustrate presently preferred embodiments of the 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 invention.
Now, the present invention will be described by referring to the accompanying drawings that illustrate preferred embodiments of the invention.
To begin with, the first embodiment of the invention will be summarily described below.
According to the invention, a 1-bit data will be written into a single cell in a write operation. When writing the next 1-bit data into the cell, a new data will be taken in from the outside and a write operation will be carried out. In this way, a 1-bit data will be written in a single write operation and write operations will be carried out sequentially.
Conventionally, when the first 1-bit data is written into a cell, two states of threshold value appear depending on "1" or "0" of the data of the cell. As the next 1-bit data is written into the cell, a new state of threshold value is required for each of the two states of threshold value. Thus, at least two latch circuits are required to store the three states including the first two states of threshold value and the write non-select state that is not selected for the data writing operation. When the next 1-bit data is written, a new state is required for each of the preceding four states of threshold value and hence a total of five states have to be stored including the preceding four states of threshold value and the write non-select state. Thus, at least three latch circuits are required to store the five states of threshold value. In this way, a total of n latch circuits are required for writing n bits into a single cell.
According to the invention, when a single cell stores data of n-1 bits written into it, there exist M=2(n-1) threshold values for the cell. Assuming that there are m different threshold values of A1 through Am as shown in
Then, the threshold value of the cell written there this time includes the level of Bi or not has to be verified. To do this, the gate potential of the cell is made equal to vbi' to see if the cell is turned on or off. If the cell is turned off, the threshold value of the cell is higher than the potential Vbi' and hence the write optical will be terminated.
However, since there is no knowing about the initial state of the cell, although it is equal to one of A1 through Am, a verify operation has to be carried out for each of the potentials vbi' through Vbm' to determine if the data is written only into the cell whose threshold value has been shifted from Ai to Bi or not.
When carrying out a verify operation with potential Vbi', the cell will be turned off to indicate that the verify operation is OK and terminated successfully if the threshold value of the cell is higher than Ai+1. Therefore, this state is stored in the latch circuit by preliminarily reading the data of the cell with potential Vai+1. Then, a verify read operation is carried out with potential Vbi'. If the state of the cell is higher than Ai+1, the outcome of the verify read operation is forcibly brought down to a low level (to indicate that the verify operation is NG). If, on the other hand, the state of the cell is lower than Ai, the cell is turned on without exception to indicate that the verify operation is NG. Thus, the bit line is brought up to a high level only when the verify operation is OK with Bi.
If the latch circuit storing the written data is at the high level (and hence no data is written), the bit line is forcibly brought up to a high level. Thus, the bit line is brought up to a high level only when the verify operation is OK or the high level is latched from the beginning (and hence no data is written). The outcome of this operation is latched by the latch circuit where the data to be written is latched. On the other hand, the latch circuit is brought down to level LOW only when the write operation is NG.
In this way, a verify operation is carried out for each and every one of the potentials Vb1' through Vbm'. However, the data latch circuit comes into the write non-select state (data "1") only when the verify operation is OK with potential Vbi' for the cell where Ai written there is shifted to Bi. Therefore, the data stored in the data latch circuit remains unchanged with any other verify potential.
As a result of using the above process according to the invention, only two latch circuits are required, one for storing the written data always when storing data of n bits and one for carrying out a preliminary reading operation of determining if the cell has a potential higher than Ai+1 (and hence disregards any verify operation) and storing the outcome of the determining operation.
Referring to
The bit line control circuit 2 includes a plurality of data storage circuits, which will be described hereinafter, and is adapted to read a data from a selected one of the memory cells of the memory cell array 1 by way of a corresponding bit line, detect the state of a selected one of the memory cells of the memory cell array 1 also by way of a corresponding bit line or write a data into a selected one of the memory cells of the memory cell array 1 by applying a write control voltage thereto by way of a corresponding bit line. The bit line control circuit 2 is connected to a column decoder 3 and a data input/output buffer 4. The column decoder 3 selects one of the data storage circuits of the bit line control circuit 2 and the data read out from a memory cell to the selected data storage circuit is output to the outside way of the data input/output buffer 4 and data input/output terminal 5.
On the other hand, the data input to the data input/output terminal 5 from the outside is input to a data storage circuit selected by the column decoder 3 via the data input/output buffer 4.
The word line control circuit 6 is connected to the memory cell array 1. The word line control circuit 6 is adapted to select one of the word lines of the memory cell array 1 and apply a voltage thereto that is necessary for reading, writing or erasing a data.
The memory cell array 1, the bit line control circuit 2, the column decoder 3, the data input/output buffer 4 and the word line control circuit 6 are connected to a control signal generating circuit 7a and a control voltage generating circuit 7b and controlled by the latter circuits. The control signal generating circuit 7a and the control voltage generating circuit 7b are connected to a control signal input terminal 8 and controlled by a control signal input from the outside by way of a control signal input terminal 8. Thus, the control signal generating circuit 7a and the control voltage generating circuit 7b generate respectively a signal and a voltage necessary for a program operation, a program verify operation, a read operation, an erase operation, an erase verify operation or some other operation to be carried out in the memory device according to the control signal supplied from the outside.
A plurality of NAND cells are arranged in the memory cell array 1. For example, each NAND cell may comprise sixteen memory cells M1, M2, M3, . . . , M16 connected in series, which are EEPROMs, a first selection gate S1 connected to the memory cell M1 and a second selection gate S2 connected to the memory cell M16. The first selection gate S1 is connected to the bit line BL0 and the second selection gate S2 is connected to the source line SRC. The control gates of the memory cells M1, M2, M3, . . . , M16 arranged in a row are commonly connected to word lines WL1, WL2, WL3, WL16. All the first selection gates S1 are commonly connected to select line SG1 and all the second selection gates S2 are commonly connected to select line SG2.
Each block comprises a total of 4,224 NAND cells and the data of each block are collectively erased. The memory cells connected to a word line form a sector and data are collectively written into and read from a sector. For example, a sector may store the data of three pages.
The current path of N-channel transistor 61a is connected at an end thereof to bit line BLi. The gate of the transistor 61a is supplied with signal BLTR. The other end of the current path of the transistor 61a is connected to an end of the current path of transistor 61b and also to an end of the current path of transistor 61c. The other end of the current path of the transistor 61b is connected to terminal 62a. The terminal 62a is supplied with voltage VBLA. The gate of the transistor 61b is supplied with signal PREA. The gate of the transistor 61c is supplied with signal BLSA.
Bit line BLi+1 is connected to an end of the current path of an N-channel transistor 61d. The gate of the transistor 61d is supplied with said signal BLTR. The other end of the current path of the transistor 61d is connected to an end of the current path of transistor 61e and also to an end of the current path of transistor 61f. The other end of the current path of the transistor 61e is connected to terminal 62b. The terminal 62b is supplied with voltage VBLB. The gate of the transistor 61e is supplied with signal PREB. The gate of the transistor 61f is supplied with signal BLSB. The transistors 61b, 61e respectively precharge the non-select bit lines to potentials VBLA, VBLB according to signals PREA, PREB. The transistors 61c, 61f respectively select bit lines according to signal BLSA, BLSB.
The other ends of the transistors 61c, 61f are connected to terminal 62c through transistor 61g and also to node NE. The gate of the transistor 61g is supplied with signal BIAS and the terminal 62c is supplied with voltage VCC. The transistor 61g precharges a bit line according to signal BIAS when reading data.
The node NE is connected to an end of the current path of transistor 61h. The gate of the transistor 61h is supplied with signal BLC1 and the other end of the current path of the transistor 61h is connected to a first latch circuit LAT (A). The first latch circuit LAT (A) is formed by a pair of clocked inverter circuits 61i, 61j. The clocked inverter circuit 61i is controlled by signals SEN1, SEN1B (B representing an inverse signal) while the clocked inverter circuit 61j is controlled by signals LAT1, LAT1B. The first latch circuit LAT (A) latches a data to be written.
Transistors 61k, 61l are connected in series to the node NE. The gate of the transistor 61k is connected to node NC of the first latch circuit LAT (A), while the gate of the transistor 61l is supplied with signal VRFY1. The current path of the transistor 61l is supplied with voltage VREG. The transistors 61k, 61l select potentials for bit lines according to the data latched by the latch circuit LAT (A).
The node NA of the first latch circuit LAT (A) is connected to terminal 62d through P-channel transistor 61m. The gate of the transistor 61m is supplied with signal PRSTB1, while the terminal 62d is supplied with voltage VCC. The transistor 61m sets the node NA of the first latch circuit LAT (A) to level HIGH when writing or reading a data. The node NA is grounded through capacitor 61n. The capacitor 61n holds the electric charge of the node NA when reading a data.
The node NA is also connected to said column select gate (not shown) through transistor 61o and clocked inverter circuit 61p that are connected in parallel. The gate of the transistor 61o is supplied with signal SPB and the clocked inverter 61p is controlled by signals Osac, Osacb. The transistor 61o transfers the data supplied to it by way of said column select gate to the first latch circuit LAT (A) when writing a data. The clocked inverter circuit 61p operates as buffer when reading a data.
Meanwhile, the node NE is connected to an end of the current path of transistor 61q. The gate of the transistor 61q is supplied with signal BLC2 and the other end of the current path of the transistor 61q is connected to the second latch circuit LAT (B). The second latch circuit LAT (B) is formed by a pair of clocked inverter circuits 61r, 61s. The clocked inverter circuit 61r is controlled by signals SEN2, SEN2B, whereas the clocked inverter circuit 61s is controlled by signals LAT2, LAT2B. The second latch circuit LAT (B) latches the dats read out from a memory cell.
A pair of transistors 61t, 61u that are connected in series are then connected to the node NE. The gate of the transistor 61t is connected to node ND of the second latch circuit LAT (B), whereas the gate of the transistor 61u is supplied with signal VRFY2. The current path of the transistor 61u is supplied with voltage VREG. The transistors 61t, 61u are used to select the potential of a bit line according to the latched data.
The node NB of the second latch circuit LAT (B) is connected to terminal 62e through P-channel transistor 61v. The gate of the transistor 61v is supplied with signal FRSTB2, whereas the terminal 62e is supplied with voltage VCC. The transistor 61v sets the node NB of the second latch circuit LAT (B) to a high level in a verify read operation. The node NB is grounded through capacitor 61w. The capacitor 61w holds the electric charge of the node NB in a verify read operation.
The first embodiment having the above described configuration operates in a manner as described below.
Referring to
Since the memory cells of the embodiment are multi-valued cells, each cell can store a 3-bit data. The stored 3-bit data can be switched by means of an address (1st page, 2nd page, 3rd page).
The data of a memory cell is reduced to "0" as a result of an erase operation and data "1" will be read out by addressing any of the first through third pages.
(Method of Selecting a Cell)
In a read operation, a program verify operation or a program operation, one of the pair of bit lines (BLi, BLi+1) connected to a data storage circuit is selected by an externally specified address. Then, a word line is selected by an externally specified address to select a sector as shown in FIG. 3. The sector can be switched by means of an address.
An erase operation is conducted on a block by block basis as shown in
In an erase verify operation, the bit line (BLi) of the pair of bit lines (BLi, BLi+1) connected to a data storage circuit is subjected to verify read in a single operation and the outcome of the operation is stored in the first latch circuit LAT (A) as shown in FIG. 6. Then, a verify operation is conducted for bit line (BLi+1) and the logical sum of the outcome of this optical and that of the previous verify read operation is stored in the first latch circuit LAT (A). The erase verify operation is repeated until the nodes NA of all the first latch circuits LAT (A) are brought down to a low level.
(Program and Program Verify)
(1st Page Program)
In a program operation, firstly an address is specified to select a sector as shown in FIG. 3. The memory can proceeds for a program operation only in the sequence of the first page, the second page and the third page. Thus, the first page is firstly addressed.
Then, the data to be written is stored in the first latch circuits LAT (A) in all the data storage circuits through the data input/output buffer 4, the column select gate and the transistor 61o shown in FIG. 6. If data "1" (no data is written) is externally input, the node NA of the first latch circuit LAT (A) is set to a high level. If, on the other hand, data "0" (a data is written) is externally input, the node NA is set to a low level. Thereafter, the data of the first latch circuit LAT (A) will be the potential of the node NA of the data storage circuit and the data of the second latch circuit LAT (B) will be the potential of the node NB of the data storage circuit.
The transistor 61h is turned on as voltage VCC+Vth is supplied to the gate of the transistor 61h as signal BLC1. Then, since the transistors 61c, 61a are on, the bit line will show the supply potential VCC when data "1" is stored in the first latch circuit LAT (A) and it will show the ground potential VSS when data "0" is stored in the first latch circuit LAT (A). No data should be written to any cells that are in an unselected page but connected to the selected word line because their bit lines are not selected. Therefore, the bit lines connected these cells are held to potential VCC as in the case where data "1" is stored.
Referring to
When writing data "0", the data of the memory cell is made equal to "4". When writing data "1", on the other hand, the data of the memory cell remains equal to "0".
(Verify 1st Page)
(Verify Operation of the Cell having the Highest Threshold Value)
A verify operation on the cell having the highest threshold value will be described by referring to
For verifying the first page, potential "d" that is slightly higher than potential "d" to be used for a corresponding read operation is applied to the selected word line. In the following description, the denomination of a potential accompanied by "'" refers to a potential to be used for a verify operation, which is slightly higher than the potential to be used for a corresponding read operation.
Then, potential Vread is supplied to the unselected word lines and select line SG1 of the selected block. At the same time, the signal BIAS supplied to the gate of the transistor 61g of
As described earlier, the low level is stored in the first latch circuit LAT (A) as shown in
The above operations are same as those conducted for 2-valued data.
(2nd Page Program)
As in the case of the first page program, the data to be written is stored in the first latch circuits LAT (A) in all the data storage circuits for the second page program. Then, the data is written in all the cells of the page that are selected by supplying a predetermined voltage.
As shown in
(Verify 2nd Page)
(Verify Operation of the Cell having the Highest Threshold Value)
A verify operation to be conducted when the data of a memory cell is quality to "6" will be described by referring to
The verify operation is exactly same as the one described above for the first page because no cells other than those storing data "6" show a potential higher than potential "f'". In the verify operation for the first page, potential "d'" is applied to the word line to verify if the data of the memory cell becomes equal to "4" or not. Likewise, potential "f'" is applied to the word line to verify if the data of the memory cell becomes equal to "6" or not. As a result of a verify operation same as the one described for the first page, a high level is latched by the first latch circuit LAT (A) only when the cell gets to the threshold voltage or when no write operation is carried out (as level HIGH is latched to the first latch circuit LAT (A) from the beginning). A low level is latched by the first latch circuit LAT (A) only when the cell does not get to the threshold voltage and hence data "6" is not written into the memory cell or data "2" is written into the memory cell.
(Verify Operation of a Cell having a Medium Threshold Value)
Now, a verify operation of a cell having a medium threshold value will be described by referring to
Then, potential "b'", is supplied to the word line to read the data of the memory cell. As a result, a high level is produced when the bit line gets to threshold voltage "b'" or the data of the memory cell is equal to or greater than "4". On the other hand, a low level is produced when the bit line does not get to threshold voltage "b'" or the data of the memory cell is equal to "0". Then, as signal VREG shown in
Then, as signal VREG at the side of the first latch circuit LAT (A) is made equal to potential VCC and potential VRFY1 is brought up to a high level, the bit line is brought up to a high level if the first latch circuit LAT (A) stores the high level (and hence no write operation is carried out). The potential of the bit line is read to the first latch circuit LAT (A) after the operation. The high level is latched by the first latch circuit LAT (A) when the memory cell storing data "2" gets to the threshold voltage or when no write operation is carried out. The low level is latched by the first latch circuit LAT (A) when the memory cell storing data "2" does not get to the threshold voltage or when the data of the memory cell where a write operation is carried out is equal to or greater than "4".
Thus, the verify operation of the second page is carried out twice, once when data "2" is written into the memory cell and once when data "6" is written into the memory cell. As a result, a write operation is carried out again when the first latch circuit LAT (A) is at a low level and the program operation and the verify operation will be repeated until the data of all the data storage circuits get to a high level. However, the write operation will take time when the data of the memory cell is equal to "6" because the threshold voltage is high.
In view of this fact, of the program verify operations that are repeatedly carried out, the first several verify operations of seeing if the data of the memory cell is equal to "6" or not may be omitted as shown in FIG. 13D. Additionally, after several program verify operations, the operation of writing data "2" whose threshold voltage is low must have been finished. Then, the subsequent verify operations of seeing if the data of the memory cell is equal to "2" can be omitted. However, at and near the time when the operation of writing data "2" is finished, both a program verify operation of seeing if the data of the memory cell is equal to "2" and that of seeing if the data of the memory cell is equal to "6" will be carried out.
In the operation of verifying the second page, potential "d" as shown in
(3rd Page Program)
As in the case of the first and second page programs, the data to be written is stored in the first latch circuits LAT (A) in all the data storage circuits for the third page program. Then, the data is written in all the cells of the page that are selected by supplying a predetermined voltage to the word lines.
As shown in
(Verify 3rd Page) The data of the memory cells written by the third page program will be any of four data of "7", "5", "3" and "1". Therefore, four verify operations will be carried out for the third page.
(Verify Operation of the Cell having the Highest Threshold Value)
A verify operation on the cell having the highest threshold value that is conducted when the data of the memory cells is equal to "7" will be described by referring to
The verify operation is exactly same as the operation of the first page where the data of the memory cells are made equal to "4" by the verify operation and that of the second page where the data of the memory cells are made equal to "6" because no cells other than those storing data "7" show a potential higher than potential "g". In the case of the third page, potential "g'" is supplied to the word line to carry out a verify operation.
As a result of a verify operation same as the one described for the first page, a high level is latched by the first latch circuit LAT (A) only when the cell gets to the threshold voltage or when no write operation is carried out (as the high level is latched to the first latch circuit LAT (A) from the beginning). A low level is latched by the first latch circuit LAT (A) only when the cell does not get to the threshold voltage and hence data "7" is not written into the memory cell or data "1", "3" and "5" are written into the memory cell.
(Verify Operation of a Cell having a Medium Threshold Value)
Now, a verify operation of a memory cell for storing data "5" will be described. This verify operation is same as the one that is carried out when the data of the memory cell is equal to "2" in the second page.
However, since the operation is conducted to verify if the data of the memory cell is equal to "5" or not, the potential of the word line is made equal to "f" as shown in
(Verify Operation of a Cell having a Medium Threshold Value)
Now, a verify operation of a memory cell for storing data "3" will be described.
The verify operation is exactly same as the operation of the second page where the data of the memory cells are made equal to "2" by the verify operation and that of the third page where the data of the memory cells are made equal to "5".
However, since the operation is conducted to verify if the data of the memory cell is equal to "3" or not, the potential of the word line is made equal to "d" as shown in
(Verify Operation of a Cell having a Medium Threshold Value)
Now, a verify operation of a memory cell for storing data "1" will be described.
The verify operation is exactly same as the operation of the second page where the data of the memory cells are made equal to "2", by the verify operation and that of the third page where the data of the memory cells are made equal to "5" and "3".
However, since the operation is conducted to verify if the data of the memory cell is equal to "1" or not, the potential of the word line is made equal to "b" as shown in
As described above, since data of the memory cells are made equal to "7", "5", "1" and "1", a total of four verify operations will be conducted for the third page. As a result, when the first latch circuit LAT (A) is at a low level, the program operation and the verify operation are repeated until all the data of all the storage circuits are found to be at a high level. However, as in the case of the verify operation of the second page, the time required for a write operation is long when the data of the memory cells shows a high threshold voltage as in the case of the program verify operation of the second page. In view of this fact, of the program verify operations that are repeatedly carried out, the first several verify operations of seeing if the data of the memory cell is equal to "7", "5" or "3" or not may be omitted and the operations are conducted only for data "1". Thereafter, the verify operation of seeing if the data of the memory cell is equal to "1", "3" is repeated for several times. Subsequently, the verify operation of seeing if the data of the memory cell is equal to "1", "3" or "5" is repeated for several times. Finally, the verify operation of seeing if the data of the memory cell is equal to "1", "3", "5" or "7" is repeated for several times. By this time, the entire write operation should have been finished on all the memory cells where data "1" is to be written with a low threshold voltage. In this way, by verifying firstly only data "3", "5" and "7", secondly data "5" and "7" and finally data "7", the time required for the entire verify operations can be significantly reduced.
Additionally, it is no longer necessary to carry out a preliminary read operation of reading the data of memory cells in advance for each verify operation and such a preliminary read operation can be omitted when any data remains in the second latch circuit LAT (B) of FIG. 6.
(Read 1st Page)
(Read Operation of the Cell Having the Highest Threshold Value)
Potential "d" is supplied to the selected word line for reading the first page. Then, potential Vread (4.5V) is supplied to unselected word lines and select line SG1 in the selected block to bring up the potential BIAS supplied to the gate of the transistor 61g of
Then, as the potential of the bit line is read by the first latch circuit LAT (A), the first latch circuit LAT (A) is brought down to a low level if the data of the memory cells is "0", "1", "2" or "3". On the other hand, the first latch circuit LAT (A) is brought up to a high level if the data of the memory cells is "4", "5", "6" or "7". However, when outputting the data stored in the first latch circuit LAT (A), signal Osac of clocked inverter circuit 61p shown in
The above read operations are same as those conducted for 2-valued data.
(Read 2nd Page)
When the data obtained as a result of an operation of reading the second page is equal to "0", the data of the memory cells are separated into two regions of "2" and "3" and "6" and "7", as shown in FIG. 8.
Therefore, firstly it is determined if the data of the memory cells is equal to "6" or "7" and then it is determined if the data of the memory cell is equal to "2" or "3".
(Read Operation of the Cell Having the Highest Threshold Value)
Firstly, it is determined if the data of the memory cells is equal to "6" or "7". This is same as described above for reading the first page because there are no cells showing a potential higher than "f" other than those whose data is equal to "6" or "7". When reading the first page, potential "d" is supplied to the word lines in order to check if the data of the memory cells is equal to "4", "5", "6" or "7". On the other hand, potential "f" is used for the read operation to check if the data of the memory cells is equal to "6" or "7".
As in the case of reading the first page, a high level is latched by the first latch circuit LAT (A) only when the data of the memory cells is equal to "6" or "7". On the other hand, a low level is latched by the first latch circuit LAT (A) when the data of the memory cells is equal to "0", "1", "2", "3", "4" or "5".
(Read Operation of a cell Having a Medium Threshold Value)
Now, a read operation of determining if the data of the memory cells is equal to "2" or "3" will be described below.
This read operation can be carried out simply by supplying potential "b" to the word lines. However, since the cells storing a data of "4" or a higher value also show a high threshold voltage, they will also be turned off. Therefore, it is necessary to check in advance if the data of the memory cells is equal to or greater than "4". Therefore, potential "d" is supplied to the word lines for a read operation and the outcome of the operation is stored in the second latch circuit LAT (B) shown in FIG. 6. Thereafter, as potential "b" is supplied to the word lines to carry out a read operation, the bit line will be brought up to a high level if the data of the memory cells is equal to or greater than "2", whereas it will be brought down to a low level if the data of the memory cells is equal to "0" or "1".
If, at this stage of operation, signal VREG is brought to ground potential VSS and signal VRFY2 is brought up to a high level to turn on transistor 61U, the bit line will be brought down to a low level when the second latch circuit LAT (B) is at the high level. In other words, the bit line will be brought down to a low level when the data of the memory cells is equal to or greater than "4". Therefore, at this time, it will be brought up to a high level only when the data of the memory cells is equal to "2" or "3". This level may be latched by the first latch circuit LAT (A). Then, however, the data stored in the first latch circuit LAT (A) is changed if the data of the memory cells is equal to "6" or "7". In view of this fact, signal VREG is brought to the level of supply voltage VCC and signal VRFY1 is brought up to a high level to turn on transistor 61l. If the high level is latched by the first latch circuit LAT (A) (and hence the data of the memory cells is equal to "6" or "7"), the bit line will be brought up to a high level.
After this operation, the potential of the bit line is latched by the first latch circuit LAT (A). Then, a high level is latched by the first latch circuit LAT (A) when the data of the memory cells is equal to "2", "3", "6" or "7", whereas a low level is latched by the first latch circuit LAT (A) when the data of the memory cells is equal to "0", "1", "4" or "5". As in the case of the operation of reading the first page, signal Osac of the clocked inverter circuit 61p of
In the operation of reading the second page, potential "d" is applied to the word lines to check if the data of the memory cells is equal to or greater than "4" during the read operation provided that the data of the memory cells is equal to "2" or "3" and the result is stored in the second latch circuit LAT (B) shown in FIG. 6. However, if the second page is read after the operation of reading the first page and the data of the memory cells is equal to or greater than "4", a high level is latched by the first latch circuit LAT (A). Therefore, this operation can be omitted by transferring the data stored by the first latch circuit LAT (A) to the second latch circuit LAT (B).
(Read 3rd Page)
If data "0" is output as a result of the operation of reading the third page, the data of the memory cells is equal to "1", "3", "5" or "7" as shown in FIG. 8.
Therefore, firstly, it is determined if the data of the memory cells is equal to "7" or not and, thereafter, it is determined if the data of the memory cells is equal to "5" or not. Then, it is determined if the data of the memory cells is equal to "3" or not and, finally, it is determined if the data of the memory cells is equal to "1" or not. Thus, a total of four operations have to be carried out.
(Read Operation of the Cell Having the Highest Threshold Value)
Firstly, it is determined if the data of the memory cells is equal to "7" or not. This is same as the above described operation of determining if the data of the memory cells is equal to "6" or "7" that is carried out when reading the first and second pages. This is because there are no cells showing a potential higher than "g" other than those whose data is equal to "7". Potential "d" is supplied to the word lines in order to check if the data of the memory cells is equal to "4", "5", "6" or "7" when reading the first page and potential "f" is supplied to the word lines in order to check if the data of the memory cells is equal to "6" or "7" when reading the second page. On the other hand, potential "g" is used for the read operation of this page to check if the data of the memory cells is equal to "7" or not.
As in the case of reading the first page where the data of the memory cells is equal to "14", "5", "6" or "7" and reading the second page where the data of the memory cells is equal to "6" or "7", a high level is latched by the first latch circuit LAT (A) only when the data of the memory cells is equal to "7". On the other hand, a low level is latched by the first latch circuit LAT (A) when the data of the memory cells is equal to "0 ", "1 ", "2 ", "3", "4", "5" or "6.
(Read Operation of a cell Having a Medium Threshold Value)
Now, a read operation of a memory cell storing data "5" will be described. The read operation is exactly same as the operation of the second page where the data of the memory cells is made equal to "2" or "3".
However, potential "f" is supplied to the word lines when reading the data of the memory cell in advance it order to determine if the data of the memory cell is equal to "5" or not. Then, potential "e" is supplied to the word lines for the next read operation.
(Read Operation of a cell Having a Medium Threshold Value)
Now, a read operation of a memory cell storing data "3" will be described. The read operation is exactly same as the operation of the second page where the data of the memory cells is made equal to "2" or "3" and that of the third page where the data of the memory cell is equal to "5".
However, potential "d" is supplied to the word lines when reading the data of the memory cell in advance it order to determine if the data of the memory cell is equal to "3" or not. Then, potential "c" is supplied to the word lines for the next read operation.
(Read Operation of a cell Having a Medium Threshold Value)
Now, a read operation of a memory cell storing data "1" will be described. The read operation is exactly same as the operation of the second page where the data of the memory cells is made equal to "2" or "3" and that of the third page where the data of the memory cells is made equal to "5" or "3".
However, potential "b" supplied to the word lines when reading the data of the memory cell in advance it order to determine if the data of the memory cell is equal to "1" or no. Then, potential "a" is supplied to the word lines for the next read operation.
The data of the memory cell is latched by the first latch circuit LAT (A) as a result of the above four operations.
(Erase)
(Erase/verify)
If the erase operation is carried out thoroughly and the hence threshold voltage of the cells is not higher than the reference value (0V), the potential of the bit line is found to be at a low level. If, on the other hand, the erase operation is carried out insufficiently and hence the threshold voltage of the cells is higher than the reference value (0V), the potential of the bit line is found to be at a high level and the data is latched by the first latch circuit LAT (A). Thus, the high level is latched by the first latch circuit LAT (A) when the erase operation is not carried out sufficiently, whereas a low level is latched by the first latch circuit LAT (A) when the erase operation is carried out sufficiently.
Then, a verify operation is conducted on the other bit line, or bit line (BLi+1). The outcome of the operation may be stored in the first latch circuit LAT (A). However, since the data stored in the first latch circuit LAT (A) is changed, signal VREG is brought to the level of source voltage VCC and signal VRFY1 is brought up to a high level to turn on transistor 61l. When the high level is latched by the first latch circuit LAT (A) (and hence the erase operation is insufficient), the bit line is brought up to a high level through transistors 61k, 61l. After this operation, the potential of the bit line is read by the first latch circuit LAT (A). The high level is latched by the first latch circuit LAT (A) when either of the two bit lines (BLi, BLi+1) is not erased sufficiently.
In this way, the erase operation and the erase/verify operation are repeated until the data of all the first latch circuits LAT (A) are brought down to a low level.
With the memory of this embodiment, eight values, or 3 bits, are stored in a cell. However, sixteen values, or 4 bits, can be stored in a cell by selecting a value for the eight values defined for the third page and carrying out the program operation and the program-verify operation as described above. Therefore, sixteen values or more than sixteen values may be stored in a cell without modifying the data storage circuits and the operation of controlling them according to the invention.
With the above first embodiment, a 1-bit data is written into a cell by a single write operation. Therefore, a total of 2(n-1) threshold voltages exists for the cell when an n-1-bit data is written into the cell. When the next 1-bit data is written, the number of threshold voltages becomes equal to 2n. If the new threshold voltage is selected between two existing threshold voltages, a verify operation of seeing if the newly selected threshold voltage is reached or not can be carried out simply by firstly checking if there is a data is written to a threshold voltage higher than the selected threshold voltage and, if there is, by excluding the data. Then, it is no longer necessary to store all the data stored up to that time to the latch circuits. Therefore, the first embodiment is required to have only a single first latch circuit LAT (A) for storing the data to be written and a single second latch circuit LAT (B) for storing the outcome of the operation of checking if there is a data written to a threshold voltage higher than the predetermined threshold voltage used for the verify operation. Thus, regardless of the value of n, the embodiment is realized by using only two latch circuits to consequently reduce the space required for arranging latch circuits.
The basic operational sequence for driving the latch circuits, the potential of the word lines and the number of the program operations have to be modified. This provides an advantage of easy and simple control operations.
In the circuit diagram of a data storage circuit that can be used for the first embodiment, only the first latch circuit LAT (A) is connected to the transistor 61o, the clocked inverter circuit 61p and the data input/output buffer 4 through the column selected gate (not shown) and the second latch circuit LAT (B) is not connected to the data input/output buffer 4. Thus, the patterned area of the chip can be reduced.
In the case of the above described first embodiment, a total of 2n operations of bringing up the word lines to a high level, reading the data of the cells and latching the read out data have to be carried out for the program-verify operation and the read operation of the n-th page. This means that the time required for the program-verify operation and the read operation is increased enormously as the number of n rises.
An NAND type cell can output a voltage corresponding to the threshold voltage of the cell to the bit line if the threshold voltage is negative. Thus, negative values are selected for the threshold voltages corresponding to all the data of the memory cell and the potentials corresponding to the threshold voltages are output to the bit line by one read operation. Then, the potentials of the bit line are verified simultaneously by a plurality of differential amplifiers to check if they are OK or NG or see if the data is equal to "1" or "0". With this arrangement, the time required for a program-verify operation and a read operation can be significantly reduced. Then, however, a large pattern will be required for the plurality of differential amplifiers and the logic circuits connected to their outputs. Therefore, the second embodiment that will be described hereinafter is designed to make a plurality of sense amplifiers share a single differential amplifier and a single logic circuit on a time division basis.
The overall configuration of the second embodiment of non-volatile semiconductor memory device is same as the one illustrated in FIG. 2.
Referring to
Bit line BLi+1 is connected to an end of the current path of N-channel transistor 241d. The gate of the transistor 241d is supplied with signal BLTR. The other end of the current path of the transistor 241d is connected to an end of the current path of transistor 241e and an end of the current path of transistor 241f. The other end of the current path of said transistor 241e is connected to terminal 242b. The terminal 242b is supplied with voltage VBLB. The gate of said transistor 241e is supplied with signal PREB. The gate of said transistor 241f is supplied with signal BLSB. The transistors 241b, 241e precharge unselected bit lines to potentials VBLA, VBLB according to signals PREA, PREB. The transistors 241c, 241f respectively select bit lines according to signal BLSA, BLSB.
The other ends of the transistors 242c, 241f are connected to node NE. The node NE is connected to an end of the current path of transistor 241h. The gate of the transistor 241h is supplied with signal BLC1 and the other end of the current path of the transistor 241h is connected to latch circuit LAT (C). The latch circuit LAT (C) is formed by a pair of clocked inverter circuits 241i, 241j. The clocked inverter circuit 241i is controlled by signals SEN1, SENLB (B representing an inverse signal) while the clocked inverter circuit 241j is controlled by signals LAT1, LAT1B. The latch circuit LAT (C) latches a data to be written.
The node NA of the latch circuit LAT (C) is connected to terminal 242d through P-channel transistor 241m. The gate of the transistor 241m is supplied with signal PRSTB1, while the terminal 242d is supplied with voltage VCC. The transistor 241m sets the node NA of the latch circuit LAT (C) to a high level when writing or reading a data.
The node NA is also connected to said logic circuit 232 and said column select gate (not shown) through transistor 241o and clocked inverter circuit 241p that are connected in parallel. The gate of the transistor 241o is supplied with signal SPB and the clocked inverter 241p is controlled by signals Osac, Osacb. The transistor 241o transfers the data supplied to it through the column select gate to the latch circuit LAT (C) when writing a data. The clocked inverter circuit 241p operates as buffer when reading a data. Said node NE is connected to said differential amplifier section 231 (not shown) through the Y-selector.
The output terminal of the differential amplifier DFA3 is connected to the input terminal of the inverter circuit 251a. The output signal of the inverter circuit 251a, the output signal of the differential amplifier DFA2 and signal EN1 are supplied to NOR circuit 251b. The output terminal of the differential amplifier DFA5 is connected to the input terminal of inverter circuit 251c. The output signal of the inverter circuit 251c, the output signal of the differential amplifier DFA4 and signals EN1, EN2 are supplied to NOR circuit 251d. The output terminal of the differential amplifier DFA7 is connected to the input terminal of inverter circuit 251e. The output signal of the inverter circuit 251e, the output signal of the differential amplifier DFA6 and signals EN1, EN2 are supplied to NOR circuit 251f.
NOR circuit 251a of the above described logic circuit 232 is supplied with the output signal of the data storage circuit and signal Verify B. The output signal of the NOR circuit 252a, the output signal of the differential amplifier DFA1 and the output signals of the NOR circuits 251b, 251d, 251f are supplied to NOR circuit 252b. The output signal of the NOR circuit 252b is supplied to latch circuit LAT (D). The latch circuit LAT (D) is formed by clocked inverter circuits 252c, 252d. The clocked inverter circuits 252c, 252d are controlled by signal PD. The output signal of the latch circuit LAT (D) is supplied to the Y-selector and the data storage circuit through inverter circuit 252e and clocked inverter circuit 252f.
The data of a memory cell and the threshold voltages thereof are defined in a manner as illustrated in
The data of a memory cell is reduced to "0" as a result of an erase operation and data "1" will be read out by addressing any of the first through third pages.
Cell Selection Method
The cell selection method of this embodiment is similar to that of the first embodiment and 1 sector (3 pages) as shown in
(Program and Program Verify)
(1st Page Program)
When writing data "0", the data of the memory cell is made equal to "4" as shown in FIG. 28. When writing data "1", on the other hand, the data of the memory cell remains equal to "0".
(Verify 1st Page)
Firstly, the unselected word lines and select line SG1 of the selected block are set to potential Vread7 (=Vread+Vth) and source line SRC is set to potential Vread, whereas the selected word lines are set to grounding potential VSS. Thereafter, select line SG2 of the source side of the cell is set to potential Vread 7. A potential is output to the bit line depending on the threshold voltage of the cell. The potential of the bit line is then supplied to the differential amplifier section 231 and the logic circuit 232 through the Y-selector group 233 on a time division basis.
Only the differential amplifier DFA1 is used out of the seven differential amplifiers shown in
Then, as shown in
Additionally, since the verify operation is going on, signal Verify B supplied to the NOR circuit 252a of the logic circuit 232 is brought to a low level and the data stored in the latch circuit LAT (C) of the data storage circuit is supplied to the logic circuit 232. When data "1" is latched by the latch circuit LAT (C) of the data storage circuit (and hence no data is written), data "0" inverted by the clocked inverter circuit 241p is supplied to the NOR circuit 252a shown in FIG. 25. Thus, the high level is latched to the output terminal ND of the latch circuit LAT (D) regardless of the output signal of the differential amplifier DFA1.
On the other hand,
Thus, if the potential read out to the bit line is lower than the reference potential "d'" (and hence the data is written sufficiently), the output signal of the differential amplifier DFA1 is brought up to a high level. Then, the high level is latched to the output terminal ND of the latch circuit LAT (D).
If the potential read out to the bit line is higher than the reference potential "d'" (and hence the data is written insufficiently), the output signal of the differential amplifier DFA1 is brought down to a low level. Thus, the low level is latched to the output terminal of the latch circuit LAT (D).
The input signal is latched by the latch circuit LAT (D) when signal PD as shown in
Then, the Y-selector group 233 is switched and the above sequence is repeated on the output signal of another data storage circuit. At this time, the data of the cell is already read out to the bit line. Therefore, the above operation can be conducted simply by switching the Y-selector group 233 and driving the differential amplifier section 231 and the logic circuit 232.
The program operation and the verify operation as described above are repeated until the data of all the data storage circuits are brought up to a high level.
(2nd Page Program)
As in the case of the first page program, the data to be written next that is externally input is stored in the latch circuits LAT (C) of all the data storage circuits. Then, the data is written in all the memory cells of the selected page depending on the data stored in the latch circuit LAT (C).
As shown in
(Verify 2nd Page)
As in the case of the operation of verifying the first page, a potential is output to the bit line depending on the threshold voltage of the cell. The differential amplifiers DFA1 through DFA3 are used out of the seven differential amplifiers shown in
On the other hand,
Thus, if the potential read out to the bit line is lower than the reference potential "f'" (and hence the data is written thoroughly), the output signal of the differential amplifier DFA1 is brought up to a high level. Then, the high level is latched to the output terminal ND of the latch circuit LAT (D).
If the potential read out to the bit line is lower than the reference potential "d" and higher than the reference potential "f'" (and hence the data is written insufficiently), the output signal of the differential amplifier DFA3 is brought up to a high level. However, since the output of the differential amplifier DFA2 is also at the high level, a low level is latched to the output terminal of the latch circuit LAT (D).
If the potential read out to the bit line is lower than the reference potential "b'" and higher than the reference potential "d" (and hence the data is written sufficiently), the output signal of the differential amplifier DFA3 is brought up to a high level. Therefore, a high level is latched to the output terminal of the latch circuit LAT (D).
If the potential read out to the bit line is higher than the reference potential "b'" (and hence the data is written insufficiently), all the output signals of the differential amplifiers DFA1 through DFA3 are at a low level. Therefore, a low level is latched to the output terminal of the latch circuit LAT (D).
The operation that is conducted after the data is latched by the latch circuit LAT (D) of the logic circuit 232 is same as the operation of verifying the first page. More specifically, if data "1" is latched by the latch circuit LAT (C) of the data storage circuit (and hence no data is written), the data "1" of the latch circuit LAT (C) remains there. On the other hand, if data "0" is latched by the latch circuit LAT (C) of the data storage circuit (and hence a data is written), the data "0" of the latch circuit LAT (C) remains there if the data is written insufficiently. However, the data is replaced by data "1" if the data is written sufficiently into the cell. Then, the Y-selector group 233 is switched and the above sequence is repeated on the output signal of another data storage circuit.
The program operation and the verify operation as described above are repeated until the data of all the data storage circuits are brought up to a high level.
(3rd Page Program)
As in the case of the first page program and the second page program, the data to be written next that is externally input is stored in the latch circuits LAT (C) of all the data storage circuits. Then, the data is written in all the memory cells of the selected page depending on the data stored in the latch circuit LAT (C).
As shown in
(Verify 3rd Page)
As in the case of the operation of verifying the first page, a potential is output to the bit line depending on the threshold voltage of the cell. All the differential amplifiers DFA1 through DFA7 shown in
On the other hand,
Thus, if the potential read out to the bit line is lower than the reference potential "g'" (and hence the data is written sufficiently), the output signal of the differential amplifier DFA1 is brought up to a high level. Then, a high level is latched to the output terminal ND of the latch circuit LAT (D).
If the potential read out to the bit line is lower than the reference potential "f" and higher than the reference potential "g'" (and hence the data is written insufficiently), the output signal of the differential amplifier DFA3 is brought up to a high level. However, since the output of the differential amplifier DFA2 is also at a high level, a low level is latched to the output terminal of the latch circuit LAT (D).
If the potential read out to the bit line is lower than the reference potential "e'" and higher than the reference potential "f" (and hence the data is written sufficiently), the output signal of the differential amplifier DFA3 is brought up to a high level but the output signal of the differential amplifier DFA2 is brought down to a low level. Therefore, a high level is latched to the output terminal of the latch circuit LAT (D).
If the potential read out to the bit line is lower than the reference potential "d" and higher than the reference potential "e'" (and hence the data is written insufficiently), the output signal of the differential amplifier DFA5 is brought up to a high level. However, since the output of the differential amplifier DFA4 is also at a high level, a low level is latched to the output terminal of the latch circuit LAT (D).
If the potential read out to the bit line is lower than the reference potential "c'" and higher than the reference potential "d" (and hence the data is written sufficiently), the output signal of the differential amplifier DFA5 is brought up to a high level. Therefore, a high level is latched to the output terminal of the latch circuit LAT (D).
If the potential read out to the bit line is lower than the reference potential "b" and higher than the reference potential "c'" (and hence the data is written insufficiently), the output signal of the differential amplifier DFA7 is brought up to a high level. However, since the output of the differential amplifier DFA6 is also at a high level, a low level is latched to the output terminal of the latch circuit LAT (D).
If the potential read out to the bit line is lower than the reference potential "a'" and higher than the reference potential "b" (and hence the data is written sufficiently), the output signal of the differential amplifier DFA7 is brought up to a high level. Therefore, a high level is latched to the output terminal of the latch circuit LAT (D).
If the potential read out to the bit line is higher than the reference potential "a'" (and hence the data is written insufficiently), all the output signals of the differential amplifiers DFA1 through DFA7 are at a low level. Therefore, a low level is latched to the output terminal of the latch circuit LAT (D).
The operation that is conducted after the data is latched by the latch circuit LAT (D) of the logic circuit is same as the operation of verifying the first page and that of verifying the second page. More specifically, if data "1" is latched by the latch circuit LAT (C) of the data storage circuit (and hence no data is written), the data "1" of the latch circuit LAT (C) remains there. On the other hand, if data "0" is latched by the latch circuit LAT (C) of the data storage circuit (and hence a data is written), the data "0" of the latch circuit LAT (C) remains there if the data is written insufficiently. However, the data is replaced by data "1" if the data is written sufficiently into the cell. Then, the Y-selector group 233 is switched and the above sequence is repeated on the output signal of another data storage circuit.
The program operation and the verify operation as described above are repeated until the data of all the data storage circuits are brought up to a high level.
(Read 1st Page)
As in the case of a program verify operation, a potential is output to the bit line depending on the threshold voltage of the cell for a read operation. Like an operation of verifying the first page, only the differential amplifier DFA1 is used out of the seven differential amplifiers shown in
If the potential read out to the bit line is higher than the reference potential "d'" (and hence the data of the memory cell is "0", "1", "2" or "3"), the output signal of the differential amplifier DFA1 is brought down to a low level. Thus, the low level is latched to the output terminal of the latch circuit LAT (D).
The data latched by the latch circuit LAT (D) is then supplied to the data storage circuit through the data storage circuit. Then, signal SPB is brought to a high level, and the signal SPB is supplied from the latch circuit LAT (D) to the latch circuit LAT (C) through the transistor 241o shown in FIG. 24. Then, the Y-selector group 233 is switched and the above sequence is repeated on the output signal of another data storage circuit. At this time, the data of the cell is already read out to the bit line. Therefore, the above operation can be conducted simply by switching data storage circuit by means of the Y-selector group 233 and driving the differential amplifier section 231 and the logic circuit 232. In this way, the data of the first page can be stored in all the data storage circuits by switching the Y-selector group 233 and repeating the above sequence.
The data of a memory cell and the threshold voltages thereof are defined in a manner as illustrated in
(Read 2nd Page)
As in the case of reading the first page, a potential is output to the bit line depending on the threshold voltage of the cell for an operation of reading the second page. For verifying the second page, the differential amplifiers DFA1 through DAF3 are used out of the seven differential amplifiers. Therefore, signal EN2 is brought up to a high level and the output signals of the NOR circuits 251b, 251d, 251f are invariably set to a low level. Then, as shown in
If the potential read out to the bit line is lower than the reference potential "d" and higher than "f" (and hence the data of the memory cell is "4" or "5"), the output signal of the differential amplifier DFA3 is brought up to a high level and the output signal of the differential amplifier DAF2 is also brought up to a high level. Thus, a low level is latched to the latch circuit LAT (D).
If the potential read out to the bit line is lower than the reference potential "b" and higher than "d" (and hence the data of the memory cell is "2" or "3"), the output signal of the differential amplifier DFA3 is brought up to a high level. Then, the high level is latched to the latch circuit LAT (D).
If the potential read out to the bit line is higher than the reference potential "b" (and hence the data of the memory cell is "0" or "1"), all the output signals of the differential amplifiers DAF1 through DAF7 are at a low level. Therefore, the low level is latched to the output terminal of the latch circuit LAT (D).
The operation after the step where the data is latched by the latch circuit LAT (D) of the logic circuit 232 is same as that of reading the first page. Thus, a low level is stored in the latch circuit LAT (C) when the data of the memory cells is equal to "0", "1", "4" or "5", whereas a high level is stored in the latch circuit LAT (C) when the data of the memory cells is "2", "3", "6" or "7". However, the data stored in the latch circuit LAT (C) is output to the data input/output buffer 4 through the clocked inverter circuit 241p. Therefore, data "1" is supplied to the data input/output buffer 4 when the data of the memory cells is equal to "0", "1", "4" or "5", whereas data "0" is supplied to the data input/output buffer when the data of the memory cells is equal to "2", "3", "6" or "7".
(Read 3rd Page)
As in the case of reading the first page or the second page, a potential is output to the bit line depending on the threshold voltage of the cell for an operation of reading the third page. For verifying the third page, all the seven differential amplifiers DFA1 through DAF7 are used. Therefore, potentials "g", "f", "e", "c", "d", "b" and "a" are supplied respectively as reference potentials to the non-inverse input terminals of the differential amplifiers DFA1 through DFA7. Then, the single data storage circuit selected by the Y-selector 233 is connected to the differential amplifier section 231 and the logic circuit 232. Additionally, since the read operation is going on, signal Verify B is brought to a high level and the data (indefinite) stored in the latch circuit LAT (C) of the data storage circuit is not supplied to the logic circuit 232.
If the potential read out to the bit line is lower than the reference potential "f" and higher than "g" (and hence the data of the memory cell is "6"), the output signal of the differential amplifier DFA3 is brought up to a high level. However, since the output signal of the differential amplifier DAF2 is also brought up to a high level. Thus, a low level is latched to the output terminal of the latch circuit LAT (D).
If the potential read out to the bit line is lower than the reference potential "e" and higher than "f" (and hence the data of the memory cell is "5"), the output signal of the differential amplifier DFA3 is brought up to a high level. Then, a high level is latched to the output terminal of the latch circuit LAT (D) of the logic circuit 232.
If the potential read out to the bit line is lower than the reference potential "d" and higher than "e" (and hence the data of the memory cell is "4"), the output signal of the differential amplifier DFA5 is brought up to a high level. However, since the output signal of the differential amplifier DAF4 is also brought up to a high level. Thus, a high level is latched to the output terminal of the latch circuit LAT (D).
If the potential read out to the bit line is lower than the reference potential "c" and higher than "d" (and hence the data of the memory cell is 3"), the output signal of the differential amplifier DFA5 is brought up to a high level. Then, a high level is latched to the output terminal of the latch circuit LAT (D) of the logic circuit 232.
If the potential read out to the bit line is lower than the reference potential "b" and higher than "c" (and hence the data of the memory cell is "2"), the output signal of the differential amplifier DFA7 is brought up to a high level. However, since the output signal of the differential amplifier DAF6 is also brought up to a high level. Thus, a low level is latched to the output terminal of the latch circuit LAT (D).
If the potential read out to the bit line is lower than the reference potential "a" and higher than "b" (and hence the data of the memory cell is "1"), the output signal of the differential amplifier DFA7 is brought up to a high level. Then, a high level is latched to the output terminal of the latch circuit LAT (D) of the logic circuit 232.
If the potential read out to the bit line is higher than "a" (and hence the data of the memory cell is "0"), all the output signals of the differential amplifiers DAF1 through DAF7 are at a low level. Therefore, a low level is latched to the output terminal of the latch circuit LAT (D).
The operation after the step where the data is latched by the latch circuit LAT (D) of the logic circuit 232 is same as that of reading the first page. Thus, a low level is stored in the latch circuit LAT (C) when the data of the memory cells is equal to "0", "2", "4" or "6", whereas a high level is stored in the latch circuit LAT (C) when the data of the memory cells is "1", "3", "5" or "7". However, the data stored in the latch circuit LAT (C) is output to the data input/output buffer 4 through the clocked inverter circuit 241p. Therefore, data "1" is supplied to the data input/output buffer 4 when the data of the memory cells is equal to "0", "2", "4" or "6", whereas data "0" is supplied to the data input/output buffer when the data of the memory cells is equal to "1", "3", "5" or "7".
(Erase)
The erase operation of the second embodiment is similar to that of the first embodiment. In an erase operation, firstly a block as indicated by broken lines in
As the erase operation is conducted by selecting voltages for different component sections as shown in
(Erase-verify)
An erase-verify operation is conducted on each of a pair of bit lines (BLi, BLi+1) connected to a data storage circuit. For instance, an erase-verify operation is conducted firstly on bit line (BLi). The outcome of the operation is then stored in the latch circuit LAT (C). The erase-verify operation is almost same as a read operation. However, all the word lines of the selected block are brought to the level of the ground potential VSS in order to verify all the cells of the block.
Then, as shown in FIG. 30 and like a program-varify operation or a read operation, a potential is output to the bit line depending on the threshold voltage of the selected memory cell. Only the differential amplifier DFA1 is used out of the seven differential amplifiers of
Then, as shown in
If the potential read out to the bit line is lower than the reference potential (and hence the erase operation is conducted insufficiently), the output signal of the differential amplifier DFA1 is brought up to a high level. Therefore, the high level is latched to the output terminal of the latch circuit LAT (D).
If, on the other hand, the potential read out to the bit line is higher than the reference potential (and hence the erase operation is conducted sufficiently), the output signal of the differential amplifier DFA1 is brought down to a low level. Therefore, the low level is latched to the output terminal of the latch circuit LAT (D).
The data latched by the latch circuit LAT (D) of the logic circuit 232 is stored in the latch circuit LAT (C) of the data storage circuit by way of the transistor 241o of FIG. 24. Then, the above sequence of operation is followed by switching the Y-selector group 233 depending on select signals YA0 through YA7. At this time, the data of the cell is already read out to the bit line. Therefore, the above operation can be conducted simply by switching data storage circuit by means of the Y-selector group 233 and driving the differential amplifier section 231 and the logic circuit 232. In this way, the data of the first page can be stored in all the data storage circuits by switching the Y-selector group 233 and repeating the above sequence.
The data of a memory cell and the threshold voltages thereof are defined in a manner as illustrated in FIG. 28. Thus, a low level is stored in the latch circuit LAT (C) when the erase operation is conducted sufficiently, whereas a high level is stored in the latch circuit LAT (C) when the erase operation is conducted only insufficiently.
Then, an entire identical operation is conducted on the other bit line, or bit line (BLi+1). At this time, Verify B of the logic circuit 232 is brought down to a low level. Then, if the verify operation is defective in the first erase-verify operation, the high level is latched by the latch circuit LAT (C) regardless of the outcome of the second erase-verify operation because the node NA of the latch circuit LAT (C) is at the high level. In other words, the high level is latched by the latch circuit LAT (C) only when either of the bit lines (BLi, BLi+1) is found defective as a result of the erase-verify operation. Thus, the erase operation and the erase-verify operation are repeated until the data of all the latch circuits LAT (C) are brought down to the low level.
Like the first embodiment, the above described second embodiment is also adapted to prevent any increase in the number of latch circuits if the number of data to be stored is increased. Additionally, a plurality of data storage circuits are provided only with a differential amplifier section 231 and a logic circuit 232 and the data storage circuits are connected by means of a Y-selector group on a time division basis. Thus, the number of differential amplifier sections 231 and logic circuits 232 that normally take a large space can be reduced to minimize the chip size.
While the operation of bringing the word lines to a high level, reading the data of a memory cell and latching the outcome of the reading has to be repeated 2n times for a program-verify and read operation in the first embodiment. The threshold voltages of the memory cells are collectively judged by means of differential amplifiers in the second embodiment. Thus, the possible increase in the time required for the program-verify and read operation can be suppressed simply by increasing the number of differential amplifiers if the value of n is raised.
In the case of the above described first embodiment, the read operation has to be repeated by shifting the level of the word lines by a total of (2n-1) times for reading the n-th page. In the case of the above described second embodiment, on the other hand, the number of times of repeating the read operation is reduced in the third embodiment. More specifically, in the third embodiment, when writing into the n-th page after writing into the (n-1)-th page, the externally input data is not directly written into the n-th page but the value obtained by carrying out an logical operation on the externally input data and the data already written into the inside is written. Once such a data is written, it is no longer necessary to shift the level of word lines by (2n-1) times for the operation of reading the n-th page and it is now possible to reduce the number of times of shifting the level to (2n/2) times. For example, when reading 8-valued data, while seven read operations are required for reading the third page in the first embodiment, the third page can be read by four read operations in the third embodiment.
Now, the third embodiment will be described in detail below. The circuit configuration of the third embodiment is identical with that of the first embodiment.
The data of a memory cell and the threshold voltages thereof are defined in a manner as illustrated in
The data of a memory cell is reduced to "0" as a result of an erase operation and data "1" will be read out by addressing any of the first through third pages.
(Cell Selection Method)
In a read operation, a program verify operation or a program operation, one of the pair of bit lines (BLi, BLi+1) connected to one of the data storage circuits 310 through 312111 as shown in
An erase operation is conducted on a block by block basis as shown in
In an erase verify operation, the bit line (BLi) of the pair of bit lines (BLi, BLi+1) connected to one of the data storage circuits 310 through 312111 is subjected to verify read in a single operation and the outcome of the operation is stored in the first latch circuit LAT (A) as shown in FIG. 6. Then, a verify operation is conducted for bit line (BLi+1) and the logical sum of the outcome of this operation and that of the previous verify-read operation is stored in the first latch circuit LAT (A).
Program and Program Verify
(1st Page Program)
In a program operation, firstly an address is specified to select three pages as shown in FIG. 3. The program operation of the three pages can proceeds only in the sequence of the first page, the second page and the third page. Thus, the first page is firstly addressed.
Then, the data to be written (and read out) is stored in the first latch circuits LAT (A) in all the data storage circuits 310 through 312111. The program operation of the first page is exactly same as that of the first embodiment. Thus, if the data of the latch circuits LAT (A) is equal to "1", no data is written and the data of the memory cells remain to be equal to "0". If, on the other hand, the data of the latch circuits LAT (A) is equal to "0", a data is written and the data of the memory cells is shifted to be equal to "4".
(2nd Page Program)
As in the case of the first page program, the data to be written next (and read out) that is externally input is stored in the latch circuits LAT (A) of all the data storage circuits. Then, if the data of memory cells is equal to "0" as a result of the first page program and the externally input data is equal to "1", no data writing operation will be conducted. If the externally input data is equal to "0", a write operation is conducted for the cell and the data of the memory cells is made equal to "2". If the data of the memory cell is equal to "4" as a result of the first page program and the externally input data is equal to "1"', a write operation is conducted for the cell and the data of the memory cell is made equal to "6". If the externally input data is equal to "0", no write operation is conducted and the data of the memory cell has to remain to be equal to "4". However, a write operation is conducted there if the data of the latch circuit LAT (A) is equal to "0". Therefore, if the data of the memory cell is equal to "14", the data stored in the latch circuit LAT (A) has to be reversed from "1" to "0" or vice versa.
(Internal Input Data Conversion)
For this operation, it is necessary to check in advance if the data of the memory cell is made equal to "0" or "4" as a result of the first page program. To do this, potential "d" as shown in
The bit line is at the level same as the data of the latch circuit LAT (B). As signal VREG shown in
3rd Page Program
Exactly as in the case of the first page program and the second page program, the data to be written (and read out) next that is externally input is stored in the latch circuits LAT (A) of all the data storage circuits 310 through 312111. No write operation is conducted when the data of memory cells is equal to "0" as a result of the first page program and the second page program and the externally input data is equal to "1". A write operation is conducted and the data of the memory cell is made equal to "1" when the externally input data is equal to "0". A write operation is conducted and the data of the memory cell is made equal to "3" when the data of the memory cell is equal to "2" as a result of the first page program and the second page program and the externally input data is equal to "1". No write operation is conducted and the data of the memory cell has to remain to be equal to "2" when the externally input data is equal to "0".
No write operation is conducted when the data of memory cells is equal to "4" as a result of the first page program and the second page program and the externally input data is equal to "1". A write operation is conducted and the data of the memory cell is made equal to "5" when the externally input data is equal to "0". A write operation is conducted and the data of the memory cell is made equal to "7" when the data of the memory cell is equal to "6" as a result of the first page program and the second page program and the externally input data is equal to "1". No write operation is conducted and the data of the memory cell has to remain to be equal to "6" when the externally input data is equal to "0". However, a write operation is conducted there if the data of the latch circuit LAT (A) is equal to "0". Therefore, if the data of the memory cell is equal to "2" or "6", the data stored in the latch circuit LAT (A) has to be reversed from "1" to "0" or vice versa.
(Internal Input Data Conversion)
For this operation, it is necessary to check in advance the state of the data of the memory cell that arises as a result of the first page program and the second page program. To do this, potential "f" as shown in
The bit line is at the level same as the data of the latch circuit LAT (B). As signal VREG shown in
As a result, the latch circuit LAT (A) is brought up to the high level if the data of the memory cell is equal to "0" and data "1" is externally input as shown in
(Read 1st Page)
Then, potential Vread (4.5V) is supplied to unselected word lines and select line SG1 in the selected block to bring up signal BIAS of the data storage circuit shown in
Since the data and the threshold voltages of the memory cells are defined as shown in
Then, as the potential of the bit line is read by the first latch circuit LAT (A), the first latch circuit LAT (A) is brought down to the low level if the data of the memory cells is "0", "1", "2" or "3". On the other hand, the first latch circuit LAT (A) is brought up to the high level if the data of the memory cells is "4", "5", "6" or "7". However, when outputting the data stored in the first latch circuit LAT (A), signal Osac of clocked inverter circuit 61p shown in
(Read 2nd Page)
The read operation is repeated three times when reading the second page in the above described first embodiment. However, it is repeated only twice for reading the second page in the third embodiment to realize a high speed read operation for reading the second page in the third embodiment.
(Read 3rd Page)
Then, it is checked if the data of the memory cell is found between "0" and "4" or between "5" and "7". To do this, potential "e" of read operation as shown in
Then, it is checked if the data of the memory cell is found between "0" and "2" or between "3" and "7". To do this, potential "c" of read operation as shown in
Then, it is checked if the data of the memory cell is found to be equal to "0" or between "1" and "7". To do this, potential "a" of read operation as shown in
However, when outputting the data stored in the first latch circuit LAT (A), signal Osac, Osacb of clocked inverter circuit 61p shown in
The read operation is repeated seven times when reading the third page in the above described first embodiment. However, it is repeated only four times for reading the third page in the third embodiment to realize a high speed read operation for reading the third page in the third embodiment.
(Erase and Erase-verify)
The erase operation and the erase-verify operation of the third embodiment are identical with those of the first embodiment. As a result of an erase operation, the data of all the memory cells is made equal to "0" and data "1" is read out regardless if the first, second or third page is addressed.
Thus, in the above described third embodiment, when writing into the n-th page after writing into the (n-1)-th page, the externally input data is not directly written into the n-th page but the value obtained by carrying out an logical operation on the externally input data and the data already written into the inside is written. Once such a data is written, it is no longer necessary to shift the level of word lines by (2n-1) times for the operation of reading the n-th page and it is now possible to reduce the number of times of shifting the level to (2n/2) times. Therefore, high-speed read operation is realized.
The definitions illustrated in
For instance, when the definitions illustrated in
While an 8-valued data, or 3 bits data, is stored in a cell in each of the above described first through third embodiments, it is also possible to store a 16-valued data, or 4 bits data in a cell. If such is the case, a new threshold voltage has to be defined between two adjacently arranged threshold voltages defined for the third page for the program operation and the program/verify operation. However, the present invention provides the advantage that the data storage circuits and the operations for controlling the circuits can remain almost intact if the number of bits to be stored in a cell is increased.
The threshold voltage of memory cells is shifted by writing a data into the memory cells in any of the above described first through third embodiments. However, the present invention is by no means limited thereto. For instance, the threshold voltage of memory cells may be selected by erasing the data of the memory cells. The threshold voltage of a block of memory cells can be set to a predetermined level by collectively writing a same data into them. Then, the threshold voltage of each memory cell can be set to a desired level by erasing the threshold voltage of the memory cell according to the data to be written there. The above described embodiments are designed for optimal modes of carrying out the present invention to maximally exploit the advantages of the invention.
If the third embodiment of memory device according to the invention is used as read-only memory storing multi-valued data, the data storage circuits may comprise only a latch circuit LAT (A) because it is not necessary to use a latch circuit LAT (B).
While NAND type cells are used for the first and second embodiments, the present invention is by no means limited thereto and they may be replaced by NOR type or DINOR type cells.
Additional advantages and modifications will readily occur to those skilled in the art. Therefore, the invention in its broader aspects is not limited to the specific details and representative embodiments 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.
Tanaka, Tomoharu, Shibata, Noboru
Patent | Priority | Assignee | Title |
7394691, | Aug 12 2005 | Kioxia Corporation | Semiconductor memory device which prevents destruction of data |
Patent | Priority | Assignee | Title |
5892710, | Jan 21 1994 | Intel Corporation | Method and circuitry for storing discrete amounts of charge in a single memory element |
5949708, | Dec 31 1997 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | Integrated circuit charge coupling circuit |
6034892, | Jul 23 1996 | LG Semicon Co., Ltd. | Nonvolatile memory cell and method for programming and/or verifying the same |
6040992, | Dec 31 1997 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | Integrated circuit charge coupling circuit |
6055188, | Apr 30 1997 | Kabushiki Kaishi Toshiba | Nonvolatile semiconductor memory device having a data circuit for erasing and writing operations |
6058042, | Dec 26 1997 | Sony Corporation | Semiconductor nonvolatile memory device and method of data programming the same |
6122193, | Jun 01 1998 | TOSHIBA MEMORY CORPORATION | Non-volatile semiconductor memory capable of storing 1-bit data or multi-bit data |
6141243, | Nov 12 1996 | Fraunhofer-Gesellschaft zur Forderung der Angewandten Forschung E.V. | Sensor element |
6178115, | Dec 25 1998 | TOSHIBA MEMORY CORPORATION | Semiconductor memory device and storage method thereof |
EP797212, | |||
EP908894, | |||
WO9748098, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Sep 24 2002 | Kabushiki Kaisha Toshiba | (assignment on the face of the patent) | / | |||
Jul 06 2017 | Kabushiki Kaisha Toshiba | TOSHIBA MEMORY CORPORATION | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 043709 | /0035 |
Date | Maintenance Fee Events |
Sep 29 2006 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Sep 22 2010 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Sep 25 2014 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. |
Date | Maintenance Schedule |
Apr 22 2006 | 4 years fee payment window open |
Oct 22 2006 | 6 months grace period start (w surcharge) |
Apr 22 2007 | patent expiry (for year 4) |
Apr 22 2009 | 2 years to revive unintentionally abandoned end. (for year 4) |
Apr 22 2010 | 8 years fee payment window open |
Oct 22 2010 | 6 months grace period start (w surcharge) |
Apr 22 2011 | patent expiry (for year 8) |
Apr 22 2013 | 2 years to revive unintentionally abandoned end. (for year 8) |
Apr 22 2014 | 12 years fee payment window open |
Oct 22 2014 | 6 months grace period start (w surcharge) |
Apr 22 2015 | patent expiry (for year 12) |
Apr 22 2017 | 2 years to revive unintentionally abandoned end. (for year 12) |