1. Field of the Invention
This invention relates to, for example, a NAND flash memory, and more particularly to a semiconductor memory device capable of storing multilevel data in a single memory cell.
2. Description of the Related Art
In a NAND flash memory, all of or half of a plurality of cells arranged in the column direction are connected in series to constitute a NAND cell. The drain side of each NAND cell is connected via a select gate to the corresponding bit line. Each bit line is connected to a write and a read latch circuit. Data is simultaneously written into or read from all of or half of the cells arranged in the row direction. With the recent trend toward larger memory capacity, a memory which stores 2 bits or more of multilevel data into a single cell has been developed (for example, Jpn. Pat. Appln. KOKAI Publication No. 2004-192789).
In a multilevel memory, writing data into an adjacent cell causing a problem: the threshold voltage of the cell in which data has already been written rises as a result of the coupling between the floating gates (FG-FG) of the two cells. Accordingly, the following method has been proposed: for example, in the case of a cell which stores 3 bits using 8 levels, first, 3 bits of data are written to a lower verify level than the original verify level, and then the cells adjacent to this cell are written into. Thereafter, the preceding cell is written into to the original verify level. However, the writing of data into the preceding cell cannot be completed unless data to be written into the adjacent cells (or data in the adjacent cells) has been determined. Therefore, all the cells in the NAND cell have to be written into. Accordingly, a semiconductor memory device capable of suppressing a fluctuation in the threshold level of a cell already written into by writing data into adjacent cells has been desired.
According to a first aspect of the invention, there is provided a semiconductor memory device comprising: a memory cell array in which a plurality of memory cells are arranged in a matrix, each of said plurality of memory cells storing one of a plurality of threshold levels; and a control circuit which, when writing one of said plurality of threshold levels into a first memory cell of the memory cell array, writes a threshold level lower than an original threshold level, and which, when not writing a second memory cell adjacent to the first memory cell consecutively, writes the original threshold level into the first memory cell.
According to a second aspect of the invention, there is provided a semiconductor memory device comprising: a memory cell array in which a plurality of memory cells are arranged in a matrix, each of said plurality of memory cells storing one of a plurality of threshold levels; and a control circuit which, when writing one of said plurality of threshold levels into a first memory cell of the memory cell array and further writing a second memory cell adjacent to the first memory cell consecutively, writes a threshold level lower than an original threshold level and which, when not writing the second memory cell adjacent to the first memory cell consecutively, writes the first memory cell at a decreased write speed.
According to a third aspect of the invention, there is provided a semiconductor memory device comprising: a memory cell array in which a plurality of memory cells are arranged in a matrix, each of said plurality of memory cells storing one of a plurality of threshold levels; and a control circuit which, when writing one of said plurality of threshold levels into a first memory cell of the memory cell array, writes a threshold level lower than an original threshold level and which, when not writing a second memory cell adjacent to the first memory cell consecutively, keeps the first memory cell at the lower threshold level and, when writing one of said plurality of threshold levels into the second memory cell, reads the threshold level from the first memory cell and, after writing a specific threshold level into the second memory cell, writes the original threshold level into the first memory cell on the basis of the result of the reading.
According to a fourth aspect of the invention, there is provided a semiconductor memory device comprising: a plurality of memory cells connected in series each of which stores one of a plurality of threshold levels; a first select gate connected to one end of said plurality of memory cells connected in series; a second select gate connected to the other end of said plurality of memory cells connected in series; and at least one dummy cell connected between at least one of the first and second select gates and a memory cell adjacent to at least one of the first and second select gates.
Hereinafter, referring to the accompanying drawings, embodiments of the invention will be explained.
A memory cell array 1 includes a plurality of bit lines, a plurality of word lines, and a common source line. In the memory cell array 1, electrically rewritable memory cells made up of, for example, EEPROM cells are arranged in a matrix. A bit line control circuit 2 for controlling bit lines and a word line control circuit 6 are connected to the memory cell array 1.
The bit line control circuit 2 reads the data in a memory cell of the memory cell array 1 via a bit line, detects the state of a memory cell of the memory cell array 1 via a bit line, and writes data into a memory cell of the memory cell array 1 by applying a write control voltage to the memory cell via a bit line. A column decoder 3 and a data input/output buffer 4 are connected to the bit line control circuit 2. A data storage circuit in the bit line control circuit 2 is selected by the column decoder 3. The data in the memory cell read into the data storage circuit is output via the data input/output buffer 4 at a data input/output terminal 5 to the outside. The data input/output terminal is connected to a host 11 outside the memory chip. The host 11, which is composed of, for example, a microcomputer, receives the data output from the data input/output terminal 5. The host 11 outputs various commands for controlling the operation of the NAND flash memory, addresses ADD, and data DT. The write data input to the input/output terminal 5 from the host 11 is supplied via the data input/output buffer 4 to the data storage circuit selected by the column decoder 3. The commands and addresses are supplied to a control signal and control voltage generator circuit 7.
The word line control circuit 6 is connected to the memory cell array 1. The word line control circuit 6 selects a word line in the memory cell array 1 and applies to the selected word line a voltage necessary for a read, write, or erase operation.
The memory cell array 1, bit line control circuit 2, column decoder 3, data input/output buffer 4, and word line control circuit 6 are connected to and controlled by the control signal and control voltage generator circuit 7. The control signal and control voltage generator circuit 7 is connected to a control signal input terminal 8 and is controlled by control signals ALE (Address Latch Enable), CLE (Command Latch Enable), and WE (Write Enable) input via the control signal input terminal 8 from the host 11.
The bit line control circuit 2, column decoder 3, word line control circuit 6, and control signal and control voltage generator circuit 7 constitute a write circuit and a read circuit.
The control signal and control voltage generator circuit 7 has a dynamic data cache (DDC) control circuit 7-1. The DDC control circuit 7-1 generates a control signal for controlling the refresh operation of a plurality of DRAMs acting as a dynamic latch circuit included in the data storage circuit described later.
The bit line control circuit 2 has a plurality of data storage circuits 10. Pairs of bit lines (BL0e, BL0o), (BL1e, BL1o), . . . , (BLie, BLio), (BL8ke, BL8ko) are connected to the individual data storage circuits 10.
The memory cell array 1 includes a plurality of blocks as shown by a broken line. Each block is composed of a plurality of NAND cells. In the memory cell array 1, data is erased in, for example, blocks. In addition, an erase operation is carried out simultaneously on the two bit lines connected to the data storage circuit 10.
A plurality of memory cells (or the memory cells enclosed by a broken line) arranged for every other bit line and connected to a single word line constitute one sector constitute a sector. Data is written or read in sectors. Specifically, half of the memory cells arranged in the row direction are connected to the corresponding bit line. Therefore, data is simultaneously written into or read from half of the memory cells arranged in the row direction.
In a read operation, a program verify operation, and a program operation, one of the two bit lines (BLie, BLio) connected to the data storage circuit 10 is selected according to the address signal (YA0, YA1, . . . , YAi, . . . , YA8k) supplied from the outside. Furthermore, one word line is selected according to an external address and a third page indicated by a broken line is selected. The changing of the third page is done using an address.
Although the configuration of
The SDC is composed of clocked inverter circuits 61a, 61b constituting a static latch circuit and transistors 61c, 61d. The transistor 61c is connected between the input end of the clocked inverter circuit 61a and the input end of the clocked inverter circuit 61b. A signal EQ2 is supplied to the gate of the transistor 61c. The transistor 61d is connected between the output end of the clocked inverter circuit 61a and the ground. A signal PRST is supplied to the gate of the transistor 61d. Node N2a of the SDC is connected via a column select transistor 61e to an input/output data line IOn. Node N2b of the SDC is connected via a column select transistor 61f to an input/output data line IO. A column select signal CSLi is supplied to the gates of the transistors 61e, 61f. Node N2a of the SDC is connected to node Nla of the PDC via transistors 61g, 61h. A signal BLC2 is supplied to the gate of the transistor 61g. A signal BLC1 is supplied to the gate of the transistor 61h.
The PDC is composed of clocked inverter circuits 61i, 61j constituting a static latch circuit and a transistor 61k. The transistor 61k is connected between the input end of the clocked inverter circuit 61i and the input end of the clocked inverter circuit 61j. A signal EQ1 is supplied to the gate of the transistor 61k. Node N1b of the PDC is connected to the gate of the transistor 61l. One end of the current path of the transistor 61l is connected to the ground via a transistor 61m. A signal CHK1 is supplied to the gate of the transistor 61m. The other end of the current path of the transistor 61l is connected to one end of the current path of transistors 61n, 61o constituting a transfer gate. A signal CHK2n is supplied to the gate of the transistor 61n. The gate of the transistor 61o is connected to node N3. The other end of the current path of the transistors 61n, 61o is connected to a signal line COMi. The signal line COMi is connected equally to all of the data storage circuits 10. On the basis of the level of the signal line COMi, whether all of the data storage circuits 10 have been verified can be determined. Specifically, as described later, if the verification has been completed, node N1b of the PDC goes low (or node N1a goes high). In this state, when the signals CHK1, CHK2n are made high, if the verification has been completed, the signal line COMi goes high.
Furthermore, the TDC is composed of, for example, a MOS capacitor 61p. One end of the capacitor 61p is connected to a junction node N3 of the transistors 61g, 61h. A signal BOOST described later is supplied to the other end of the capacitor 61p. The DDCA, DDCB, and DDCC are connected to the junction node N3 via transistors 61qA to 61qC. Signals REGA to REGC are supplied to the gates of the transistors 61qA to 61qC.
The DDCA, DDCB, and DDCC constituting a dynamic latch circuit are composed of transistors 61rA to 61rC, respectively. Signal VPRE is supplied to one end of the current path of each of the transistors 61rA to 61rC. The other ends of the transistors 61rA to 61rC are connected to the current paths of the transistors 61qA to 61qC, respectively. The gates of the transistors 61rA to 61rC are connected to node N1a of the PDC via transistors 61sA to 61sC. Signals DTGA to DTGC are supplied to the gates of the transistors 61sA to 61sC, respectively.
Furthermore, one end of the current path of each of transistors 61t, 61u is connected to the junction node N3. A signal VPRE is supplied to the other end of the current path of the transistor 61u. A signal BLPRE is supplied to the gate of the transistor 61u. A signal BLCLAMP is supplied to the gate of the transistor 61t. The other end of the current path of the transistor 61t is connected to one end of bit line BLo via a transistor 61v and to one end of bit line BLe via a transistor 61w. One end of bit line BLo is connected to one end of the current path of a transistor 61x. A signal BIASo is supplied to the gate of the transistor 61x. One end of bit line BLe is connected to one end of the current path of a transistor 61y. A signal BIASe is supplied to the gate of the transistor 61y. A signal BLCRL is supplied to the other ends of the current paths of these transistors 61x, 61y. The transistors 61x, 61y are turned on according to signals BIASo, BIASe so as to be complementary to the transistors 61v, 61w, thereby supplying the potential of the signal BLCRL to the unselected bit lines.
Between node N3 and the ground, for example, a MOS capacitor 61z is connected. The capacitor 61z adjusts the potential at node N3 so as to prevent the potential at node N3 from rising too much by coupling in raising the voltage of the capacitor 61p of the TDC described later by the signal BOOST. Hereinafter, suppose data in the PDC is the potential at node N1a, data in the SDC is the potential at node N2a, data in the TDC is the potential at node N3, and data in the DDCA to DDCC are the potentials of the gates of the transistors 61rA to 61rC.
The individual signals and voltages are generated by the control signal and control voltage generator circuit 7 shown in
The memory stores, 3 bits of data in a single cell using 8 threshold voltages. The switching between the 3 bits is controlled using addresses (or a first page, a second page, and a third page).
In plane 0, blocks 0 to 2047 are arranged. In plane 1, blocks 2048 to 4095 are arranged. Since a plurality of blocks are arranged in each of plane 1 and plane 0 in this way, either plane is selected by I/O 3 (A36) in the fifth cycle. Moreover, a read operation, a program operation, or an erase operation can be carried out by selecting an arbitrary block in each plane, a total of two blocks, at the same time.
With the above configuration, an operation will be explained.
(Program and Program Verify)
(Program Sequence)
First, in a 0-th write operation [0], 3 bits of data (7-level data) on a lower page, an upper page, and a higher page (page addresses: 0, 1, 2) are written into the cell with word line WL0 and bit line BLe by a first stage write operation. As a result, the threshold voltage distribution is as shown in
Next, in a first write operation [1], 3 bits of data (7-level data) on the lower page, the upper page, and the higher page (page addresses: 3, 4, 5) are written into the cell with word line WL0 and bit line BLo by the first stage write operation.
Next, in a second write operation [2], 3 bits of data (7-level data) on the lower page, the upper page, and the higher page (page addresses: 6, 7, 8) are written into the cell with word line WL1 and bit line BLe by the first stage write operation.
Next, in a third write operation [3], 3 bits of data (7-level data) on the lower page, the upper page, and the higher page (page addresses: 9, 10, 11) are written into the cell with word line WL1 and bit line BLo by the first stage write operation.
As a result, for example, the distribution of threshold voltages of the cell with word line WL0 and bit line BLe expands as shown by the dotted lines in
Next, in a fourth write operation [4], 3 bits of data (8-level data) on the lower page, the upper page, and the higher page (page addresses: 0, 1, 2) are written into the cell with word line WL0 and bit line BLo by the second stage write operation. As a result, the threshold voltage distribution is as shown by solid lines in
Next, in a fifth write operation [5], 3 bits of data (8-level data) on the lower page, the upper page, and the higher page (page addresses: 3, 4, 5) are written into the cell with word line WL0 and bit line BLo by the second stage write operation.
Next, in a sixth write operation [6], 3 bits of data (7-level data) on the lower page, the upper page, and the higher page (page addresses: 12, 13, 14) are written into the cell with word line WL2 and bit line BLe by the first stage write operation.
Next, in a seventh write operation [7], 3 bits of data (7-level data) on the lower page, the upper page, and the higher page (page addresses: 12, 13, 14) are written into the cell with word line WL2 and bit line BLo by the first stage write operation.
Next, in an eighth write operation [8], 3 bits of data (8-level data) on the lower page, the upper page, and the higher page (page addresses: 6, 7, 8) are written into the cell with word line WL1 and bit line BLe by the second stage write operation.
Next, in a ninth write operation [9], 3 bits of data (8-level data) on the lower page, the upper page, and the higher page (page addresses: 9, 10, 11) are written into the cell with word line WL1 and bit line BLo by the second stage write operation.
As a result, for example, the distribution of threshold voltages of the cell with word line WL0 and bit line BLe expands as shown by the broken lines in
To overcome this problem, the first embodiment uses the following write operation to prevent the threshold levels from fluctuating as a result of the operation of writing data into adjacent cells.
In the case of a write sequence shown in
Specifically, first, it is determined whether the data sent from the host 11 is the last one or not (S1). For example, it is determined whether the data sent from the host 11 is present. As a result, if the sent data is present and is not the last data, the cell to be written into is written into to a level lower than the original threshold level as described above. For example, the page addresses 3, 4, 5 in writing [1] do not hold the last data, a threshold level lower than the original threshold level is written into the page addresses 3, 4, 5 of the memory cell connected word line WL1 shown in writing [1] (S2). That is, in this case, a program verify operation is carried out using a verify level lower than the original verify level. Thereafter, a specific threshold level is written into the adjacent cells. Specifically, the original verify level is written into the cell written into earlier than the cell to be written into, that is, the page addresses 0, 1, 2 of the memory cell connected to word line WL0 shown in writing [2] (S3). Then, a lower threshold level than the original threshold level is written into the cell written into later than the cell to be written into, that is, the page addresses 6, 7, 8 of the memory cell connected to word line WL2 shown in writing [3] (S4).
Thereafter, the original threshold level is written into the cell to be written into (S5). That is, the original threshold level is written into the page addresses 3, 4, 5 of the memory cell connected to word line WL1 shown in writing [4]. Such an operation is carried out according to the data sent from the host 11.
On the other hand, for example, if the data in the page addresses 3, 4, 5 in writing [1] are the last data, the operation goes as follows. In step S1, if it has been determined that the data in the page addresses 6, 7, 8 in writing [3] following the page addresses 3, 4, 5 in writing [1] have not been sent from the host 11, control is passed to step S6. In step S6, a lower threshold level than the original threshold level is written into the page addresses 3, 4, 5 of the memory cell connected to word line WL1 shown in writing [1]. That is, in this case, a program verify operation is carried out using a verify level lower than the original verify level. Thereafter, a specific threshold level is written into the adjacent cells (S7). Specifically, on the basis of the data in the page addresses 0, 1, 2 already sent, the original verify level is written into the memory cell connected to word line WL0 shown in writing [2], that is, the page addresses 0, 1, 2 of the cell written into earlier than the cell to be written into.
Thereafter, the original threshold level is written into the cell to be written into (S8). That is, on the basis of the data in the page addresses 3, 4, 5 received last, the original threshold level is written into the page addresses 3, 4, 5 of the memory cell connected to word line WL1 as shown in writing [4]. Such an operation is carried out according to the data sent from the host 11.
Thereafter, as time advances and when writing is done again, the cell adjacent to the memory cell last written into is not written into and a cell separate from the memory cell last written into is written into. Specifically, as described above, if the page addresses 3, 4, 5 were written into last in writing [1], the host 11 performs control in such a manner that the page addresses 6, 7, 8 in writing [3] are not written into and writing is done, starting from, for example, the page addresses 9, 10, 11 in writing [5].
Specifically, when the data in the page addresses 9, 10, 11 in writing [5] are sent from the host 11 after the restart of writing, control is passed from step S1 to step S2 to step S5, where the same writing operation as described above is carried out. Therefore, the threshold voltage of the data in the cells at the page addresses 0, 1, 2 and the page addresses 3, 4, 5 will not rise through the coupling between the floating gates.
While in the above explanation, data has been written into the cell located in writing [5] in place of writing [3], the invention is not limited to this. For instance, data may be written into the cell located in writing [7] (not shown) adjacent to writing [5] in the direction of word line.
According to the first embodiment, when the write data is the last data, the original threshold level is written into the memory cell. Therefore, since the memory cell written into last has been written into before the data for the adjacent cells reaches, a fluctuation in the threshold level due to time passage can be prevented.
Furthermore, when writing is started again, the cell adjacent to the memory cell last written into in the preceding write operation is not written into and data is written into a cell separate from the memory cell last written into. Therefore, it is possible to prevent a fluctuation in the threshold level of the cell written into last in the preceding write operation.
While the memory cell array with the configuration of
Moreover, the adjacent cells are not restricted to the cells adjoining a specific memory cell in the direction of word line or bit line. For example, in
For example, in the write sequence shown in
On the other hand, for example, if the page addresses 3, 4, 5 are the last ones, control is passed from step S11 to step S12. In this case, the host 11 outputs a specific command following the page addresses 3, 4, 5. Receiving the command (S12), the control signal and control voltage generator circuit 7 lowers, for example, the write speed for the cell to be written into (S13). Specifically, the control signal and control voltage generator circuit 7 shortens, for example, the applying time of the program voltage supplied to the word line or sets an increment in the program voltage smaller. Lowering the write speed enables the distribution of each threshold level to be set narrower than the original threshold level distribution as shown in
As described above, when each threshold level distribution is set narrower, even if the threshold level of the cell previously written into becomes wider by the coupling between the floating gates of the adjacent cells as a result of the adjacent cells being written into in the next writing, the interval between the individual levels can be secured as shown in
In the second embodiment, the host 11 supplies a specific command following the last write data. According to the command, the threshold level of the cell written into last is set narrower than the original threshold level distribution. Therefore, even when data is written into an adjacent cell, it is possible to prevent the threshold level distribution of the cell already written into from spreading too much and therefore to secure a margin in reading.
In the case of
For example, in the write sequence shown in
Thereafter, when writing is started again and the host 11 supplies a write command together with the write data for adjacent cells, control is passed from step S21 to step S23. In step S23, for example, the host 11 supplies the data in the page addresses 6, 7, 8 shown in writing [3] for the preceding writing [1], the data in the cell written into at the lower level than the original threshold level in writing [1] is read out before the writing of the data and is then stored in the data storage circuit 10 shown in
In the third embodiment, when the data written into the cell is the last data, the lower threshold level than the original one is written into the cell. In the next writing, when data is written into an adjacent cell, the already written data is saved to the data storage circuit 10. After the lower threshold level than the original one is written into the adjacent cell, the threshold level of the cell previously written into is set to the original threshold level on the basis of the data saved to the data storage circuit 10. Therefore, when data is written into the adjacent cell after writing is started, it is possible to prevent the threshold level of the memory cell previously written into from getting wider by the coupling.
While in the third embodiment, the last written data is saved to the data storage circuit 10 in the next writing, the invention is not limited to this. For instance, the data may be saved to, for example, the host 11.
In the first to third embodiments, the case where 8-level data is written in the first stage of writing has been explained. This invention is not limited to this.
While in the first to third embodiments, the explanation has been given using
In a third modification of the first to third embodiments, the distribution width of the threshold level shown in
The first and second modifications are effective when the coupling between the floating gates is large.
Various operations applied to the first to third embodiments will be explained below.
(Address Input and Data Input)
It is also possible to change the input address and the location of data as shown in
(Data Transfer Command)
When the host 11 supplies a data transfer command (1Ah), the data in the SDC in the data storage circuit 10 in the selected plane is transferred to the PDC and further to the DDC. Since the DDC is a capacitance, a refresh operation is needed. Therefore, after the transfer command (1Ah) has been input, when the transfer of data to the DDC has been completed, the chip changes from the busy state to the ready state to wait for the next data to be input. In the chip, a refresh operation is repeated.
(Write Sequence, Data Load, Program Set)
Thereafter, write command 10h or write a cach-function-added command 15h is input (S35, S36), bringing the chip into the busy state.
In the chip, when an internal data load is carried out after the data in the SDC is transferred to LDDCQ (S37), the data is loaded from the memory cell. The result is transferred to LDDCQ and LDDC1.
Thereafter, data cache operation and data cache are defined (S38) (
In addition to the original verify level, a lower verify level is set. Writing after the lower verify level has been exceeded is made lower, which enables the writing distribution to be made narrower. Whether the lower verify level has been exceeded is stored in LDDCQ. If the lower verify level has not been exceeded, 0 is set in LDDCQ (LDDCQ=0). If the lower verify level has been exceeded, 1 is set in LDDCQ (LDDCQ=1).
When 8-level data is written, 3 bits are needed to distinguish 8 levels. In this case, SDC, LDDC1, and LDDC0 are used. When 4-level data is written, 2 bits are needed to distinguish 4 levels. In this case, LDDC1 and LDDC0 are used. When 2-level data is written, 1 bit is needed to distinguish 2 levels. In this case, LDDC0 is used. These writing levels and the data set in the data caches are shown in
In an REASB (Revised Erased Area Self Boost) write operation, the selected word line is set at the program voltage Vpgm (24 V). The word line adjacent to the selected word line on the source side is set at Vpass or an intermediate potential. The potential of a word line adjacent to the word line is set at the ground potential Vss, preventing erroneous writing. However, when the threshold voltage of the erased cell is too low, the cell cannot be turned off.
In the course of writing data, the writing of data to a lower threshold value is completed earlier than the writing of data to a higher threshold value. Therefore, in a case where the cache-function-added write command 15h has been input, when the writing of data to level 0 to level 3 has been completed in writing 8 levels, the data in the SDC becomes unnecessary. Therefore, the ready state is output outside the chip and the next write data is input. Thereafter, command 1Ah/10h/15h is input, thereby bringing the chip into the busy state.
When the writing of data to level 4 to level 5 has been completed, the data in LDDC1 becomes unnecessary. Therefore, after the data in the SDC is transferred to LDDC1, the ready state is output outside the chip. Then, the next write data is input to the SDC. Thereafter, command 1Ah/10h/15h is input, thereby bringing the chip into the busy state.
Furthermore, when the writing of data to level 6 has been completed, the data in LDDC0 becomes unnecessary. Therefore, after the data in the SDC is transferred to LDDC0, the ready state is output outside the chip. Then, the next write data is input to the SDC. Thereafter, command 1Ah/10h/15h is input, thereby bringing the chip into the busy state. Then, the chip is brought into the busy state by the write command 15h or 10h. After the preceding page has been written into, the operation of writing data into the next page is started.
When 4 levels are written, the SDC is not used from the beginning. Therefore, after the data cache is operated, the ready state is output outside the chip and the next write data is input. Thereafter, command 1Ah/10h/15h is input, thereby bringing the chip into the busy state.
When the writing of data to level 0 to level 1 has been completed, the data in LDDC1 becomes unnecessary. Therefore, after the data in the SDC is transferred to LDDC1, the ready state is output outside the chip. Then, the next write data is input to the SDC. Thereafter, command 1Ah/10h/15h is input, thereby bringing the chip into the busy state.
Furthermore, when the writing of data to level 2 has been completed, the data in LDDC0 becomes unnecessary. Therefore, after the data in the SDC is transferred to LDDC0, the ready state is output outside the chip. Then, the next write data is input to the SDC. Thereafter, the chip is brought into the busy state by the write command 15h or 10h. After the preceding page has been written into, the operation of writing data into the next page is started.
When 2 levels are written, the SDC is not used from the beginning. Therefore, after the data cache is operated, the ready state is output outside the chip. Then, the next write data is input. Thereafter, command 1Ah/10h/15h is input, thereby bringing the chip into the busy state.
In writing two levels, LDDC1 is not used. Therefore, after the data in the SDC is transferred to LDDC0, the ready state is output outside the chip. Then, the next write data is input to the SDC. Thereafter, command 1Ah, 10h, or 15h is input, thereby bringing the chip into the busy state.
In writing two levels, LDDC0 is not used, either. Therefore, after the data in the SDC is transferred to LDDC0, the ready state is output outside the chip. Then, the next write data is input to the SDC. Thereafter, command 1Ah, 10h, or 15h is input, thereby bringing the chip into the busy state. Then, the chip is brought into the busy state by the write command 1Ah, 10h, or 15h. After the preceding page has been written into, the operation of writing data into the next page is started.
By doing this, the present circuit can be used even in a case where transfer command 1Ah appears three times consecutively, that is, where the next write data is for 3 pages and 8 levels. However, for example, when the next write data is for 2 levels, the data on the first page is input and then write command 10h or 15h is input.
(Program Setting)
After the definition of the data caches and the operation of the data caches (S38, S39), a program operation is carried out (S40).
In
Here, Vdd is applied to the select line SGS (shown in
(Program and Program Verify Read)
A program operation and a verify operation (S41) shown in
After the verify operation has passed at each level, the PDC changes from the low level to the high level, preventing writing from being done in the next program.
Although the program is executed a plurality of times, the cells to be written into at the high level have not been written into yet at the beginning of the program loop. A verify operation is carried out sequentially only at level 0 at first, then only at level 0 and level 1, and then only level 0, level 1, and level 2. Almost at the end of the program loop, the cells at the low level have been written into. Therefore, a verify operation is carried out only at level 5, level 6, and level 7 at first, then only at level 6 and level 7, and then only level 7. In this case, for example, when a verification operation is carried out at only level 6 and level 7, the waveform at level 6 differs from that at level 6 when verifying has been done consecutively at level 5, level 6, and level 7. Therefore, when verifying is done only at level 6 and level 7, verifying is done at level 5, level 6, and level 7. In this case, verifying at level 5 is a dummy. In the verify operation at level 5, the contents of the data cache are not changed.
(Program Voltage Step-Up)
In the verify operation, if it has been determined that writing is insufficient, the program voltage Vpgm is raised a little (S42). Thereafter, the program operation and program verify operation are repeated again.
(Program)
When the PDC is at the low level, the write operation is carried out again. The program operation and verify operation are repeated until the PDCs in all the data storage circuits 10 have gone to the high level (S40). That is, while the program operation is being carried out, a check is made to see if all the PDCs are at the high level.
(Erase Operation)
An erase operation is carried out in blocks shown by a broken line in
In an EASB (Erase Area Self Boost) writing method, the threshold level of a cell to be erased from has to be made shallow.
First, referring to
For this reason, in the erase sequence, the threshold level of the erased cell is made shallower after the erasure. Alternatively, the threshold level is made shallower in the program sequence shown in
Furthermore, in the write sequence shown in
(Read Operation)
As shown in
As described above, as a measure to prevent the threshold distribution from becoming higher than the verify level, the interval between the individual threshold levels can be made sufficient by carrying out a verify operation at every other level as shown in
Moreover, as shown in
In addition, a correction value may be added to the verify level in advance. For example, when the threshold levels are written as shown by the solid lines in
Furthermore, in a program verify operation shown in
As shown in
To avoid this problem, for example, in the case of 8 levels, although a single cell stores 3 bits, 43 cells are connected in series instead of 32 cells connected in series and, only when 4-level (2 bits of) data is stored only in the cell connected to word line WL0. Then, a single NAND cell can store 2 bits+3 bits×42=128 bits, which can be expressed by the nth power of 2. Moreover, since the cell connected to word line WL0 stores 4 levels, not 8 levels, and need not be written to a high threshold level. Therefore, the high program voltage Vpgm is not needed, which can suppress a GIDL problem.
Furthermore, in a memory which stores n levels, only the cell connected to word line WL0 or only a word line whose probability of the occurrence of erroneous writing is high is caused to store k levels (k<n), which can suppress a GIDL problem. Moreover, the cell connected to word line WL31 may be configured similarly.
In addition, as shown in
According to the fourth embodiment, it is possible to prevent the occurrence of GIDL in writing data “1” into word line WL0.
While in the embodiment, the dummy cell has been provided between word line WL0 and select line SGS, the invention is not limited to this.
While in the fourth embodiment, a dummy cell has been added to prevent word line WL0 or WL31 from being written into erroneously, erroneous writing can be prevented without adding a dummy cell. The distance between word line WL0 and select line SGS and the distance between word line WL31 and select line SGD are made greater than the distance between other word lines.
In addition, for example, in the first modification, the verify levels only for word line WL0 are generally lowered, an increment DVpgm in the program voltage is made finer, each change in the threshold value is made finer, and the threshold distribution width is made narrower. This may lengthen the program time of the cell connected to word line WL0. However, since there is no high verify level for word line WL0, the program voltage Vpgm can be made lower, which enables erroneous writing to be alleviated.
In the second modification, the verify levels for word line WL0 and word line WL1 are generally lowered, an increment DVpgm in the program voltage in writing on word line WL1 is made finer, each change in the threshold value is made finer, and the threshold distribution width is made narrower. In this way, data is written into the cell connected to word line WL1, making smaller the shift of the threshold value of the cell connected to word line WL1, which makes smaller a fluctuation in the threshold level of the cell connected to word line WL0 caused by coupling. Accordingly, the verify levels for word line WL0 are generally lowered, eliminating a high verify level for word line WL0, which makes it possible to lower the program voltage Vpgm and alleviate erroneous writing. Furthermore, the first modification may be combined with the second modification.
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.
Number | Date | Country | Kind |
---|---|---|---|
2006-111177 | Apr 2006 | JP | national |
This application is a continuation of and claims the benefit of priority under 35 U.S.C. §120 from U.S. application Ser. No. 11/693,213, filed Mar. 29, 2007, and claims the benefit of priority under 35 U.S.C. §119 from Japanese Patent Application No. 2006-111177, filed Apr. 13, 2006, the entire contents of which are incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
Parent | 11693213 | Mar 2007 | US |
Child | 12340290 | US |