JP2005243205A - Semiconductor memory device - Google Patents

Semiconductor memory device Download PDF

Info

Publication number
JP2005243205A
JP2005243205A JP2004160165A JP2004160165A JP2005243205A JP 2005243205 A JP2005243205 A JP 2005243205A JP 2004160165 A JP2004160165 A JP 2004160165A JP 2004160165 A JP2004160165 A JP 2004160165A JP 2005243205 A JP2005243205 A JP 2005243205A
Authority
JP
Japan
Prior art keywords
threshold voltage
data
memory cell
potential
written
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
JP2004160165A
Other languages
Japanese (ja)
Other versions
JP4170952B2 (en
Inventor
Noboru Shibata
昇 柴田
Tomoharu Tanaka
智晴 田中
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Toshiba Corp
Original Assignee
Toshiba Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority to JP2004160165A priority Critical patent/JP4170952B2/en
Application filed by Toshiba Corp filed Critical Toshiba Corp
Priority to US10/988,592 priority patent/US7245528B2/en
Priority to KR20040107347A priority patent/KR100688369B1/en
Publication of JP2005243205A publication Critical patent/JP2005243205A/en
Priority to US11/759,627 priority patent/US7376009B2/en
Priority to US12/117,767 priority patent/US7738302B2/en
Application granted granted Critical
Publication of JP4170952B2 publication Critical patent/JP4170952B2/en
Priority to US12/775,571 priority patent/US8154930B2/en
Priority to US13/413,779 priority patent/US8385130B2/en
Priority to US13/754,057 priority patent/US8542538B2/en
Priority to US14/017,611 priority patent/US9142299B2/en
Priority to US14/825,858 priority patent/US9390802B2/en
Priority to US15/175,806 priority patent/US9627048B2/en
Priority to US15/453,302 priority patent/US9858992B2/en
Priority to US15/832,557 priority patent/US10096358B2/en
Priority to US16/125,601 priority patent/US10431297B2/en
Priority to US16/539,205 priority patent/US10699781B2/en
Priority to US16/857,611 priority patent/US10878895B2/en
Priority to US17/101,431 priority patent/US11309019B2/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C16/00Erasable programmable read-only memories
    • G11C16/02Erasable programmable read-only memories electrically programmable
    • G11C16/04Erasable programmable read-only memories electrically programmable using variable threshold transistors, e.g. FAMOS
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C11/00Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor
    • G11C11/56Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor using storage elements with more than two stable states represented by steps, e.g. of voltage, current, phase, frequency
    • G11C11/5621Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor using storage elements with more than two stable states represented by steps, e.g. of voltage, current, phase, frequency using charge storage in a floating gate
    • G11C11/5628Programming or writing circuits; Data input circuits
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C11/00Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor
    • G11C11/56Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor using storage elements with more than two stable states represented by steps, e.g. of voltage, current, phase, frequency
    • G11C11/5621Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor using storage elements with more than two stable states represented by steps, e.g. of voltage, current, phase, frequency using charge storage in a floating gate
    • G11C11/5642Sensing or reading circuits; Data output circuits
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C16/00Erasable programmable read-only memories
    • G11C16/02Erasable programmable read-only memories electrically programmable
    • G11C16/04Erasable programmable read-only memories electrically programmable using variable threshold transistors, e.g. FAMOS
    • G11C16/0483Erasable programmable read-only memories electrically programmable using variable threshold transistors, e.g. FAMOS comprising cells having several storage transistors connected in series
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C16/00Erasable programmable read-only memories
    • G11C16/02Erasable programmable read-only memories electrically programmable
    • G11C16/06Auxiliary circuits, e.g. for writing into memory
    • G11C16/10Programming or data input circuits
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C16/00Erasable programmable read-only memories
    • G11C16/02Erasable programmable read-only memories electrically programmable
    • G11C16/06Auxiliary circuits, e.g. for writing into memory
    • G11C16/10Programming or data input circuits
    • G11C16/12Programming voltage switching circuits
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C16/00Erasable programmable read-only memories
    • G11C16/02Erasable programmable read-only memories electrically programmable
    • G11C16/06Auxiliary circuits, e.g. for writing into memory
    • G11C16/34Determination of programming status, e.g. threshold voltage, overprogramming or underprogramming, retention
    • G11C16/3436Arrangements for verifying correct programming or erasure
    • G11C16/3454Arrangements for verifying correct programming or for detecting overprogrammed cells
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C16/00Erasable programmable read-only memories
    • G11C16/02Erasable programmable read-only memories electrically programmable
    • G11C16/06Auxiliary circuits, e.g. for writing into memory
    • G11C16/34Determination of programming status, e.g. threshold voltage, overprogramming or underprogramming, retention
    • G11C16/3436Arrangements for verifying correct programming or erasure
    • G11C16/3454Arrangements for verifying correct programming or for detecting overprogrammed cells
    • G11C16/3459Circuits or methods to verify correct programming of nonvolatile memory cells
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C2211/00Indexing scheme relating to digital stores characterized by the use of particular electric or magnetic storage elements; Storage elements therefor
    • G11C2211/56Indexing scheme relating to G11C11/56 and sub-groups for features not covered by these groups
    • G11C2211/562Multilevel memory programming aspects
    • G11C2211/5621Multilevel programming verification
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11CSTATIC STORES
    • G11C2211/00Indexing scheme relating to digital stores characterized by the use of particular electric or magnetic storage elements; Storage elements therefor
    • G11C2211/56Indexing scheme relating to G11C11/56 and sub-groups for features not covered by these groups
    • G11C2211/564Miscellaneous aspects
    • G11C2211/5648Multilevel memory programming, reading or erasing operations wherein the order or sequence of the operations is relevant

Abstract

<P>PROBLEM TO BE SOLVED: To provide a semiconductor memory device capable of increasing the writing speed of data by achieving a high speed for a verifying operation. <P>SOLUTION: A memory cell array is constructed by arranging a plurality of memory cells connected to word and bit lines to store n values (n is a natural number of 3 or more) in a matrix. A control circuit controls the potentials of the word and bit lines according to input data to write data in the memory cells. The control circuit performs a writing operation to write at the threshold voltage of a k value (k<=n), precharges the bit line, and then changes the potential of the word line by i times to verify whether the memory cells reach the threshold voltage of an i value (i<=k). Thus, the problem of the long time of the verifying operation is solved. <P>COPYRIGHT: (C)2005,JPO&NCIPI

Description

本発明は、例えば2ビット以上のデータを記憶することが可能な半導体記憶装置に関する。   The present invention relates to a semiconductor memory device capable of storing, for example, data of 2 bits or more.

EEPROMを用いたNAND型フラッシュメモリであって、多値データを記憶可能な不揮発性半導体記憶装置が提案されている(例えば、特許文献1参照)。   A nonvolatile semiconductor memory device that is a NAND flash memory using an EEPROM and can store multi-value data has been proposed (see, for example, Patent Document 1).

この種の不揮発性半導体記憶装置において、メモリセルに多値データを記憶する場合、各データに対応した閾値電圧をメモリセルに設定する。この閾値電圧の数は、メモリセルに記憶するデータのビット数が増加するに従って増加する。例えば2ビット、4値のデータを記憶する場合、4つの閾値電圧を必要とし、3ビット、8値のデータを記憶する場合、8つの閾値電圧を必要とする。   In this type of nonvolatile semiconductor memory device, when multi-value data is stored in a memory cell, a threshold voltage corresponding to each data is set in the memory cell. The number of threshold voltages increases as the number of bits of data stored in the memory cell increases. For example, when storing 2-bit, 4-value data, four threshold voltages are required, and when storing 3-bit, 8-value data, eight threshold voltages are required.

メモリセルにデータを書き込む場合、メモリセルの閾値電圧が書き込むべきデータに対応した閾値電圧に達したかどうかをベリファイする。ベリファイ動作を行なう場合、メモリセルが接続されたビット線を所定の電位にプリチャージし、この状態において、ワード線にベリファイ用の電圧を供給する。メモリセルの閾値電圧が書き込みデータに対応した閾値電圧に達していない場合、メモリセルはオンする。このため、ビット線の電位はメモリセルを介して放電され、ローレベルとなる。一方、メモリセルの閾値電圧が書き込みデータに対応した閾値電圧に達している場合、メモリセルはオフ状態を保持する。このため、ビット線はハイレベルを保持する。このビット線の電位を検出することにより、メモリセルの閾値電圧がベリファイされる。ベリファイの結果、メモリセルの閾値電圧が書き込むべきデータに対応した閾値電圧に達していない場合、再度書き込み動作が繰り返される。   When writing data to the memory cell, it is verified whether the threshold voltage of the memory cell has reached the threshold voltage corresponding to the data to be written. When performing a verify operation, the bit line connected to the memory cell is precharged to a predetermined potential, and in this state, a verify voltage is supplied to the word line. When the threshold voltage of the memory cell does not reach the threshold voltage corresponding to the write data, the memory cell is turned on. For this reason, the potential of the bit line is discharged through the memory cell and becomes a low level. On the other hand, when the threshold voltage of the memory cell has reached the threshold voltage corresponding to the write data, the memory cell maintains the off state. For this reason, the bit line maintains a high level. By detecting the potential of the bit line, the threshold voltage of the memory cell is verified. As a result of verification, when the threshold voltage of the memory cell does not reach the threshold voltage corresponding to the data to be written, the write operation is repeated again.

前述したように、多値データを記憶する不揮発性半導体記憶装置の場合、記憶するデータのビット数が多い場合、メモリセルに設定する閾値電圧の数が増加する。データの書き込みにおいて、上記ベリファイ動作は、各閾値電圧毎に実行する必要がある。このため、ベリファイ動作に長時間を要し、データの書き込み動作の高速化が困難であった。
特開2000−195280号公報
As described above, in the case of a nonvolatile semiconductor memory device that stores multilevel data, when the number of bits of data to be stored is large, the number of threshold voltages set in the memory cell increases. In writing data, the verify operation needs to be executed for each threshold voltage. Therefore, it takes a long time for the verify operation, and it is difficult to increase the speed of the data write operation.
JP 2000-195280 A

本発明は、上記課題を解決するためになされたものであり、その目的とするところは、ベリファイ動作を高速化し、データの書き込み速度を向上可能な半導体記憶装置を提供しようとするものである。   The present invention has been made to solve the above-described problems, and an object of the present invention is to provide a semiconductor memory device capable of speeding up a verify operation and improving a data writing speed.

本発明の第1の態様は、ワード線、及びビット線に接続され、n値(nは3以上の自然数)を記憶する複数のメモリセルがマトリックス状に配置されて構成されたメモリセルアレイと、入力データに応じて前記ワード線、ビット線の電位を制御し、前記メモリセルにデータを書き込む制御回路とを具備し、前記制御回路は、書き込み動作により、k値(k<=n)の閾値電圧に書き込み、前記ビット線を一度プリチャージした後、前記ワード線の電位をi回変化させて前記メモリセルが、i値(i<=k)の閾値電圧に達したかのベリファイを行なうことを特徴とする半導体記憶装置。   A first aspect of the present invention is a memory cell array configured by arranging a plurality of memory cells connected to a word line and a bit line and storing n values (n is a natural number of 3 or more) in a matrix, A control circuit for controlling the potentials of the word line and the bit line in accordance with input data and writing the data to the memory cell. The control circuit is configured to write a threshold value of k value (k <= n) by a write operation. After the voltage is written and the bit line is precharged once, the potential of the word line is changed i times to verify whether the memory cell has reached the threshold voltage of i value (i <= k). A semiconductor memory device.

本発明の第2の態様は、ワード線、及びビット線に接続され、4値を記憶する複数のメモリセルがマトリックス状に配置されて構成されたメモリセルアレイと、入力データに応じて前記ワード線、ビット線の電位を制御し、前記メモリセルにデータを書き込む制御回路とを具備し、前記制御回路は、第1の書き込み動作により、前記メモリセルの閾値電圧を前記第1の閾値電圧から第1の閾値電圧又は第2の閾値電圧(第1の閾値電圧<第2の閾値電圧)とし、第2の書き込み動作により、前記メモリセルの閾値電圧が前記第1の閾値電圧である場合、第1の閾値電圧又は第3の閾値電圧(第1の閾値電圧<第3の閾値電圧)とし、第2の閾値電圧である場合、第4の閾値電圧(第2の閾値電圧<=第4の閾値電圧)又は第5の閾値電圧(第4の閾値電圧<第5の閾値電圧)とし、前記制御回路は、前記第1、第2の書き込み動作において、プログラム電圧をΔVpgmづつ上げて、プログラム及びベリファイ動作を繰り返して書き込み動作を行ない、前記第1の書き込み動作時のΔVpgmは、前記第2の書き込み動作時のΔVpgmよりも大きい値であることを特徴とする半導体記憶装置。   According to a second aspect of the present invention, there is provided a memory cell array configured by arranging a plurality of memory cells connected to word lines and bit lines and storing four values in a matrix, and the word lines according to input data. And a control circuit that controls the potential of the bit line and writes data to the memory cell, and the control circuit changes the threshold voltage of the memory cell from the first threshold voltage by a first write operation. 1 threshold voltage or second threshold voltage (first threshold voltage <second threshold voltage), and when the threshold voltage of the memory cell is the first threshold voltage by the second write operation, 1 threshold voltage or third threshold voltage (first threshold voltage <third threshold voltage), and the second threshold voltage, the fourth threshold voltage (second threshold voltage <= fourth Threshold voltage) or fifth threshold voltage (th In the first and second write operations, the control circuit increases the program voltage by ΔVpgm, repeats the program and verify operations, and performs the write operation. A semiconductor memory device, wherein ΔVpgm at the time of one write operation is larger than ΔVpgm at the time of the second write operation.

本発明の第3の態様は、ワード線、及びビット線に接続され、4値を記憶する複数のメモリセルがマトリックス状に配置されて構成されたメモリセルアレイと、入力データに応じて前記ワード線、ビット線の電位を制御し、前記メモリセルにデータを書き込む制御回路とを具備し、前記制御回路は、第1の書き込み動作により、前記メモリセルの閾値電圧を前記第1の閾値電圧から第1の閾値電圧又は第2の閾値電圧(第1の閾値電圧<第2の閾値電圧)とし、第2の書き込み動作により、前記メモリセルの閾値電圧が前記第1の閾値電圧である場合、第1の閾値電圧又は第3の閾値電圧(第1の閾値電圧<第3の閾値電圧)とし、第2の閾値電圧である場合、第4の閾値電圧(第2の閾値電圧<=第4の閾値電圧)又は第5の閾値電圧(第4の閾値電圧<第5の閾値電圧)とし、前記制御回路は、前記第2の書き込み動作において、プログラム及びベリファイ動作を繰り返し行ない、前記第3の閾値電圧に達したかどうかをベリファイするベリファイ動作の回数に最大値を設定し、前記ベリファイ動作の回数が前記最大値に達した場合、前記第3の閾値電圧に達したかどうかをベリファイするベリファイ動作をスキップすることを特徴とする半導体記憶装置。   According to a third aspect of the present invention, there is provided a memory cell array configured by arranging a plurality of memory cells connected to word lines and bit lines to store four values in a matrix, and the word lines according to input data. And a control circuit that controls the potential of the bit line and writes data to the memory cell, and the control circuit changes the threshold voltage of the memory cell from the first threshold voltage by a first write operation. 1 threshold voltage or second threshold voltage (first threshold voltage <second threshold voltage), and when the threshold voltage of the memory cell is the first threshold voltage by the second write operation, 1 threshold voltage or third threshold voltage (first threshold voltage <third threshold voltage), and the second threshold voltage, the fourth threshold voltage (second threshold voltage <= fourth Threshold voltage) or fifth threshold voltage (th The threshold voltage is less than the fifth threshold voltage, and the control circuit repeatedly performs the program and verify operations in the second write operation to verify whether the third threshold voltage has been reached. A semiconductor memory device, wherein a maximum value is set for the number of times, and when the number of verify operations reaches the maximum value, a verify operation for verifying whether the third threshold voltage has been reached is skipped.

本発明の第4の態様は、第1閾値電圧乃至第n閾値電圧(nは2以上の自然数)により、データを記憶するメモリセルと、入力データに応じて前記メモリセルに前記第1乃至第n閾値電圧のいずれかを書き込む制御回路とを具備し、前記制御回路は、第1回目の書き込み動作により、前記メモリセルに第n閾値電圧、第(n−1)閾値電圧…第(n−k+1)閾値電圧のk値の閾値電圧に書き込み、第2回目の書き込み動作により、前記メモリセルに第(n−k)閾値電圧、第(n−k−1)閾値電圧…第(n−2k+1)閾値電圧のk値の閾値電圧に書き込み、第n/k回目の書き込み動作により、前記メモリセルに第k閾値電圧、第(k−1)閾値電圧…第2閾値電圧の(k−1)値の閾値電圧を書き込むことを特徴とする半導体記憶装置。   According to a fourth aspect of the present invention, there is provided a memory cell for storing data according to a first threshold voltage to an nth threshold voltage (n is a natural number of 2 or more), and the first to second memory cells according to input data. a control circuit for writing any one of the n threshold voltages, and the control circuit causes the memory cell to receive the nth threshold voltage, the (n−1) th threshold voltage,. (k + 1) writing to the threshold voltage of the k value of the threshold voltage, and by the second writing operation, the (n−k) th threshold voltage, the (n−k−1) th threshold voltage,. ) The threshold voltage is written to the threshold voltage of the k value, and the kth threshold voltage, the (k−1) th threshold voltage,... Semiconductor memory device characterized by writing threshold voltage of value .

本発明の第5の態様は、少なくとも1つ以上のデータを記憶するメモリと、前記メモリセルに接続され、外部より入力された第1論理レベル又は第2論理レベルのデータを記憶する少なくとも1つ以上のデータ記憶回路と、前記データ記憶回路の動作を制御する制御回路とを有し、前記制御回路は、前記データ記憶回路に記憶されたデータの論理レベルが、第1論理レベルの場合、第2論理レベルに反転させ、第2論理レベルの場合、第1論理レベルに反転させ、前記データ記憶回路に記憶されたデータの論理レベルが第1論理レベルの場合、前記メモリセルに閾値電圧を上げる書き込み動作を行ない、第2論理レベルの場合、前記メモリセルに閾値電圧は変化させず維持させることを特徴とする半導体記憶装置。   According to a fifth aspect of the present invention, there is provided a memory that stores at least one data and at least one that is connected to the memory cell and stores data of a first logic level or a second logic level input from the outside. The data storage circuit, and a control circuit for controlling the operation of the data storage circuit. The control circuit has a first logic level when the logic level of the data stored in the data storage circuit is the first logic level. Inverted to the second logic level. If the second logic level, the first logic level is inverted. If the logic level of the data stored in the data storage circuit is the first logic level, the threshold voltage of the memory cell is increased. A semiconductor memory device, wherein a write operation is performed and the threshold voltage is maintained unchanged in the memory cell in the second logic level.

本発明の第6の態様は、ワード線、及びビット線に接続され、n値(nは3以上の自然数)を記憶する複数のメモリセルがマトリックス状に配置されて構成されたメモリセルアレイと、入力データに応じて前記ワード線、ビット線の電位を制御し、前記メモリセルにデータを書き込む制御回路とを具備し、前記制御回路は、第1の書き込み動作により、a1値(a1<=n)の閾値電圧に書き込み、第2の書き込み動作により、a2値(a2<=n)の閾値電圧に書き込み、第k(kは2以上の自然数:k<=n)の書き込み動作により、ak値(ak<=n)の閾値電圧を書き込み、前記第1、第2乃至第kの書き込み動作において、プログラム電圧をΔVpgmづつ上げて、プログラム及びベリファイ動作を繰り返して書き込み動作を行ない、前記第1、第2乃至第kの書き込み動作時のΔVpgmは、第1のΔVpgm>第2のΔVpgm…>第kのΔVpgmであることを特徴とする半導体記憶装置。   A sixth aspect of the present invention is a memory cell array configured by arranging a plurality of memory cells connected to word lines and bit lines and storing n values (n is a natural number of 3 or more) in a matrix form, A control circuit for controlling the potentials of the word line and the bit line in accordance with input data and writing data to the memory cell. The control circuit performs a1 value (a1 <= n) by a first write operation. ), The second write operation writes to the a2 value (a2 <= n) threshold voltage, and the kth (k is a natural number greater than or equal to 2: k <= n) write operation causes the ak value. The threshold voltage of (ak <= n) is written, and in the first, second to kth write operations, the program voltage is increased by ΔVpgm and the program and verify operations are repeated to perform the write operation. ΔVpgm at the time of the second to kth write operations is first ΔVpgm> second ΔVpgm...> Kth ΔVpgm.

本発明の第7の態様は、第1閾値電圧乃至第n閾値電圧(nは2以上の自然数)の順で閾値電圧が高く定義され、書き込み動作により閾値電圧が高くなり、前記第1閾値電圧乃至第n閾値電圧により、データを記憶するメモリセルと、入力データに応じて前記メモリセルに前記第1乃至第n閾値電圧のいずれかを書き込む制御回路とを具備し、前記制御回路は、第1回目の書き込み動作により、前記メモリセルに第n閾値電圧、第(n−1)閾値電圧…第(n−k1+1)閾値電圧のk1値の閾値電圧に書き込み、第2回目の書き込み動作により、前記メモリセルに第(n−k1)閾値電圧、第(n−k1−1)閾値電圧…第(n−k1−k2+1)閾値電圧のk2値の閾値電圧に書き込み、第i回目の書き込み動作により、前記メモリセルに第ki閾値電圧、第(ki−1)閾値電圧…第2閾値電圧の(ki−1)値の閾値電圧を書き込むことを特徴とする半導体記憶装置。   According to a seventh aspect of the present invention, the threshold voltage is defined to be higher in the order of the first threshold voltage to the nth threshold voltage (n is a natural number of 2 or more), the threshold voltage is increased by the write operation, and the first threshold voltage Through a memory cell for storing data according to the nth threshold voltage, and a control circuit for writing any of the first to nth threshold voltages in the memory cell in accordance with input data. By the first write operation, the memory cell is written to the threshold voltage of the k1 value of the nth threshold voltage, the (n−1) th threshold voltage,... (N−k1 + 1) threshold voltage, and the second write operation The memory cell is written to the threshold voltage of the (n−k1) th threshold voltage, the (n−k1-1) threshold voltage, k2 value of the (n−k1−k2 + 1) th threshold voltage, and the i th write operation , The memory cell The ki threshold voltage, the (ki-1) a semiconductor memory device and writes the threshold voltage ... threshold voltage (ki-1) value of the second threshold voltage.

本発明の第8の態様は、ワード線、及びビット線に接続され、n値(nは3以上の自然数)を記憶する複数のメモリセルがマトリックス状に配置されて構成されたメモリセルアレイと、入力データに応じて前記ワード線、ビット線の電位を制御し、前記メモリセルにデータを書き込む制御回路と、前記ビット線に接続され、少なくとも1ビット以上のデータを記憶するデータ記憶回路を具備し、前記制御回路は、書き込み動作により、メモリセルの閾値電圧が第k値の閾値電圧に達したかのベリファイ時、前記第k値の閾値電圧より低い閾値電圧でベリファイ動作を行ない、前記メモリセルの閾値電圧が前記第k値の閾値電圧より低い閾値電圧を越えている場合、前記データ記憶回路内のデータを第k値より低い第i値の閾値電圧(i<k)への書き込みと同じデータに設定することを特徴とする半導体記憶装置。   An eighth aspect of the present invention is a memory cell array configured by arranging a plurality of memory cells connected to word lines and bit lines and storing n values (n is a natural number of 3 or more) in a matrix form, A control circuit for controlling the potentials of the word lines and bit lines in accordance with input data and writing data to the memory cells; and a data storage circuit for connecting at least one bit of data connected to the bit lines. The control circuit performs a verify operation at a threshold voltage lower than the threshold voltage of the kth value when verifying whether the threshold voltage of the memory cell has reached the threshold voltage of the kth value by a write operation, and the threshold value of the memory cell When the voltage exceeds a threshold voltage lower than the threshold voltage of the k-th value, the data in the data storage circuit is converted into an i-th threshold voltage (i <k) lower than the k-th value. The semiconductor memory device and setting the same data as the write.

本発明の第9の態様は、k(kは2以上の自然数)ビットを記憶するメモリセルと、外部から入力されるデータ、及びメモリセルから読み出されたデータを記憶する第1の記憶回路と、前記第1の記憶回路に記憶されたデータを記憶する第2の記憶回路と、前記メモリセルから読み出されたデータを記憶する第3の記憶回路と、前記第3の記憶回路に記憶されたデータを記憶する第4の記憶回路とを具備し、書き込み動作時、前記メモリセルが記憶しているデータに応じて、前記第1乃至第4の記憶回路のデータを保持又は変更し、第3ページの書き込み動作において、8値のデータを同じに書き込む制御回路とを具備すること特徴とする半導体記憶装置。   According to a ninth aspect of the present invention, a memory cell that stores k (k is a natural number of 2 or more) bits, a first memory circuit that stores data input from the outside, and data read from the memory cell A second memory circuit that stores data stored in the first memory circuit, a third memory circuit that stores data read from the memory cell, and a memory stored in the third memory circuit. A fourth memory circuit that stores the data stored therein, and holds or changes data in the first to fourth memory circuits according to the data stored in the memory cell during a write operation, A semiconductor memory device comprising: a control circuit for writing the same 8-level data in the third page write operation.

本発明の第10の態様は、ワード線、及びビット線に接続され、n値(nは3以上の自然数)を記憶する複数のメモリセルがマトリックス状に配置されて構成されたメモリセルアレイと、入力データに応じて前記ワード線、ビット線の電位を制御し、前記メモリセルからデータを読み出す制御回路とを具備し、前記制御回路は、前記ビット線を一度プリチャージした後、前記ワード線の電位をi回変化させて前記メモリセルのデータを読み出すことを特徴とする半導体記憶装置。   A tenth aspect of the present invention is a memory cell array configured by arranging a plurality of memory cells connected to word lines and bit lines and storing n values (n is a natural number of 3 or more) in a matrix form, A control circuit for controlling the potential of the word line and the bit line according to input data and reading data from the memory cell, and the control circuit precharges the bit line once, A semiconductor memory device, wherein data of the memory cell is read by changing a potential i times.

本発明によれば、ベリファイ動作を高速化し、データの書き込み速度を向上可能な半導体記憶装置を提供できる。   According to the present invention, it is possible to provide a semiconductor memory device capable of speeding up the verify operation and improving the data writing speed.

以下、本発明の実施の形態について図面を参照して説明する。   Hereinafter, embodiments of the present invention will be described with reference to the drawings.

(第1の実施形態)
図2は、不揮発性半導体記憶装置の概略構成を示すものであり、例えば4値(2ビット)を記憶するNANDフラッシュメモリの構成を示している。
(First embodiment)
FIG. 2 shows a schematic configuration of a nonvolatile semiconductor memory device, and shows a configuration of a NAND flash memory that stores, for example, four values (2 bits).

メモリセルアレイ1は複数のビット線と複数のワード線と共通ソース線を含み、例えばEEPROMセルからなる電気的にデータを書き換え可能なメモリセルがマトリクス状に配置されている。このメモリセルアレイ1には、ビット線を制御するためのビット制御回路2とワード線制御回路6が接続されている。   The memory cell array 1 includes a plurality of bit lines, a plurality of word lines, and a common source line, and memory cells that are electrically rewritable, such as EEPROM cells, are arranged in a matrix. A bit control circuit 2 and a word line control circuit 6 for controlling bit lines are connected to the memory cell array 1.

ビット線制御回路2は、後述するように複数のデータ記憶回路及びフラグ用データ記憶回路を含んでいる。このビット線制御回路2は、ビット線を介してメモリセルアレイ1中のメモリセルのデータを読み出したり、ビット線を介してメモリセルアレイ1中のメモリセルの状態を検出したり、ビット線を介してメモリセルアレイ1中のメモリセルに書き込み制御電圧を印加してメモリセルに書き込みを行なう。ビット線制御回路2には、カラムデコーダ3、データ入出力バッファ4が接続されている。ビット線制御回路2内のデータ記憶回路はカラムデコーダ3によって選択される。データ記憶回路に読み出されたメモリセルのデータは、前記データ入出力バッファ4を介してデータ入出力端子5から外部へ出力される。   As will be described later, the bit line control circuit 2 includes a plurality of data storage circuits and a flag data storage circuit. The bit line control circuit 2 reads the data of the memory cells in the memory cell array 1 via the bit lines, detects the state of the memory cells in the memory cell array 1 via the bit lines, or via the bit lines. A write control voltage is applied to the memory cells in the memory cell array 1 to write to the memory cells. A column decoder 3 and a data input / output buffer 4 are connected to the bit line control circuit 2. The data storage circuit in the bit line control circuit 2 is selected by the column decoder 3. Data of the memory cell read to the data storage circuit is output to the outside from the data input / output terminal 5 via the data input / output buffer 4.

また、外部からデータ入出力端子5に入力された書き込みデータは、データ入出力バッファ4を介して、カラムデコーダ3によって選択されたデータ記憶回路に入力される。   Write data input from the outside to the data input / output terminal 5 is input to the data storage circuit selected by the column decoder 3 via the data input / output buffer 4.

ワード線制御回路6は、メモリセルアレイ1に接続されている。このワード線制御回路6は、メモリセルアレイ1中のワード線を選択し、選択されたワード線に読み出し、書き込みあるいは消去に必要な電圧を印加する。   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 a voltage necessary for reading, writing or erasing to the selected word line.

メモリセルアレイ1、ビット線制御回路2、カラムデコーダ3、データ入出力バッファ4、及びワード線制御回路6は、制御信号及び制御電圧発生回路7に接続され、この制御信号及び制御電圧発生回路7によって制御される。制御信号及び制御電圧発生回路7は、制御信号入力端子8に接続され、外部から制御信号入力端子8を介して入力される制御信号によって制御される。   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 and control voltage generation circuit 7, and the control signal and control voltage generation circuit 7 Be controlled. The control signal and control voltage generation circuit 7 is connected to the control signal input terminal 8 and is controlled by a control signal input from the outside via the control signal input terminal 8.

前記ビット線制御回路2、カラムデコーダ3、ワード線制御回路6、制御信号及び制御電圧発生回路7は書き込み回路、及び読み出し回路を構成している。   The bit line control circuit 2, column decoder 3, word line control circuit 6, control signal and control voltage generation circuit 7 constitute a write circuit and a read circuit.

図3は、図2に示すメモリセルアレイ1及びビット線制御回路2の構成を示している。メモリセルアレイ1には複数のNANDセルが配置されている。1つのNANDセルは、直列接続された例えば16個のEEPROMからなるメモリセルMCと、選択ゲートS1、S2とにより構成されている。第1の選択ゲートS1はビット線BL0に接続され、第2の選択ゲートS2はソース線SRCに接続されている。各ロウに配置されたメモリセルの制御ゲートはワード線WL1、WL2、WL3〜WL16に共通接続されている。また、第1の選択ゲートS1はセレクト線SG1に共通接続され、第2の選択ゲートS2はセレクト線SG2に共通接続されている。   FIG. 3 shows the configuration of the memory cell array 1 and the bit line control circuit 2 shown in FIG. A plurality of NAND cells are arranged in the memory cell array 1. One NAND cell includes a memory cell MC composed of, for example, 16 EEPROMs connected in series and select gates S1 and S2. 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 arranged in each row are commonly connected to word lines WL1, WL2, WL3 to WL16. The first selection gate S1 is commonly connected to the select line SG1, and the second selection gate S2 is commonly connected to the select line SG2.

ビット線制御回路2は複数のデータ記憶回路10及び第1、第2のフラグ用データ記憶回路10a、10bを有している。各データ記憶回路10及び第1、第2のフラグ用データ記憶回路10a、10bには、一対のビット線(BL0、BL1)、(BL2、BL3)…(BLi、BLi+1)、(BLf1、BLf2、BLf3、BLf4)が接続されている。   The bit line control circuit 2 includes a plurality of data storage circuits 10 and first and second flag data storage circuits 10a and 10b. Each data storage circuit 10 and the first and second flag data storage circuits 10a and 10b have a pair of bit lines (BL0, BL1), (BL2, BL3)... (BLi, BLi + 1), (BLf1, BLf2, BLf3, BLf4) are connected.

メモリセルアレイ1は、破線で示すように、複数のブロックを含んでいる。各ブロックは、複数のNANDセルにより構成され、このブロック単位でデータが消去される。また、消去動作は、データ記憶回路10、第1、第2のフラグ用データ記憶回路10a、10bに接続されている2本のビット線について同時に行なわれる。   The memory cell array 1 includes a plurality of blocks as indicated by broken lines. Each block includes a plurality of NAND cells, and data is erased in units of blocks. The erase operation is simultaneously performed on the two bit lines connected to the data storage circuit 10 and the first and second flag data storage circuits 10a and 10b.

また、ビット線の1つ置きに配置され、1つのワード線に接続された複数のメモリセル(破線で囲まれた範囲のメモリセル)は、1セクタを構成する。このセクタ毎にデータが書き込まれ、読み出される。1セクタには例えば2ページ分のデータが記憶される。また、各ワード線には、フラグを記憶するための複数の第1のフラグセルFC1、及び複数の第2のフラグセルFC2が接続されている。すなわち、この実施形態の場合、1セクタは1つの第1のフラグセルFC1と、1つの第2のフラグセルFC2を含んでいる。   A plurality of memory cells (memory cells in a range surrounded by a broken line) arranged every other bit line and connected to one word line constitute one sector. Data is written and read for each sector. For example, data for two pages is stored in one sector. Each word line is connected to a plurality of first flag cells FC1 and a plurality of second flag cells FC2 for storing flags. That is, in this embodiment, one sector includes one first flag cell FC1 and one second flag cell FC2.

尚、第1、第2のフラグセルFC1、FC2は、1セクタにそれぞれ1つと限定されるものではなく、破線で示すように、1セクタに複数のフラグセルを接続してもよい。この場合、後述するように、複数のフラグセルに記憶されたデータの多数決により、フラグセルに記憶されたデータを決定すればよい。   The first and second flag cells FC1 and FC2 are not limited to one for each sector, and a plurality of flag cells may be connected to one sector as indicated by a broken line. In this case, as will be described later, the data stored in the flag cell may be determined by majority of the data stored in the plurality of flag cells.

リード動作、プログラムベリファイ動作及びプログラム動作時において、データ記憶回路10に接続されている2本のビット線(BLi、BLi+1)のうち外部より指定されたアドレス信号(YA1、YA2…YAi、YAFlag)に応じて1本のビット線が選択される。さらに、外部アドレスに応じて、1本のワード線が選択され、1セクタ(2ページ分)が選択される。この2ページの切り替えはアドレスによって行われる。   During the read operation, the program verify operation, and the program operation, the address signals (YA1, YA2,... YAi, YAFlag) designated from the outside of the two bit lines (BLi, BLi + 1) connected to the data storage circuit 10 are applied. In response, one bit line is selected. Furthermore, one word line is selected according to the external address, and one sector (for two pages) is selected. Switching between the two pages is performed by an address.

図4(a)(b)はメモリセル及び選択トランジスタの断面図を示している。図4(a)はメモリセルを示している。基板41にはメモリセルのソース、ドレインとしてのn型拡散層42が形成されている。基板41の上にはゲート絶縁膜43を介して浮遊ゲート(FG)44が形成され、この浮遊ゲート44の上には絶縁膜45を介して制御ゲート(CG)46が形成されている。図4(b)は選択ゲートを示している。基板41にはソース、ドレインとしてのn型拡散層47が形成されている。基板41の上にはゲート絶縁膜48を介して制御ゲート49が形成されている。   4A and 4B are cross-sectional views of the memory cell and the select transistor. FIG. 4A shows a memory cell. An n-type diffusion layer 42 is formed on the substrate 41 as the source and drain of the memory cell. A floating gate (FG) 44 is formed on the substrate 41 via a gate insulating film 43, and a control gate (CG) 46 is formed on the floating gate 44 via an insulating film 45. FIG. 4B shows the selection gate. An n-type diffusion layer 47 as a source and a drain is formed on the substrate 41. A control gate 49 is formed on the substrate 41 via a gate insulating film 48.

図5は、メモリセルアレイの1つのNANDセルの断面を示している。この例において、1つのNANDセルは、図4(a)に示す構成の16個のメモリセルMCが直列接続されて構成されている。NANDセルのドレイン側、ソース側には、図4(b)に示す構成の第1の選択ゲートS1及び第2の選択ゲートS2が設けられている。   FIG. 5 shows a cross section of one NAND cell of the memory cell array. In this example, one NAND cell is configured by serially connecting 16 memory cells MC configured as shown in FIG. A first selection gate S1 and a second selection gate S2 having the configuration shown in FIG. 4B are provided on the drain side and the source side of the NAND cell.

図6は、図3に示すデータ記憶回路10の一例を示す回路図である。第1、第2のフラグ用データ記憶回路10a、10bもデータ記憶回路10と同様の構成とされている。   FIG. 6 is a circuit diagram showing an example of the data storage circuit 10 shown in FIG. The first and second flag data storage circuits 10 a and 10 b have the same configuration as the data storage circuit 10.

このデータ記憶回路10は、プライマリデータキャッシュ(PDC)、セコンダリデータキャッシュ(SDC)、ダイナミックデータキャッシュ(DDC)、テンポラリデータキャッシュ(TDC)を有している。SDC、PDC、DDCは、書き込み時に入力データを保持し、読み出し時に読み出しデータを保持し、ベリファイ時に一時的にデータを保持し、多値データを記憶する際に内部データの操作に使用される。TDCは、データの読み出し時にビット線のデータを増幅し、一時的に保持するとともに、多値データを記憶する際に内部データの操作に使用される。   The data storage circuit 10 includes a primary data cache (PDC), a secondary data cache (SDC), a dynamic data cache (DDC), and a temporary data cache (TDC). The SDC, PDC, and DDC hold input data at the time of writing, hold read data at the time of reading, temporarily hold data at the time of verification, and are used for internal data operations when storing multi-value data. The TDC amplifies and temporarily holds bit line data when reading data, and is used to manipulate internal data when storing multilevel data.

SDCは、ラッチ回路を構成するクロックドインバータ回路61a、61b、及びトランジスタ61c、61dにより構成されている。トランジスタ61cはクロックドインバータ回路61aの入力端と、クロックドインバータ回路61bの入力端の間に接続されている。このトランジスタ61cのゲートには信号EQ2が供給されている。トランジスタ61dはクロックドインバータ回路61bの入力端と接地間に接続されている。このトランジスタ61dのゲートには信号PRSが供給されている。SDCのノードN2aは、カラム選択トランジスタ61eを介して入出力データ線IOに接続され、ノードN2bは、カラム選択トランジスタ61fを介して入出力データ線IOnに接続される。これらトランジスタ61e、61fのゲートにはカラム選択信号CSLiが供給されている。SDCのノードN2aは、トランジスタ61g、61hを介してPDCのノードN1aに接続されている。トランジスタ61gのゲートには信号BLC2が供給され、トランジスタ61hのゲートには信号BLC1が供給されている。   The SDC includes clocked inverter circuits 61a and 61b and transistors 61c and 61d that constitute a latch circuit. The transistor 61c is connected between the input terminal of the clocked inverter circuit 61a and the input terminal 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 input terminal of the clocked inverter circuit 61b and the ground. A signal PRS is supplied to the gate of the transistor 61d. The node N2a of the SDC is connected to the input / output data line IO via the column selection transistor 61e, and the node N2b is connected to the input / output data line IOn via the column selection transistor 61f. A column selection signal CSLi is supplied to the gates of the transistors 61e and 61f. The node N2a of the SDC is connected to the node N1a of the PDC via the transistors 61g and 61h. A signal BLC2 is supplied to the gate of the transistor 61g, and a signal BLC1 is supplied to the gate of the transistor 61h.

PDCは、クロックドインバータ回路61i、61j及びトランジスタ61kにより構成されている。トランジスタ61kは、クロックドインバータ回路61iの入力端とクロックドインバータ回路61jの入力端の相互間に接続されている。このトランジスタ61kのゲートには信号EQ1が供給されている。PDCのノードN1bはトランジスタ61lのゲートに接続されている。このトランジスタ61lの電流通路の一端はトランジスタ61mを介して接地されている。このトランジスタ61mのゲートには信号CHK1が供給されている。また、トランジスタ61lの電流通路の他端はトランスファーゲートを構成するトランジスタ61n、61oの電流通路の一端に接続されている。このトランジスタ61nのゲートには信号CHK2nが供給されている。また、トランジスタ61oのゲートは前記トランジスタ61gと61hの接続ノードに接続されている。トランジスタ61n、61oの電流通路の他端には、信号COMiが供給されている。この信号COMiは全データ記憶回路10に共通の信号であり、全データ記憶回路10のベリファイが完了したかどうかを示す信号である。すなわち、後述するように、ベリファイが完了すると、PDCのノードN1bがローレベルとなる。この状態において、信号CHK1、CHK2をハイレベルとすると、ベリファイが完了している場合、信号COMiがハイレベルとなる。   The PDC includes clocked inverter circuits 61i and 61j and a transistor 61k. The transistor 61k is connected between the input terminal of the clocked inverter circuit 61i and the input terminal of the clocked inverter circuit 61j. A signal EQ1 is supplied to the gate of the transistor 61k. The 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 grounded through the 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 the transistors 61n and 61o constituting the transfer gate. A signal CHK2n is supplied to the gate of the transistor 61n. The gate of the transistor 61o is connected to the connection node of the transistors 61g and 61h. A signal COMi is supplied to the other end of the current path of the transistors 61n and 61o. This signal COMi is a signal common to all the data storage circuits 10 and indicates whether or not the verification of all the data storage circuits 10 has been completed. That is, as will be described later, when the verification is completed, the node N1b of the PDC goes to a low level. In this state, if the signals CHK1 and CHK2 are set to the high level, the signal COMi is set to the high level when the verification is completed.

さらに、前記TDCは、例えばMOSキャパシタ61pにより構成されている。このキャパシタ61pは、前記トランジスタ61g、61hの接続ノードN3と接地間に接続されている。また、接続ノードN3には、トランジスタ61qを介してDDCが接続されている。トランジスタ61qのゲートには、信号REGが供給されている。   Further, the TDC is constituted by, for example, a MOS capacitor 61p. The capacitor 61p is connected between the connection node N3 of the transistors 61g and 61h and the ground. A DDC is connected to the connection node N3 via a transistor 61q. A signal REG is supplied to the gate of the transistor 61q.

DDCは、トランジスタ61r、61sにより構成されている。トランジスタ61rの電流通路の一端には信号VREGが供給され、他端は前記トランジスタ61qの電流通路に接続されている。このトランジスタ61rのゲートはトランジスタ61sを介して前記PDCのノードN1aに接続されている。このトランジスタ61sのゲートには信号DTGが供給されている。   The DDC is composed of transistors 61r and 61s. The signal VREG is supplied to one end of the current path of the transistor 61r, and the other end is connected to the current path of the transistor 61q. The gate of the transistor 61r is connected to the node N1a of the PDC through the transistor 61s. A signal DTG is supplied to the gate of the transistor 61s.

さらに、前記接続ノードN3にはトランジスタ61t、61uの電流通路の一端が接続されている。トランジスタ61uの電流通路の他端には信号VPREが供給され、ゲートにはBLPREが供給されている。前記トランジスタ61tのゲートには信号BLCLAMPが供給されている。このトランジスタ61tの電流通路の他端はトランジスタ61vを介してビット線BLoの一端に接続され、トランジスタ61wを介してビット線BLeの一端に接続されている。ビット線BLoの他端はトランジスタ61xの電流通路の一端に接続されている。このトランジスタ61xのゲートには信号BlASoが供給されている。ビット線BLeの他端はトランジスタ61yの電流通路の一端に接続されている。このトランジスタ61yのゲートには信号BlASeが供給されている。これらトランジスタ61x、61yの電流通路の他端には、信号BLCRLが供給されている。トランジスタ61x、61yは、信号BlASo、BlASeに応じてトランジスタ61v、61wと相補的にオンとされ、非選択のビット線に信号BLCRLの電位を供給する。   Further, one end of a current path of the transistors 61t and 61u is connected to the connection node N3. The signal VPRE is supplied to the other end of the current path of the transistor 61u, and BLPRE is supplied to the gate. 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 the bit line BLo through the transistor 61v, and is connected to one end of the bit line BLe through the transistor 61w. The other end of the bit line BLo is connected to one end of the current path of the transistor 61x. A signal BlASo is supplied to the gate of the transistor 61x. The other end of the bit line BLe is connected to one end of the current path of the transistor 61y. A signal BlASe is supplied to the gate of the transistor 61y. A signal BLCRL is supplied to the other ends of the current paths of the transistors 61x and 61y. The transistors 61x and 61y are turned on complementarily to the transistors 61v and 61w in response to the signals BlASo and BlASe, and supply the potential of the signal BLCRL to the unselected bit lines.

さらに、データ入力端子5aは、複数のインバータ回路62a、62b、62cを介して前記入出力データ線IOに接続され、さらに、インバータ回路62dを介して前記入出力データ線IOnに接続される。   Further, the data input terminal 5a is connected to the input / output data line IO via a plurality of inverter circuits 62a, 62b and 62c, and further connected to the input / output data line IOn via an inverter circuit 62d.

上記各信号及び電圧は、図2に示す制御信号及び制御電圧発生回路7により生成され、この制御信号及び制御電圧発生回路7の制御に基づき、以下の動作が制御される。   The above signals and voltages are generated by the control signal and control voltage generation circuit 7 shown in FIG. 2, and the following operations are controlled based on the control of the control signal and control voltage generation circuit 7.

本メモリは、多値メモリであり、1セルに例えば2ビットのデータを記憶することができる。この2ビットの切り替えはアドレス(第1ページ、第2ページ)によって行なわれる。   This memory is a multi-level memory and can store, for example, 2-bit data in one cell. The 2-bit switching is performed by an address (first page, second page).

(動作説明)
上記構成において、動作について説明する。
(Description of operation)
The operation of the above configuration will be described.

図1は、メモリセルのデータとメモリセルの閾値電圧の関係を示している。消去動作を行なうとメモリセルのデータは“0”となる。図1(a)に示すように、第1ページの書き込みを行なうと、メモリセルのデータはデータ“0”とデータ“2”になる。図1(b)に示すように、第2ページの書き込み前に隣接セルに実際のデータの閾値電圧以下のデータが書き込まれる。すると、このセルに書き込まれたデータにより、データ“2”の閾値電圧の分布が大きくなる。この後、第2ページのデータが書き込まれると、メモリセルのデータは、図1(c)に示すように、本来の閾値電圧を有するデータ“0”〜“3”となる。第1の実施形態では、メモリセルのデータは閾値電圧の低いほうから高い方へと、定義されている。   FIG. 1 shows the relationship between memory cell data and memory cell threshold voltage. When the erase operation is performed, the data in the memory cell becomes “0”. As shown in FIG. 1A, when the first page is written, the data in the memory cell becomes data “0” and data “2”. As shown in FIG. 1B, data equal to or lower than the threshold voltage of actual data is written in the adjacent cell before the second page is written. Then, the threshold voltage distribution of the data “2” is increased by the data written in the cell. Thereafter, when the data of the second page is written, the data of the memory cell becomes data “0” to “3” having the original threshold voltage as shown in FIG. In the first embodiment, the memory cell data is defined from the lower threshold voltage to the higher threshold voltage.

第1の実施形態は、図1(c)に示す第2ページの書き込みにおいて、閾値電圧“b’”のベリファイと、閾値電圧“c’”のベリファイを、一度ビット線をプリチャージした後、ワード線電位を複数回変えることにより、一括して行なうことを特徴としている。   In the first embodiment, in the writing of the second page shown in FIG. 1C, after verifying the threshold voltage “b ′” and verifying the threshold voltage “c ′”, once precharging the bit line, It is characterized in that it is performed collectively by changing the word line potential a plurality of times.

図7は、NANDセルに対する書き込み順序を示している。ブロック内において、ソース線に近いメモリセルからページごとに書き込み動作が行なわれる。図7は、説明の便宜上、ワード線を4本としている。   FIG. 7 shows a write order for the NAND cell. In the block, a write operation is performed for each page from a memory cell close to the source line. FIG. 7 shows four word lines for convenience of explanation.

第1番目の書き込みは、メモリセル1の第1ページに1ビットのデータが書きこまれる。   In the first writing, 1-bit data is written in the first page of the memory cell 1.

第2番目の書き込みは、メモリセル1とワード方向に隣接したメモリセル2の第1ページに1ビットのデータが書きこまれる。   In the second writing, 1-bit data is written in the first page of the memory cell 2 adjacent to the memory cell 1 in the word direction.

第3番目の書き込みは、メモリセル1とビット方向に隣接したメモリセル3の第1ページに1ビットのデータが書きこまれる。   In the third write, 1-bit data is written in the first page of the memory cell 3 adjacent to the memory cell 1 in the bit direction.

第4番目の書き込みは、メモリセル1と対角に隣接したメモリセル4の第1ページに1ビットのデータが書きこまれる。   In the fourth write, 1-bit data is written in the first page of the memory cell 4 diagonally adjacent to the memory cell 1.

第5番目の書き込みは、メモリセル1の第2ページに1ビットのデータが書きこまれる。   In the fifth write, 1-bit data is written in the second page of the memory cell 1.

第6番目の書き込みは、メモリセル1とワード方向に隣接したメモリセル2の第2ページに1ビットのデータが書きこまれる。   In the sixth writing, 1-bit data is written in the second page of the memory cell 2 adjacent to the memory cell 1 in the word direction.

第7番目の書き込みは、メモリセル3とビット方向に隣接したメモリセル5の第1ページに1ビットのデータが書きこまれる。   In the seventh writing, 1-bit data is written in the first page of the memory cell 5 adjacent to the memory cell 3 in the bit direction.

第8番目の書き込みは、メモリセル3と対角に隣接したメモリセル6の第1ページに1ビットのデータが書きこまれる。   In the eighth write, 1-bit data is written in the first page of the memory cell 6 diagonally adjacent to the memory cell 3.

第9番目の書き込みは、メモリセル3の第2ページに1ビットのデータが書きこまれる。   In the ninth write, 1-bit data is written in the second page of the memory cell 3.

第10番目の書き込みは、メモリセル3とワード方向に隣接したメモリセル4の第2ページに1ビットのデータが書きこまれる。   In the tenth write, 1-bit data is written in the second page of the memory cell 4 adjacent to the memory cell 3 in the word direction.

第11番目の書き込みは、メモリセル5とビット方向に隣接したメモリセル7の第1ページに1ビットのデータが書きこまれる。   In the eleventh write, 1-bit data is written in the first page of the memory cell 7 adjacent to the memory cell 5 in the bit direction.

第12番目の書き込みは、メモリセル5と対角に隣接したメモリセル8の第1ページに1ビットのデータが書きこまれる。   In the twelfth write, 1-bit data is written in the first page of the memory cell 8 diagonally adjacent to the memory cell 5.

第13番目の書き込みは、メモリセル5の第2ページに1ビットのデータが書きこまれる。   In the thirteenth write, 1-bit data is written in the second page of the memory cell 5.

第14番目の書き込みは、メモリセル5とワード方向に隣接したメモリセル6の第2ページに1ビットのデータが書きこまれる。   In the fourteenth write, 1-bit data is written in the second page of the memory cell 6 adjacent to the memory cell 5 in the word direction.

第15番目の書き込みは、メモリセル7の第2ページに1ビットのデータが書きこまれる。   In the fifteenth write, 1-bit data is written in the second page of the memory cell 7.

第16番目の書き込みは、メモリセル7とワード方向に隣接したメモリセル8の第2ページに1ビットのデータが書きこまれる。   In the sixteenth write, 1-bit data is written in the second page of the memory cell 8 adjacent to the memory cell 7 in the word direction.

(プログラム及びプログラムベリファイ)
(第1ページプログラム)
図8は、第1ページのプログラムのブロックダイアグラムを示している。プログラム動作は、先ずアドレスを指定し、図3に示す2ページ(1セクタ)が選択する。本メモリは、この2ページのうち、第1ページ、第2ページの順でしか、プログラム動作できない。したがって、先ず、アドレスにより第1ページを選択する。
(Program and program verify)
(First page program)
FIG. 8 shows a block diagram of the first page program. In the program operation, an address is first designated, and two pages (one sector) shown in FIG. 3 are selected. The memory can perform a program operation only in the order of the first page and the second page of the two pages. Therefore, first, the first page is selected by the address.

このアドレス入力中に図6の61dのトランジスタをオンすることで、全てのSDCのN2aのノードをVssにする。(S11)
次に、データ入出力線IO、IOnを介して書き込みデータを、外部より入力し全てのデータ記憶回路10内のSDC(図6に示す)に記憶する(S12)。このとき、データを書き込む場合、外部よりデータ入力端子5aにデータ“0”が入力される。このデータはインバータ回路62a、62b、62c、トランジスタ62d、61eを介してSDCに供給される。このため、SDCのN2aのノードは、Vddになる。また、書き込み非選択の場合、データ入力端子5aにデータ“1”が入力される。このため、SDCのN2aのノードは、Vssになる。この後、書き込みコマンドが入力されると、全てのデータ記憶回路10内のSDCのデータがPDCに転送される(S13)。すなわち、信号BLC1,BLC2が所定の電圧、例えばVdd+Vth(Vdd:電源電圧(例えば3V又は1.8V、しかし、この電圧に限定されるものではない)、Vth:NチャネルMOSトランジスタの閾値電圧)とされ、トランジスタ61h、61gがオンとされる。すると、ノードN2aのデータがトランジスタ61g、61hを介してPDCに転送される。このため、外部よりデータ“1”(書き込みを行なわない)が入力された場合、PDCのノードN1aは、ローレベルになり、データ“0”(書き込みを行なう)が入力された場合、PDCのノードN1aは、ハイレベルとなる。以後、PDCのデータはノードN1aの電位、SDCのデータはノードN2aの電位とする。
By turning on the transistor 61d in FIG. 6 during this address input, the N2a node of all SDCs is set to Vss. (S11)
Next, write data is input from the outside via the data input / output lines IO and IOn and stored in the SDCs (shown in FIG. 6) in all the data storage circuits 10 (S12). At this time, when data is written, data “0” is input from the outside to the data input terminal 5a. This data is supplied to the SDC via inverter circuits 62a, 62b, 62c and transistors 62d, 61e. For this reason, the node N2a of the SDC becomes Vdd. In addition, when writing is not selected, data “1” is input to the data input terminal 5a. For this reason, the node N2a of the SDC becomes Vss. Thereafter, when a write command is input, the data of SDC in all the data storage circuits 10 is transferred to the PDC (S13). That is, the signals BLC1 and BLC2 have a predetermined voltage, for example, Vdd + Vth (Vdd: power supply voltage (for example, 3V or 1.8V, but not limited to this voltage), Vth: threshold voltage of the N-channel MOS transistor) Then, the transistors 61h and 61g are turned on. Then, the data of the node N2a is transferred to the PDC through the transistors 61g and 61h. For this reason, when data “1” (not written) is input from the outside, the node N1a of the PDC is at a low level, and when data “0” (written) is input, the node of the PDC N1a is at a high level. Thereafter, the data of the PDC is the potential of the node N1a, and the data of the SDC is the potential of the node N2a.

(データ反転動作)(S14)
この後、VPRE=Vdd、信号BLPREをVdd+Vthとし、とし一旦N3をVddにプリチャージした後に、DTG=Vdd+Vth、としてPDCのデータをDDCに写す。次に、REG=Vdd、VREG=Vssとし、DDCがハイレベルの場合、ノードN3はローレベル、DDCがローレベルの場合、ノードN3はハイレベルとなる。この後、一旦信号SEN1、LAT1をオフとし、信号EQ1をVddとし、ノードN1aとノードN1bを同電位とする。この後、信号BLC1=Vdd+Vthとし、TDCのデータ(ノードN3の電位)をPDCに移す。この結果、元々PDCにデータ“1”がラッチされていた場合、PDCのデータは“0”になる。また、PDCにデータ“0”がラッチされていた場合、PDCのデータは“1”になる。
(Data inversion operation) (S14)
After this, VPRE = Vdd, the signal BLPRE is set to Vdd + Vth, N3 is precharged to Vdd, and then DTG = Vdd + Vth, and the PDC data is copied to the DDC. Next, when REG = Vdd and VREG = Vss, and the DDC is at a high level, the node N3 is at a low level, and when the DDC is at a low level, the node N3 is at a high level. Thereafter, the signals SEN1 and LAT1 are once turned off, the signal EQ1 is set to Vdd, and the nodes N1a and N1b are set to the same potential. Thereafter, the signal BLC1 = Vdd + Vth is set, and the TDC data (the potential of the node N3) is transferred to the PDC. As a result, when data “1” is originally latched in the PDC, the data in the PDC becomes “0”. When data “0” is latched in the PDC, the data in the PDC becomes “1”.

書き込みコマンドが入力されるとプログラムをするための電圧Vpgm及びVpassの昇圧回路が動作する。これら電圧Vpgm及びVpassの電位は直ぐには立ち上がらない。上記データ反転動作は、この電位上昇に要する待ち時間の間に行なう。このため、書き込みスピードは遅くならない。   When a write command is input, the voltage Vpgm and Vpass booster circuits for programming operate. The potentials of these voltages Vpgm and Vpass do not rise immediately. The data inversion operation is performed during the waiting time required for this potential increase. For this reason, the writing speed is not slowed down.

このように、入力データを反転するのは、メモリセル内に書かれている1ページのデータをページバッファに読み出し、外部に出力せずに他の1ページに書き込むページコピーを行なう場合、有効である。すなわち、ページコピーを行なう場合、先ず、読み出しを行なう。この結果、書き込みを行った場合(データ入力端子5aにデータ“0”を入力した場合)、SDCはデータ“1”をラッチし、書き込みを行なわなかった場合(データ入力端子5aにデータ“1”を入力した場合)、SDCはデータ“0”をラッチする。前述したように、SDCは入力データに対して反転されたデータをラッチしている。このため、ページコピーのために読み出されたデータと書き込み時にSDCにラッチされたデータとが一致する。このようにSDCにおいて、次に書くデータを一致させておくと、読み出したデータの一部のみデータを外部より入力し書き換えることが容易にできる。したがって、ページコピーをしない場合においても、常に、外部より入力されたデータをページバッファ内でデータ反転するようにする。   Inverting input data in this way is effective when page copy data written in a memory cell is read to a page buffer and written to another page without being output to the outside. is there. That is, when page copy is performed, first, reading is performed. As a result, when writing is performed (when data “0” is input to the data input terminal 5a), the SDC latches data “1” and when writing is not performed (data “1” is input to the data input terminal 5a). SDC latches data “0”. As described above, the SDC latches the inverted data with respect to the input data. For this reason, the data read for page copy and the data latched in the SDC at the time of writing match. In this way, if the data to be written next is matched in the SDC, only a part of the read data can be easily inputted and rewritten from the outside. Therefore, even when page copying is not performed, data input from the outside is always inverted in the page buffer.

上記データ反転動作は、通常のプログラムコマンドを入れることにより行なう。この後、PDCのデータをDDCにコピーする。   The data inversion operation is performed by inputting a normal program command. Thereafter, the PDC data is copied to the DDC.

尚、第1ページのプログラムにおいて、フラグセルにはデータが書き込まれない。このため、第1、第2のフラグ用データ記憶回路10a,10b内のPDCはデータ“1”をラッチしている。   In the first page program, no data is written in the flag cell. Therefore, the PDC in the first and second flag data storage circuits 10a and 10b latches data “1”.

さらに、プログラマブルカウンタ(PC)の値が“0”に初期設定される。このカウンタは、図2に示す例えば制御信号及び制御電圧発生回路7に設けられている。しかし、制御信号及び制御電圧発生回路7に限定されるものではない。   Further, the value of the programmable counter (PC) is initialized to “0”. This counter is provided, for example, in the control signal and control voltage generation circuit 7 shown in FIG. However, the present invention is not limited to the control signal and control voltage generation circuit 7.

(プログラム動作)(S15)
先ず、図6示す信号BLC1、BLCLAMP、BLSo又はBLSeの電位をVdd+Vthとする。すると、トランジスタ61h、61t、61v又は61wがオンとなり、PDCに保持されたデータがビット線に供給される。PDCにデータ“1”(書き込みを行なわない)が記憶されている時、ビット線がVddになり、データ“0”(書き込みを行なう)時、ビット線がVss(接地電位)になる。また、選択されたワード線に接続され、非選択ページの(ビット線が非選択である)セルは書き込みが行なわれてはならない。このため、これらのセルに接続されているビット線にもデータ“1”と同じようにVddを供給する。ここで、選択されているブロックのセレクト線SG1にVdd、選択ワード線に電位VPGM(20V)、非選択ワード線に電位Vpass(10V)を印加する。すると、ビット線がVssになっている場合、セルのチャネルがVss、ワード線がVPGMとなるので書き込みが行なわれる。一方、ビット線がVddになっている場合、セルのチャネルがVssではなく、VPGMを上げることにより、カップリングでVPGM/2となる。このため、このセルはプログラムされない。
(Program operation) (S15)
First, the potential of the signal BLC1, BLCLAMP, BLSo, or BLSe shown in FIG. 6 is set to Vdd + Vth. Then, the transistors 61h, 61t, 61v or 61w are turned on, and the data held in the PDC is supplied to the bit line. When data “1” (not written) is stored in the PDC, the bit line becomes Vdd, and when data “0” (writes), the bit line becomes Vss (ground potential). In addition, a cell connected to the selected word line and not selected (the bit line is not selected) must not be written. Therefore, Vdd is supplied to the bit lines connected to these cells in the same way as data “1”. Here, Vdd is applied to the select line SG1 of the selected block, the potential VPGM (20V) is applied to the selected word line, and the potential Vpass (10V) is applied to the unselected word line. Then, when the bit line is at Vss, the cell channel is at Vss and the word line is at VPGM, so that writing is performed. On the other hand, when the bit line is at Vdd, the cell channel is not Vss but VPGM is raised to VPGM / 2 by coupling. For this reason, this cell is not programmed.

多値メモリでは、閾値の分布を狭めるため、図1に示すように、本来のベリファイ電位“v’”と、これより低いベリファイ電位“v*’”を設定し、このベリファイ電位“v*’”を超えたセルに対応するビット線に中間電位(例えば1V)を供給することにより、書き込みスピードを遅くしている。したがって、ここで、信号VREGをVdd、信号REGを中間電位(例えば1V+Vth)にすると、ビット線がVssの場合で、DDCがハイレベルの場合、ビット線は中間電位になる。また、DDCがローレベルの場合、ビット線はVssのままとなり、ビット線がVddの場合、Vddのままになる。   In the multi-value memory, in order to narrow the threshold distribution, as shown in FIG. 1, an original verify potential “v ′” and a lower verify potential “v * ′” are set, and this verify potential “v * ′” is set. By supplying an intermediate potential (for example, 1 V) to the bit line corresponding to the cell exceeding “,” the writing speed is reduced. Therefore, here, when the signal VREG is set to Vdd and the signal REG is set to the intermediate potential (for example, 1 V + Vth), the bit line is set to the intermediate potential when the bit line is Vss and the DDC is at the high level. When the DDC is at a low level, the bit line remains at Vss, and when the bit line is at Vdd, it remains at Vdd.

第1ページの書き込みにおいて、入力データが“0”の場合、図1に示すように、メモリセルのデータを“2”にする。入力データが“1”の場合、メモリセルのデータは“0”のままである。   In the first page write, when the input data is “0”, the memory cell data is set to “2” as shown in FIG. When the input data is “1”, the data in the memory cell remains “0”.

また、プログラム動作に伴い、カウンタ(PC)がカウントアップされる(PC=PC+1)。   Further, the counter (PC) is counted up (PC = PC + 1) with the program operation.

(第1ページベリファイ)(S16)
第1ページでは、図1(a)に示すように、本来のベリファイ電位“v’”まで書き込む。したがって、ベリファイ動作の第1ステップでは、ワード線に本来のベリファイ電位“v’”より低い電位“v*’”を供給してベリファイし、第2ステップにおいて、ワード線の電位を“v’”に上げてベリファイする。以後“*”は本来の値より低い電位を表す。
(First page verify) (S16)
On the first page, as shown in FIG. 1A, the original verify potential “v ′” is written. Therefore, in the first step of the verify operation, the potential “v * ′” lower than the original verify potential “v ′” is supplied to the word line for verification, and in the second step, the potential of the word line is set to “v ′”. To verify. Hereinafter, “*” represents a potential lower than the original value.

先ず、選択されているブロック内の非選択ワード線及びセレクト線SG1に読み出し時の電位Vreadを供給し、図6に示すデータ記憶回路10の信号BLPREに例えばVdd+Vth、信号BLCLAMPに所定の電圧、例えば1V+Vthを供給し、信号VPREをVddとし、ビット線を1Vにプリチャージする。   First, the read potential Vread is supplied to the unselected word line and the select line SG1 in the selected block. For example, Vdd + Vth is applied to the signal BLPRE of the data storage circuit 10 shown in FIG. 6, and a predetermined voltage, for example, is applied to the signal BLCLAMP. 1V + Vth is supplied, the signal VPRE is set to Vdd, and the bit line is precharged to 1V.

次に、セルのソース側のセレクト線SG2をハイレベルにする。閾値電圧が電位“v*’”より高いセルはオフする。このため、ビット線はハイレベルのままである。また、閾値電圧が電位“v*’”より低いセルはオンする。このため、ビット線はVssとなる。   Next, the select line SG2 on the source side of the cell is set to the high level. A cell having a threshold voltage higher than the potential “v * ′” is turned off. For this reason, the bit line remains at the high level. A cell having a threshold voltage lower than the potential “v * ′” is turned on. For this reason, the bit line becomes Vss.

次に、信号BLPREに所定の電圧、例えばVdd+Vthを供給し、VPRE=Vddとすることにより、TDCのノードN3をVddにプリチャージした後、信号BLCLAMPを所定の電圧、例えば0.9V+Vthとしてトランジスタ61tをオンさせる。TDCのノードN3は、ビット線がローレベルの場合、ローレベルとなり、ビット線がハイレベルの場合、ハイレベルとなる。   Next, by supplying a predetermined voltage, for example, Vdd + Vth to the signal BLPRE and setting VPRE = Vdd, the node N3 of the TDC is precharged to Vdd, and then the signal BLCLAMP is set to a predetermined voltage, for example, 0.9V + Vth, and the transistor 61t. Turn on. The node N3 of the TDC is at a low level when the bit line is at a low level, and is at a high level when the bit line is at a high level.

ここで、書き込みを行なう場合、図6のDDCにローレベルが記憶され、書き込みを行なわない場合、DDCにハイレベルが記憶されている。このため、信号VREGをVddとし、信号REGをハイレベルにすると、書き込みを行なわない場合のみTDCのノードN3が強制的にハイレベルとなる。この動作の後、PDCのデータをDDCに移し、TDCの電位をPDCに転送する。PDCにハイレベル信号がラッチされる場合は、セルに書き込みを行なわない場合と、セルにデータ“2”を書き込んでおり、セルの閾値電圧がベリファイ電位“v*’”に達した場合だけである。また、PDCにローレベル信号がラッチされる場合は、セルの閾値電圧が“v*’”に達しない場合である。   Here, when writing is performed, a low level is stored in the DDC of FIG. 6, and when writing is not performed, a high level is stored in the DDC. Therefore, when the signal VREG is set to Vdd and the signal REG is set to the high level, the node N3 of the TDC is forcibly set to the high level only when writing is not performed. After this operation, the data in the PDC is transferred to the DDC, and the potential of the TDC is transferred to the PDC. When the high level signal is latched in the PDC, only when the cell is not written and when the data “2” is written in the cell and the threshold voltage of the cell reaches the verify potential “v * ′”. is there. Further, when the low level signal is latched in the PDC, the threshold voltage of the cell does not reach “v * ′”.

次に、ワード線の電位を“v*’”から“v’”に上げると、閾値電圧が“v’”より低いセルはオンし、ビット線はVssとなる。   Next, when the potential of the word line is increased from “v * ′” to “v ′”, the cell whose threshold voltage is lower than “v ′” is turned on, and the bit line becomes Vss.

次に、信号BLPREに所定の電圧、例えばVdd+Vthを供給し、VPRE=Vddとすることにより、TDCのノードN3をVddにプリチャージした後、信号BLCLAMPを所定の電圧、例えば0.9V+Vthとしてトランジスタ61tをさせる。TDCのノードN3は、ビット線がローレベルの場合、ローレベルとなり、ビット線がハイレベルの場合、ハイレベルとなる。   Next, by supplying a predetermined voltage, for example, Vdd + Vth to the signal BLPRE and setting VPRE = Vdd, the node N3 of the TDC is precharged to Vdd, and then the signal BLCLAMP is set to a predetermined voltage, for example, 0.9V + Vth, and the transistor 61t. Let The node N3 of the TDC is at a low level when the bit line is at a low level, and is at a high level when the bit line is at a high level.

ここで、書き込みを行なう場合、図6のDDCにローレベルが記憶され、書き込みを行なわない場合、DDCにハイレベルが記憶されている。このため、信号VREGをVddとし、信号REGをハイレベルにすると、書き込みを行なわない場合のみTDCのノードN3が強制的にハイレベルとなる。この動作の後、PDCのデータをDDCに移し、TDCの電位をPDCに転送する。PDCにハイレベル信号がラッチされる場合は、セルに書き込みを行なわない場合と、セルにデータ“2”を書き込んでおり、セルの閾値電圧がベリファイ電位“v’”に達した場合だけである。また、PDCにローレベル信号がラッチされる場合は、セルの閾値電圧が“v’”に達しない場合である。   Here, when writing is performed, a low level is stored in the DDC of FIG. 6, and when writing is not performed, a high level is stored in the DDC. Therefore, when the signal VREG is set to Vdd and the signal REG is set to the high level, the node N3 of the TDC is forcibly set to the high level only when writing is not performed. After this operation, the data in the PDC is transferred to the DDC, and the potential of the TDC is transferred to the PDC. The high level signal is latched in the PDC only when the cell is not written or when the data “2” is written in the cell and the threshold voltage of the cell reaches the verify potential “v ′”. . Further, when the low level signal is latched in the PDC, the threshold voltage of the cell does not reach “v ′”.

この結果、DDCがハイレベルとなるのは、セルの閾値電圧が“v*’”を超えている場合と、書き込み非選択の場合であり、DDCがローレベルとなるのは、書き込みを行っている場合で、セルの閾値電圧が“v*’”以下の場合である。PDCがハイレベルとなるのは、セルの閾値電圧が“v’”を超えている場合と、書き込み非選択の場合であり、PDCがローレベルとなるのは、書き込みを行っている場合で、セルの閾値電圧が“v’”以下の場合である。   As a result, DDC becomes high level when the threshold voltage of the cell exceeds “v * ′” and when writing is not selected. DDC becomes low level when writing is performed. In this case, the threshold voltage of the cell is “v * ′” or less. The PDC goes high when the cell threshold voltage exceeds “v ′” and when writing is not selected. The PDC goes low when writing is performed. This is a case where the threshold voltage of the cell is “v ′” or less.

PDCがローレベルの場合、再び書き込み動作を行ない全てのデータ記憶回路10のデータがハイレベルになるまでこのプログラム動作とベリファイ動作を繰り返す(S15−S18)。このとき、PDCがローレベルでDDCがハイレベルのセル、すなわち、閾値電圧が“v*’”以上で“v’”の場合、ビット線に中間電位を供給し、書き込みスピードを抑える。   When the PDC is at the low level, the write operation is performed again, and the program operation and the verify operation are repeated until the data in all the data storage circuits 10 become the high level (S15-S18). At this time, when the PDC is at a low level and the DDC is at a high level, that is, when the threshold voltage is “v * ′” or higher and “v ′”, an intermediate potential is supplied to the bit line to suppress the writing speed.

(隣接セルプログラム)
図7に示すように、メモリセル1の第1ページに1ビットのデータの書き込んだ後、メモリセル1とワード方向に隣接したメモリセル2の第1ページの書き込み、メモリセル1とビット方向に隣接したメモリセル3の第1ページの書き込み、メモリセル1と対角に隣接したメモリセル4の第1ページの書き込みが順次行なわれる。これらの書き込み動作が行なわれると、書き込みデータによっては、隣接セルの浮遊ゲート間容量(FG−FG間容量)によって、メモリセル1の閾値電圧が上がる。このため、メモリセル1のデータ“0”とデータ“2”の閾値電圧分布は図1(b)のように電位が高いほうに広がる。
(Adjacent cell program)
As shown in FIG. 7, after writing 1-bit data to the first page of the memory cell 1, writing to the first page of the memory cell 2 adjacent to the memory cell 1 in the word direction, Writing of the first page of the adjacent memory cell 3 and writing of the first page of the memory cell 4 diagonally adjacent to the memory cell 1 are sequentially performed. When these write operations are performed, the threshold voltage of the memory cell 1 increases due to the floating gate capacitance (FG-FG capacitance) of the adjacent cell depending on the write data. For this reason, the threshold voltage distribution of the data “0” and data “2” of the memory cell 1 spreads toward the higher potential as shown in FIG.

この後、第5の書き込みにおいて、メモリセル1の第2ページに1ビットのデータを書き込む。   Thereafter, in the fifth write, 1-bit data is written to the second page of the memory cell 1.

(第2ページプログラム)
第1の実施形態において、第2ページのプログラム及びベリファイ動作が高速化されている。すなわち、メモリセルのデータ“2”及び“3”のベリファイ動作を同時に行なうことにより、高速動作を可能としている。以下に、その動作を説明する。
(2nd page program)
In the first embodiment, the second page program and verify operations are speeded up. That is, by simultaneously performing the verify operation of the data “2” and “3” of the memory cell, high speed operation is possible. The operation will be described below.

図9は、第2ページのプログラム(書き込み)動作のブロックダイアグラムを示している。第2ページプログラム動作も、先ずアドレスに応じて、図3に示す2ページが選択される。これと同時にページバッファをリセットする(S21)。   FIG. 9 shows a block diagram of the program (write) operation of the second page. In the second page program operation, two pages shown in FIG. 3 are first selected according to the address. At the same time, the page buffer is reset (S21).

次に、書き込みデータを外部より入力し、全てのデータ記憶回路内のSDCに記憶する(S22)。外部よりデータ“1”(書き込みを行なわない)が入力されると、データ記憶回路10のSDCのノードN2aは、ローレベルになり、外部よりデータ“0”(書き込みを行なう)が入力されるとハイレベルとなる。   Next, write data is input from the outside and stored in the SDCs in all data storage circuits (S22). When data “1” (not written) is input from the outside, the node N2a of the SDC of the data storage circuit 10 becomes low level, and when data “0” (write is performed) is input from the outside. Become high level.

(第1のフラグセルデータロード)(S23)
書き込みコマンドが入力されると、第2ページのプログラムであるので、第1のフラグセルFC1にデータを書き込むため、第1のフラグセル用データ記憶回路10a内のSDCはハイレベルとなる。前述したように、フラグセルは、信頼性を高めるために、複数セル用意することも可能である。第2ページにおいて、第1のフラグセルFC1に対応するSDCはハイレベルとなる。これにより第1のフラグセルFC1は、メモリセルのデータを“0”からメモリセルのデータを“1”へとデータが書き込まれる。
(First flag cell data load) (S23)
When a write command is input, since it is a program for the second page, data is written to the first flag cell FC1, so that the SDC in the first flag cell data storage circuit 10a becomes high level. As described above, a plurality of flag cells can be prepared in order to improve reliability. In the second page, the SDC corresponding to the first flag cell FC1 is at a high level. As a result, data is written from the memory cell data “0” to the memory cell data “1” in the first flag cell FC1.

第2のフラグに対応するSDCをローレベルにする。これによりメモリセルのデータ“0”への書き込みとなるが、後の操作によりメモリセルデータ“2”への書き込みとなる。   The SDC corresponding to the second flag is set to a low level. As a result, writing to the data “0” of the memory cell is performed, but writing to the memory cell data “2” is performed by a later operation.

第2ページのプログラムでは、図1(c)に示すように、メモリセルのデータが“0”の場合で、外部から入力されるデータが“1”の場合、メモリセルのデータを“0”のままとし、外部から入力されるデータが“0”の場合、メモリセルのデータを“1”にする。   In the program of the second page, as shown in FIG. 1C, when the data in the memory cell is “0” and the data input from the outside is “1”, the data in the memory cell is “0”. If the data input from the outside is “0”, the data in the memory cell is set to “1”.

また、メモリセルのデータが“2”の場合で、外部から入力されるデータが“1”の場合、メモリセルのデータを“2”のままとする。しかし、第1ページの書き込みにおいて、メモリセルの閾値電圧は、本来のデータ“2”の閾値電圧より低い“v’”までしか上昇していない。このため、データ“2”本来の閾値電圧“b’”まで、これらのセルに対し書き込みを行なう。   When the data in the memory cell is “2” and the data input from the outside is “1”, the data in the memory cell remains “2”. However, in the writing of the first page, the threshold voltage of the memory cell only rises to “v ′” lower than the threshold voltage of the original data “2”. Therefore, data is written to these cells up to the data “2” original threshold voltage “b ′”.

また、メモリセルのデータが“2”の場合で、外部から入力されるデータが“0”の場合、メモリセルのデータを“3”にする。   When the data in the memory cell is “2” and the data input from the outside is “0”, the data in the memory cell is set to “3”.

(内部データリード)(S24)
先ず、セルへの書き込みの前に、第1ページのメモリセルのデータが“0”か“2”であるかを判断するため、内部リード動作を行なう。内部データリードは、リード動作と同様である。通常メモリセルのデータが“0”か“2”かの判断時において、選択ワード線には、リード時の電位“b”を与える。しかし、第1ページのプログラム動作では、ベリファイ電位を通常より低い“v’”までしか書き込んでいないため、“b”の電位より低い場合もある。したがって、内部データロードでは、ワード線に“a”の電位を供給して読み出し動作をする。
(Internal data read) (S24)
First, an internal read operation is performed to determine whether the data in the memory cell of the first page is “0” or “2” before writing to the cell. The internal data read is the same as the read operation. When determining whether the data in the normal memory cell is “0” or “2”, the potential “b” at the time of reading is applied to the selected word line. However, in the programming operation of the first page, since the verify potential is written only to “v ′” which is lower than usual, it may be lower than the potential of “b”. Therefore, in the internal data load, the read operation is performed by supplying the potential “a” to the word line.

すなわち、選択されているブロック内の非選択ワード線及びセレクト線SG1に電位Vreadを印加する。これとともに、データ記憶回路10の信号VPREをVddとし、信号BLPRE、BLCLAMPを所定の電圧、例えば1V+Vthとして、ビット線をVddにプリチャージした後、セルのソース側のセレクト線SG2をハイレベルとする。閾値電圧が電位“a”より高いセルはオフするため、ビット線はハイレベルのままである。また、閾値電圧が電位“a”より低いセルはオンするため、ビット線は放電され、接地電位Vssとなる。   That is, the potential Vread is applied to the non-selected word line and the select line SG1 in the selected block. At the same time, the signal VPRE of the data storage circuit 10 is set to Vdd, the signals BLPRE and BLCLAMP are set to a predetermined voltage, for example, 1V + Vth, the bit line is precharged to Vdd, and the select line SG2 on the source side of the cell is set to the high level. . Since the cell having the threshold voltage higher than the potential “a” is turned off, the bit line remains at the high level. In addition, since the cell whose threshold voltage is lower than the potential “a” is turned on, the bit line is discharged and becomes the ground potential Vss.

次に、データ記憶回路10の信号VPREをVdd、信号BLPREをVdd+Vthとし、TDCのノードN3をVddにプリチャージする。この後、信号BLCLAMPを0.9V+Vthとする。TDCのノードN3はビット線がローレベルの場合、ローレベルとなり、ビット線がハイレベルの場合、ハイレベルとなる。この後、TDCの電位をPDCに転送する。この結果、メモリセルのデータが“2”である場合、PDCにハイレベル信号がラッチされ、メモリセルのデータが“0”である場合、PDCにローレベル信号がラッチされる。図10(a)は、データロード、内部リード後のSDC、PDCとメモリセルのデータの関係を示している。   Next, the signal VPRE of the data storage circuit 10 is set to Vdd, the signal BLPRE is set to Vdd + Vth, and the node N3 of the TDC is precharged to Vdd. Thereafter, the signal BLCLAMP is set to 0.9 V + Vth. The node N3 of the TDC is at a low level when the bit line is at a low level, and is at a high level when the bit line is at a high level. Thereafter, the potential of TDC is transferred to the PDC. As a result, when the data in the memory cell is “2”, the high level signal is latched in the PDC, and when the data in the memory cell is “0”, the low level signal is latched in the PDC. FIG. 10A shows the relationship between SDC, PDC and memory cell data after data load and internal read.

(データキャッシュの設定)(S25)
この後、図11、図12に示すデータキャッシュ設定手順に従い各データキャッシュに記憶されたデータが操作される。すなわち、図11(a)に示すように、外部よりデータを入力し、内部リードにより読み出したデータを各データキャッシュにラッチさせた状態において、図11(b)に示すように、SDCのデータがPDCに転送され、PDCのデータがDDCに転送される。次に、図11(c)に示すように、DDCのデータが反転されてSDCに転送される。この後、PDCのデータがDDCに転送される。次に、図12(a)に示すように、DDCのデータが反転されてPDCに転送される。この後、PDCのデータがDDCに転送される。次に、図12(b)に示すように、第2のフラグセル用データ記憶回路10bに第2のフラグセルFC2用のデータがロードされ、SDCにラッチされる。次いで、図12(c)に示すように、SDCとDDCのデータが合成され、この合成されたデータが反転されて、PDCに転送される。このPDCのデータはDDCに転送される。
(Data cache setting) (S25)
Thereafter, the data stored in each data cache is operated in accordance with the data cache setting procedure shown in FIGS. That is, as shown in FIG. 11A, when data is input from the outside and the data read by the internal read is latched in each data cache, as shown in FIG. The data is transferred to the PDC, and the PDC data is transferred to the DDC. Next, as shown in FIG. 11C, the DDC data is inverted and transferred to the SDC. Thereafter, the PDC data is transferred to the DDC. Next, as shown in FIG. 12A, the DDC data is inverted and transferred to the PDC. Thereafter, the PDC data is transferred to the DDC. Next, as shown in FIG. 12B, data for the second flag cell FC2 is loaded into the second flag cell data storage circuit 10b and latched in the SDC. Next, as shown in FIG. 12C, the SDC and DDC data are combined, and the combined data is inverted and transferred to the PDC. This PDC data is transferred to the DDC.

このような操作をすることにより、各データキャッシュに記憶されるデータは図10(b)、図12(c)に示すようになる。   By performing such an operation, the data stored in each data cache is as shown in FIG. 10 (b) and FIG. 12 (c).

すなわち、メモリセルのデータを“0”にする場合(第1ページにおいてデータ“1”、第2ページにおいてデータ“1”)、PDC、DDC、SDCは全てハイレベルに設定される。   That is, when the data in the memory cell is set to “0” (data “1” in the first page and data “1” in the second page), the PDC, DDC, and SDC are all set to a high level.

メモリセルのデータを“1”にする場合(第1ページにおいてデータ“1”、第2ページにおいてデータ“0”)、PDCはローレベル、DDCはローレベル、SDCはハイレベルに設定される。   When the data in the memory cell is set to “1” (data “1” on the first page and data “0” on the second page), the PDC is set to the low level, the DDC is set to the low level, and the SDC is set to the high level.

メモリセルのデータを“2”する場合(第1ページにおいてデータ“0”、第2ページにおいてデータ“1”)、PDCはローレベル、DDCはハイレベル、SDCはローレベルに設定される。   When the data in the memory cell is “2” (data “0” in the first page, data “1” in the second page), the PDC is set to the low level, the DDC is set to the high level, and the SDC is set to the low level.

メモリセルのデータを“3”する場合(第1ページにおいてデータ“0”、第2ページにおいてデータ“0”)、PDC、DDC、SDCは全てローレベルに設定される。   When the data in the memory cell is “3” (data “0” in the first page and data “0” in the second page), the PDC, DDC, and SDC are all set to a low level.

(第2のフラグセルデータロード)(S25)
前述したように、データキャッシュの設定途中において、第2のフラグセル用データ記憶回路10b内のSDCがローレベルに設定される。これにより第2のフラグセルFC2のデータは“0”から“2”となる。第2ページの書き込みは、図1(c)に示すように、メモリセルのデータ“0”から“1”への書き込みと、メモリセルのデータ“2”から“3”への書きこみであるが、第2のフラグセルに関しては、メモリセルのデータを“0”からメモリセルのデータを“2”にプログラムする。このため、図1(d)に示すように、第2のフラグセルのデータ“2”の閾値電圧の分布は広がる可能性がある。しかし、第2のフラグセルFC2のリード動作は、必ず“b’”より低い“b”のレベルをワード線に供給して行なうため問題はない。
(Second flag cell data load) (S25)
As described above, during the setting of the data cache, the SDC in the second flag cell data storage circuit 10b is set to a low level. As a result, the data in the second flag cell FC2 changes from “0” to “2”. As shown in FIG. 1C, the second page write is a write from the memory cell data “0” to “1” and a write from the memory cell data “2” to “3”. However, with respect to the second flag cell, the memory cell data is programmed from “0” to the memory cell data “2”. For this reason, as shown in FIG. 1D, the distribution of the threshold voltage of the data “2” of the second flag cell may widen. However, there is no problem because the read operation of the second flag cell FC2 is always performed by supplying a level of “b” lower than “b ′” to the word line.

さらに、例えば各データキャッシュの設定の途中において、カウンタ(PC)が“0”に初期設定される(S25)。   Further, for example, during the setting of each data cache, the counter (PC) is initialized to “0” (S25).

この後、第1のフラグセルFC1にデータが書かれたか否かが判別される(S26)。第1のフラグセルFC1のデータは、内部リード(S24)において読み出されている。第1のフラグセルFC1にデータが書き込まれていない場合、プログラムへ移行される(S27)。しかし、第1のフラグセルFC1にデータが書き込まれている場合、図1(c)の分布になっているため、内部リードを“b”のレベルで再度行なう(S26−S23)。   Thereafter, it is determined whether data is written in the first flag cell FC1 (S26). The data of the first flag cell FC1 is read in the internal read (S24). If no data is written in the first flag cell FC1, the program proceeds to the program (S27). However, when data is written in the first flag cell FC1, since the distribution is as shown in FIG. 1C, the internal read is performed again at the "b" level (S26-S23).

(プログラム)(S27)
第1のフラグセルFC1にデータが書き込まれていない場合、メモリセルにデータが書き込まれる。例えばカウンタ(PC)をカウントアップした後、先ず、信号BLC1をVsgとすると、PDCがデータ“0”の場合、ビット線がVssとなり、データ“1”の場合、ビット線はVddになる。次に、信号BLC1=Vssとした後、信号VREG=Vdd、信号REG=中間電位+Vth(1V+Vth)とする。すると、DDCがデータ“1”の場合、ビット線がVddとなり、DDCがデータ“0”の場合、ビット線はプリチャージされない。この結果、メモリセルにデータ“1”,“3”を書き込んでいるときのみ、ビット線はVssとなる。メモリセルにデータ“2”を書き込んでいる場合、ビット線は中間電位(1V)となり、メモリセルのデータが“0”の場合(書き込みしない場合)、ビット線はVddになる。ここで、選択ワード線をVpgm、非選択ワード線をVpassとすると、ビット線がVddの場合、書き込みが行なわれない。また、ビット線がVssの場合、書き込みが起こり、ビット線が中間電位(1V)の場合、少しだけ書き込まれる。したがって、データ“2”を書き込んでいるメモリセルは、あまり書き込まれない可能性がある。しかし、これは、データ“2”とデータ“3”のベリファイを一括して行なうため、出来るだけ同時に書き込まれたほうが書き込み時間が早く終わる。したがって、ビット線に中間電位を供給する。
(Program) (S27)
When data is not written in the first flag cell FC1, data is written in the memory cell. For example, after counting up the counter (PC), first, when the signal BLC1 is set to Vsg, when the PDC is data “0”, the bit line becomes Vss, and when the data is “1”, the bit line becomes Vdd. Next, after setting the signal BLC1 = Vss, the signal VREG = Vdd and the signal REG = intermediate potential + Vth (1V + Vth). Then, when the DDC is data “1”, the bit line becomes Vdd, and when the DDC is data “0”, the bit line is not precharged. As a result, the bit line becomes Vss only when data “1” and “3” are written in the memory cell. When data “2” is written to the memory cell, the bit line is at an intermediate potential (1 V), and when the data in the memory cell is “0” (when not written), the bit line is Vdd. Here, if the selected word line is Vpgm and the non-selected word line is Vpass, writing is not performed when the bit line is Vdd. In addition, when the bit line is Vss, writing occurs, and when the bit line is at the intermediate potential (1 V), writing is slightly performed. Therefore, the memory cell in which the data “2” is written may not be written much. However, since the data “2” and the data “3” are verified at once, the writing time ends earlier if they are written simultaneously. Therefore, an intermediate potential is supplied to the bit line.

この後、メモリセルにデータ“1”が書き込まれており(S28)、さらに、カウンタ(PC)の値が予め定められたベリファイ電圧“a’”によるベリファイ回数の最大値より小さい場合(S29)、ベリファイ電圧“a*’”と“a’”を順次設定して書き込みベリファイが行なわれる(S30)。   Thereafter, data “1” is written in the memory cell (S28), and further, the value of the counter (PC) is smaller than the maximum number of verify times by the predetermined verify voltage “a ′” (S29). Then, the verify voltages “a * ′” and “a ′” are sequentially set and the write verify is performed (S30).

尚、以下に説明するベリファイ動作は、ベリファイ電圧を“a*’”、“a’”、“b’”、“b’”、“c’”の順に設定して実行される。このとき、不要なベリファイ動作をスキップしてプログラム及びベリファイするため、カウンタ(PC)の値が予め定められた値と比較される(S29,S31,S32、S34、S37)。例えばベリファイ“a*’、a’”のベリファイ回数が最大ループ回数に達した場合、ベリファイ“a*’”、“a’”をスキップする。また、例えばベリファイ“b’”のベリファイ開始回数に達していない場合、ベリファイ“b’”をスキップして、プログラムが実行される。このスキップの制御に必要な各値は例えば次に示すように設定されている。   The verify operation described below is executed by setting the verify voltages in the order of “a * ′”, “a ′”, “b ′”, “b ′”, “c ′”. At this time, since the unnecessary verify operation is skipped for programming and verifying, the value of the counter (PC) is compared with a predetermined value (S29, S31, S32, S34, S37). For example, when the number of verifications of the verification “a * ′, a ′” reaches the maximum number of loops, the verification “a * ′”, “a ′” is skipped. For example, when the verify start count of the verify “b ′” has not been reached, the verify “b ′” is skipped and the program is executed. Each value necessary for this skip control is set as follows, for example.

ベリファイ“a’”の最大ループ回数=10
ベリファイ“b’”によるベリファイ開始回数=4
ベリファイ“c’”によるベリファイ開始回数=8
最大プログラムロープ回数=20
(ベリファイ“a*’”、“a’”)(S30)
このベリファイにおいて、信号VPREをハイレベル、信号BLCLAMPを所定電位に設定すると、ビット線がプリチャージされる。
Maximum number of loops for verify “a ′” = 10
Number of verify starts by verify “b ′” = 4
Number of verify starts by verify “c ′” = 8
Maximum program rope count = 20
(Verify “a * ′”, “a ′”) (S30)
In this verification, when the signal VPRE is set to a high level and the signal BLCLAMP is set to a predetermined potential, the bit line is precharged.

図13(a)は、ベリファイ電圧“a*’”によるベリファイ後、各データキャッシュに設定されたデータを示している。   FIG. 13A shows data set in each data cache after verification by the verify voltage “a * ′”.

次に、ワード線の電位をベリファイ電位“a*’”に設定し、ビット線を放電する。信号VPRE=Vdd、信号BLPRE=VsgとしてTDCをVddに充電した後、信号BLCLAMPに所定の電圧を与える。ビット線がVssの場合、TDCはVss(ローレベル)になり、ビット線にプリチャージ電位が残っている場合、TDCはVdd(ハイレベル)となる。ここで、信号BLC2をVth+0.5Vとすると、SDCが“0”の場合(メモリセルにデータ“2”、“3”を書き込んでいる場合)、TDCはVssとなる。したがって、TDCがVddとなるのは、メモリセルにデータ“1”が書き込まれていてベリファイ電位“a*’”に達した時である。メモリセルにデータ“1”を書き込んでいない場合、ビット線はプリチャージされていないため、TDCはローレベルとなっている。また、メモリセルにデータ“1”を書き込んでいてベリファイ電位“a*’”に達しない場合もTDCはVssとなる。   Next, the potential of the word line is set to the verify potential “a * ′”, and the bit line is discharged. After charging the TDC to Vdd with the signal VPRE = Vdd and the signal BLPRE = Vsg, a predetermined voltage is applied to the signal BLCLAMP. When the bit line is Vss, TDC becomes Vss (low level), and when the precharge potential remains in the bit line, TDC becomes Vdd (high level). Here, when the signal BLC2 is Vth + 0.5V, when SDC is “0” (when data “2” and “3” are written in the memory cell), TDC becomes Vss. Therefore, TDC becomes Vdd when data “1” is written in the memory cell and reaches verify potential “a * ′”. When data “1” is not written in the memory cell, the bit line is not precharged, so that TDC is at a low level. The TDC is also Vss when data “1” is written in the memory cell and the verify potential “a * ′” is not reached.

ここで、信号VREGをハイレベルとし、信号REG=ハイレベルとすると、DDCのデータが“1”の場合、強制的にTDCがハイレベルになる。したがって、TDCがVddになるのは、メモリセルにデータ“1”を書き込んでいてベリファイ電位“a*’”に達した時と、DDCのデータが“1”の場合、つまりメモリセルへデータ“2”を書き込んでいた場合である。次いで、信号DTGをVsgとし、PDCのデータをDDCにコピーする。この後、信号BLC1をVsgとしてTDCの電位をPDCに取りこむ。   Here, when the signal VREG is set to a high level and the signal REG is set to a high level, when the data of the DDC is “1”, the TDC is forcibly set to a high level. Therefore, TDC becomes Vdd when data “1” is written to the memory cell and the verify potential “a * ′” is reached, and when the data of DDC is “1”, that is, data “ This is a case where 2 ”is written. Next, the signal DTG is set to Vsg, and the PDC data is copied to the DDC. Thereafter, the signal BLC1 is set to Vsg, and the potential of TDC is taken into the PDC.

図13(b)において、PDCがデータ“1”となるのは、メモリセルにデータ“1”を書き込んでいて、ベリファイ電位“a*’”を超えている場合と、メモリセルにデータ“2”を書き込んでいる場合である。   In FIG. 13B, the PDC becomes data “1” when the data “1” is written in the memory cell and exceeds the verify potential “a * ′”, and the data “2” is stored in the memory cell. "Is written.

次に、ワード線の電位を少し上げてベリファイ電位“a’”とし、ビット線を放電する。信号VPRE=Vdd、信号BLPRE=VsgとしてTDCを再びVddに充電した後、信号BLCLAMPに所定の電圧を与える。ビット線がVssの場合、TDCはVssとなり、ビット線にプリチャージ電位が残っている場合、TDCはVddになる。ここで、信号BLC2をVth+0.5Vとすると、SDCが“0”の場合(メモリセルのデータ“2”、“3”に書き込んでいる場合)、TDCはVssになる。したがって、TDCがVddになるのは、メモリセルにデータ“1”が書き込まれていてベリファイ電位“a’”に達した時である。メモリセルにデータ“1”を書き込んでいない場合と、メモリセルにデータ“1”を書き込んでいてベリファイ電位“a’”に達しない場合もTDCはVssとなる。   Next, the potential of the word line is slightly increased to a verify potential “a ′”, and the bit line is discharged. After the signal VPRE = Vdd and the signal BLPRE = Vsg, the TDC is charged again to Vdd, and then a predetermined voltage is applied to the signal BLCLAMP. When the bit line is Vss, TDC becomes Vss, and when the precharge potential remains in the bit line, TDC becomes Vdd. Here, assuming that the signal BLC2 is Vth + 0.5V, when SDC is “0” (when data is written in data “2” and “3” of the memory cell), TDC becomes Vss. Therefore, TDC becomes Vdd when data “1” is written in the memory cell and reaches verify potential “a ′”. TDC is also Vss when data “1” is not written into the memory cell and when data “1” is written into the memory cell and the verify potential “a ′” is not reached.

ここで、信号VREGをハイレベルとし、信号REG=ハイレベルとすると、DDCのデータが“1”の場合、すなわち、メモリセルにデータを書き込んでいない場合、TDCは強制的にハイレベルとされる。したがって、TDCがVddになるのは、書き込み非選択の場合と、メモリセルにデータ“1”を書き込んでいてベリファイ電位“a’”に達した場合である。   Here, when the signal VREG is set to the high level and the signal REG is set to the high level, when the data of the DDC is “1”, that is, when data is not written in the memory cell, the TDC is forcibly set to the high level. . Therefore, TDC becomes Vdd when data is not selected and when data “1” is written in the memory cell and reaches verify potential “a ′”.

次いで、信号DTGをVsgとし、PDCのデータをDDCにコピーした後に、信号BLC1をVsgとしてTDCの電位をPDCに取りこむ(図14)。   Next, after the signal DTG is set to Vsg and the data of the PDC is copied to the DDC, the signal BLC1 is set to Vsg and the potential of the TDC is taken into the PDC (FIG. 14).

メモリセルにデータ“1”を書き込んでいるセルにおいて、閾値電圧がベリファイ電位“a*’”より高くなると、DDCのデータが“1”(ハイレベル)となる。また、メモリセルにデータ“1”を書き込んでいるセルにおいて、ベリファイ電位“a’”を用いた書き込みが全て終了すると、PDCのデータは“1”(ハイレベル)になる。   In the cell in which data “1” is written in the memory cell, when the threshold voltage becomes higher than the verify potential “a * ′”, the DDC data becomes “1” (high level). In addition, in the cell in which data “1” is written in the memory cell, when all writing using the verify potential “a ′” is completed, the data in the PDC becomes “1” (high level).

この後、カウンタ(PC)の値が予め定められたベリファイ電圧“b’”によるベリファイ開始回数より大きく(S31)、予め定められたベリファイ電圧“c’”によるベリファイ開始回数より小さい場合(S32)、ベリファイ電位“b”を設定して書き込みベリファイが行なわれる(S33)。   Thereafter, when the value of the counter (PC) is larger than the number of verification starts by the predetermined verify voltage “b ′” (S31) and smaller than the number of verification starts by the predetermined verify voltage “c ′” (S32). Then, the verify potential “b” is set and the write verify is performed (S33).

(ベリファイ“b’”)(S33)
ベリファイ電位“b”を用いたベリファイ(図15)。メモリセルに対するデータ“2”の書き込みが、データ“3”の書き込みより先に終わるため、先ず、ベリファイ電位“b”のみのベリファイを行なう。信号VPRE=Vdd、信号BLCLAMPを所定の電位に設定する。すると、ビット線がプリチャージされる。次に、ワード線にベリファイ電位“b’”を供給しビット線を放電する。ビット線の放電中にDDCのデータをTDCに移す。この後、PDCのデータをDDCに移し、TDCのデータをPDCに移す。次いで、TDCをVddに充電する。この後、信号BLCLAMPを所定の電位とする。すると、TDCがハイレベルになるのは、セルの閾値電圧が、ベリファイ電位“b’”以上にある場合である。ここで、信号BLC1=Vth+0.5Vとすると、PDCが“0”の場合(メモリセルにデータ“3”を書き込んでいる場合と、メモリセルにデータ“1”を書き込んでいる場合で、ベリファイ電位“a*’”以下の場合)、TDCはVssになる。したがって、TDCがVddになるのは、メモリセルにデータ“2”が書き込まれていてベリファイ電位“b’”に達した時である。次に、信号VREGをハイレベルとし、信号REGをVsgとすると、DDCのデータがハイレベルの場合、強制的にTDCがハイレベルとなる。したがって、TDCがVddになるのは、メモリセルにデータ“2”を書き込んでいてベリファイ電位“b’”に達した時と、書き込み非選択の場合である。信号DTGをVsgとし、PDCのデータをDDCにコピーした後、信号BLC1をVsgとしてTDCの電位をPDCに取りこむ。
(Verify “b ′”) (S33)
Verify using verify potential “b” (FIG. 15). Since writing of data “2” to the memory cell is completed before writing of data “3”, first, only verify potential “b” is verified. The signal VPRE = Vdd and the signal BLCLAMP are set to a predetermined potential. Then, the bit line is precharged. Next, the verify potential “b ′” is supplied to the word line to discharge the bit line. DDC data is transferred to TDC during bit line discharge. Thereafter, the PDC data is transferred to the DDC, and the TDC data is transferred to the PDC. The TDC is then charged to Vdd. Thereafter, the signal BLCLAMP is set to a predetermined potential. Then, the TDC becomes high level when the threshold voltage of the cell is equal to or higher than the verify potential “b ′”. Here, assuming that the signal BLC1 = Vth + 0.5V, when the PDC is “0” (when data “3” is written in the memory cell and when data “1” is written in the memory cell), In the case of “a * ′” or less), TDC becomes Vss. Therefore, TDC becomes Vdd when data “2” is written in the memory cell and reaches verify potential “b ′”. Next, when the signal VREG is set to high level and the signal REG is set to Vsg, when the data of the DDC is high level, the TDC is forcibly set to high level. Therefore, TDC becomes Vdd when data “2” is written in the memory cell and the verify potential “b ′” is reached, and when writing is not selected. After the signal DTG is set to Vsg and the data of the PDC is copied to the DDC, the signal BLC1 is set to Vsg and the potential of the TDC is taken into the PDC.

この後、カウンタ(PC)の値がベリファイ電圧“c’”によるベリファイ開始回数より大きい場合(S34)、ベリファイ電位“b”、“c”を用いた同時ベリファイが行なわれる(S34、S35)。   Thereafter, when the value of the counter (PC) is larger than the number of times of verify start by the verify voltage “c ′” (S34), the simultaneous verify using the verify potentials “b” and “c” is performed (S34, S35).

(ベリファイ電位“b”“c”同時ベリファイ)(図16)。 (Verify potential “b” and “c” simultaneous verify) (FIG. 16).

プログラム及びベリファイファイを何回か繰り返していると、メモリセルのデータ“3”に書き込みを行っているセルも書き込みが終了するため、前記ベリファイ電位“b”を用いたベリファイの替わり、ベリファイ電位“b”“c”同時ベリファイを行なう。先ず、信号BLPRE=ハイレベル、信号BLCLAMPを所定電位に設定し、ビット線をプリチャージする。   If the program and the verify are repeated several times, the write to the data “3” in the memory cell is also completed. Therefore, instead of verify using the verify potential “b”, the verify potential “ b "" c "Simultaneous verification is performed. First, the signal BLPRE = high level, the signal BLCLAMP is set to a predetermined potential, and the bit line is precharged.

次に、ワード線にベリファイ電位“b’”を供給しビット線を放電する。ビット線の放電中にDDCのデータをTDCに移す。この後、PDCのデータをDDCに移し、TDCのデータをPDCに移す。   Next, the verify potential “b ′” is supplied to the word line to discharge the bit line. DDC data is transferred to TDC during bit line discharge. Thereafter, the PDC data is transferred to the DDC, and the TDC data is transferred to the PDC.

この後、TDCをVddに充電した後、BLCLAMPに所定の電位を供給する。すると、TDCがハイレベルになるのは、閾値電圧がベリファイ電位“b’”以上の場合である。ここで、信号BLC1=Vth+0.5Vとすると、PDCが“0”の場合(メモリセルのデータ“3”に書き込んでいる場合と、メモリセルにデータ“1”を書き込んでいる場合で、ベリファイ電位“a*’”以下の場合)、TDCはVssになる。したがって、TDCがVddになるのは、メモリセルがデータ“2”に書き込まれていて、ベリファイ電位“b’”に達した時である。次に、信号VREGをハイレベルとし、信号REGをVsgとすると、DDCのデータがハイレベルの場合、強制的にTDCがハイレベルとなる。したがって、TDCがVddになるのは、メモリセルにデータ“2”を書き込んでいてベリファイ電位“b’”に達した時と、書き込み非選択の場合である。信号DTGをVsgとし、PDCのデータをDDCにコピーした後、信号BLC1をVsgとしてTDCの電位をPDCに取りこむ。   Thereafter, the TDC is charged to Vdd, and then a predetermined potential is supplied to BLCLAMP. Then, the TDC becomes high level when the threshold voltage is equal to or higher than the verify potential “b ′”. Here, assuming that the signal BLC1 = Vth + 0.5V, when the PDC is “0” (when the data “3” is written to the memory cell and when the data “1” is written to the memory cell), In the case of “a * ′” or less), TDC becomes Vss. Therefore, TDC becomes Vdd when the memory cell is written in data “2” and reaches verify potential “b ′”. Next, when the signal VREG is set to high level and the signal REG is set to Vsg, when the data of the DDC is high level, the TDC is forcibly set to high level. Therefore, TDC becomes Vdd when data “2” is written in the memory cell and the verify potential “b ′” is reached, and when writing is not selected. After the signal DTG is set to Vsg and the data of the PDC is copied to the DDC, the signal BLC1 is set to Vsg and the potential of the TDC is taken into the PDC.

次に、ワード線にベリファイ電位“c’”を供給しビット線を放電する。ビット線の放電中にDDCのデータをTDCに移す。この後、PDCのデータをDDCに移し、TDCのデータをPDCに移す。   Next, the verify potential “c ′” is supplied to the word line to discharge the bit line. DDC data is transferred to TDC during bit line discharge. Thereafter, the PDC data is transferred to the DDC, and the TDC data is transferred to the PDC.

この後、TDCをVddに充電した後、BLCLAMPに所定の電位を供給する。TDCがVddになるのは、メモリセルのデータが“3”に書き込まれていてベリファイ電位“c’”に達した時である。次に、信号VREGをハイレベルとし、信号REGをVsgとすると、DDCのデータがハイレベルの場合、強制的にTDCがハイレベルとなる。したがって、TDCがVddになるのは、メモリセルにデータ“2”を書き込んでいてベリファイ電位“c’”に達した時と、書き込み非選択の場合である。信号DTGをVsgとし、PDCのデータをDDCにコピーした後、信号BLC1をVsgとしてTDCの電位をPDCに取りこむ。   Thereafter, the TDC is charged to Vdd, and then a predetermined potential is supplied to BLCLAMP. The TDC becomes Vdd when the data in the memory cell is written to “3” and reaches the verify potential “c ′”. Next, when the signal VREG is set to high level and the signal REG is set to Vsg, when the data of the DDC is high level, the TDC is forcibly set to high level. Therefore, TDC becomes Vdd when data “2” is written in the memory cell and the verify potential “c ′” is reached, and when writing is not selected. After the signal DTG is set to Vsg and the data of the PDC is copied to the DDC, the signal BLC1 is set to Vsg and the potential of the TDC is taken into the PDC.

このようにして、全てのPDCのデータが“1”になるまで、プログラムとベリファイ動作を繰り返す(S36,S37)。しかし、書き込み動作において、DDCのデータが“1”の場合、つまり、メモリセルにデータ“2”を書き込んでいる場合と、メモリセルにデータ“1”を書き込んでいてベリファイ電位“a*’”を超えている場合、ビット線を中間電位にして書き込み動作をする。   In this way, the program and verify operation are repeated until the data of all PDCs becomes “1” (S36, S37). However, in the write operation, when the DDC data is “1”, that is, when the data “2” is written in the memory cell, the data “1” is written in the memory cell and the verify potential “a * ′” If it exceeds the threshold value, the write operation is performed with the bit line set to an intermediate potential.

また、プログラムとベリファイ動作を繰り返す毎に、プログラム電圧Vpgmを少しずつ上昇させる。このプログラム電圧Vpgmの増分ΔVpgmは、第1ページの書き込み動作と、第2の書き込み動作で相違されており、例えば第1ページの書き込み動作における増分ΔVpgmは、第2の書き込み動作における増分ΔVpgmより大きく設定されている。   Further, each time the program and verify operations are repeated, the program voltage Vpgm is gradually increased. The increment ΔVpgm of the program voltage Vpgm is different between the first page write operation and the second write operation. For example, the increment ΔVpgm in the first page write operation is larger than the increment ΔVpgm in the second write operation. Is set.

図9のアルゴリズムでは、プログラムとベリファイ“a*,a’”を数回繰り返した後に、プログラムとベリファイ“a*’,a’”とプログラムベリファイ“b’”を数回繰り返し、プログラムとベリファイ“a*’,a’”とプログラムベリファイ“b’,c’”を数回繰り返す。この途中でメモリセルへのデータ“1”の書き込みは、早く終了する。このため、データ“1”を書き込むべきセルが無くなった場合、プログラムベリファイ“a*’,a’”をスキップし、プログラムとプログラムベリファイ“b’”、又はプログラムとプログラムベリファイ“b’,c’”を繰り返すようになる。プログラムとベリファイ“a*’,a’”をスキップする場合、SDCは使用しなくなる。このため、次のプログラムデータを入力することができる。しかし、稀に、メモリセルにデータ“1”がなかなか書けないセルもある。したがって、プログラムベリファイ“a*,a’”の回数を制限している(S29)。   In the algorithm of FIG. 9, the program and verify “a *, a ′” are repeated several times, and then the program, verify “a * ′, a ′”, and program verify “b ′” are repeated several times. Repeat a * ', a' "and program verify" b ', c' "several times. In the middle of this, the writing of data “1” to the memory cell is completed early. Therefore, when there is no cell to which data “1” is to be written, the program verify “a * ′, a ′” is skipped, and the program and program verify “b ′” or the program and program verify “b ′, c ′” are skipped. "Will be repeated. When the program and verify “a * ′, a ′” are skipped, the SDC is not used. Therefore, the next program data can be input. However, rarely, there are some cells in which data “1” cannot be written easily. Therefore, the number of program verifications “a *, a ′” is limited (S29).

上記第1の実施形態において、初めに第1ページ(ロアーページ)のデータをメモリセルに書き込み、この後、第2ページ(アッパーページ)のデータをメモリセルに書き込むとき、第1ページのデータを読み出し、3つのレベルの閾値電圧を書き込んでいた。しかし、第1ページのデータと第2ページのデータを同時にメモリセルに書き込むことも可能である。   In the first embodiment, when the first page (lower page) data is first written to the memory cell, and then the second page (upper page) data is written to the memory cell, the first page data is Reading and writing three levels of threshold voltages. However, the first page data and the second page data can be simultaneously written in the memory cell.

図17は、第1の実施形態の変形例を示すものであり、図9と同一部分には同一符号を付している。図17に示すように、先ず、データ記憶回路をリセットし、カウンタ(PC)を初期設定する(S51)。この後、第1ページのデータをSDCにロードし(S52)、次いで、第1ページのデータをSDCからPDCに転送する(S53)。次に、第2ページのデータをSDCにロードする(S54)。この後、各データキャッシュを図10(b)に示すように設定し(S55)、このデータキャッシュのデータに従ってプログラムを実行する(S56)。   FIG. 17 shows a modification of the first embodiment, and the same components as those in FIG. 9 are denoted by the same reference numerals. As shown in FIG. 17, first, the data storage circuit is reset and the counter (PC) is initialized (S51). Thereafter, the first page data is loaded into the SDC (S52), and then the first page data is transferred from the SDC to the PDC (S53). Next, the data of the second page is loaded into the SDC (S54). Thereafter, each data cache is set as shown in FIG. 10B (S55), and the program is executed according to the data in the data cache (S56).

このような方法によれば、第1ページのデータと第2ページのデータを同時にメモリセルに書き込んでいるため、第1ページのみの書き込み動作、及び内部データリードにより第1ページのデータを読み出す必要がない。したがって、高速な書き込みが可能である。   According to such a method, since the first page data and the second page data are simultaneously written in the memory cell, it is necessary to read the first page data by the write operation of only the first page and the internal data read. There is no. Therefore, high-speed writing is possible.

(第1ページリード)
図18(a)は、第1ページリードのダイアグラムを示している。先ず、アドレスを指定し、図3に示す2ページを選択する。図1(b)(c)に示すように、第2ページの書き込み前と後で、閾値電圧の分布が変わっている。したがって、先ず、ワード線の電位を“b”として読み出し動作を行ない第2のフラグセルのデータが“0”か“1”であるかを判別する(S71、S72)。この判別において、フラグセルが複数セルある場合は、これらの多数決により、“0”か“1”を判断する。
(First page lead)
FIG. 18A shows a diagram of the first page lead. First, an address is designated and two pages shown in FIG. 3 are selected. As shown in FIGS. 1B and 1C, the distribution of threshold voltages changes before and after the writing of the second page. Therefore, first, the read operation is performed with the word line potential set to “b” to determine whether the data of the second flag cell is “0” or “1” (S71, S72). In this determination, when there are a plurality of flag cells, “0” or “1” is determined by these majority decisions.

第2のフラグセルから読み出されたデータが“0”(メモリセルのデータが“2”)の場合、第2ページの書き込みは行われている。このため、セルの閾値電圧の分布は、図1(c)となっている。このようなセルのデータを判断するには、ワード線の電位を“b”でリード動作をすればよい。しかし、ステップS71において、ワード線電位“b”で読み出し動作をした結果は、既にデータ記憶回路に読み出されている。このため、データ記憶回路に記憶されているデータを外部に出力すれば良い(S73)。   When the data read from the second flag cell is “0” (the data in the memory cell is “2”), the second page is written. For this reason, the distribution of the threshold voltage of the cell is as shown in FIG. In order to determine such cell data, a read operation may be performed with the word line potential set to “b”. However, the result of the read operation at the word line potential “b” in step S71 has already been read out to the data storage circuit. For this reason, the data stored in the data storage circuit may be output to the outside (S73).

一方、フラグセルから読み出されたデータが“1”(メモリセルのデータが“0”)の場合、第2ページの書き込みが行われていない、セルの閾値電圧分布は、図1(a)又は(b)に示すようになっている。これらのメモリのデータを判断するには、ワード線の電位を“a”でリード動作をしなくてはならない。したがって、ワード線の電位を“a”として読み出し動作を行ない(S74)、この後、データ記憶回路に読み出されたデータが外部に出力される(S73)。   On the other hand, when the data read from the flag cell is “1” (data in the memory cell is “0”), the threshold voltage distribution of the cell in which the second page is not written is shown in FIG. As shown in (b). In order to determine the data in these memories, the read operation must be performed with the word line potential set to “a”. Therefore, a read operation is performed with the word line potential set to “a” (S74), and then the data read to the data storage circuit is output to the outside (S73).

(リード動作:第1ページリード)
上記のように、第1ページのリード動作は、選択ワード線にリード電位“a”又は“b”を供給して読み出し動作が実行される。
(Read operation: 1st page read)
As described above, the read operation for the first page is performed by supplying the read potential “a” or “b” to the selected word line.

先ず、選択されているブロック内の非選択ワード線及びセレクト線SG1に読み出し電圧Vreadを供給し、図6に示すデータ記憶回路の信号BLPREを1V+Vth、BLCLAMPをVdd+Vthとして、ビット線をプリチャージする。この後、セルのソース側のセレクト線SG2をハイレベルにする。閾値電圧が電位“a”又は“b”より高いセルはオフするため、ビット線はハイレベルのままである。また、閾値電圧が電位“a”又は“b”より低いセルはオンするため、ビット線がVssとなる。   First, the read voltage Vread is supplied to the non-selected word line and the select line SG1 in the selected block, and the bit line is precharged by setting the signal BLPRE of the data storage circuit shown in FIG. 6 to 1V + Vth and BLCLAMP to Vdd + Vth. Thereafter, the select line SG2 on the source side of the cell is set to the high level. Since the cell whose threshold voltage is higher than the potential “a” or “b” is turned off, the bit line remains at the high level. In addition, since the cell whose threshold voltage is lower than the potential “a” or “b” is turned on, the bit line becomes Vss.

次に、データ記憶回路10の信号BLPREをVdd+Vthとしてトランジスタ61uをオンとすることにより、TDCのノードN3をVddにプリチャージする。この後、信号BLCLAMPを中間電位(例えば0.9V+Vth)としてトランジスタ61tをさせる。TDCのノードN3はビット線がローレベルの場合ローレベルとなり、ビット線がハイレベルの場合ハイレベルとなる。   Next, the signal BLPRE of the data storage circuit 10 is set to Vdd + Vth to turn on the transistor 61u, thereby precharging the node N3 of the TDC to Vdd. Thereafter, the signal BLCLAMP is set to an intermediate potential (for example, 0.9 V + Vth) to cause the transistor 61t. The node N3 of the TDC is at a low level when the bit line is at a low level, and is at a high level when the bit line is at a high level.

次に、信号BLC1をVsg(Vdd+Vth)としてTDCの電位をPDCに取りこむ。この後、PDCのデータをSDCに移動させるが、第2のフラグセルFC2のデータが“1”の場合(書きこまれていない場合)、リードレベルを変更してもう一度セルから読み出す。   Next, the signal BLC1 is set to Vsg (Vdd + Vth), and the potential of the TDC is taken into the PDC. Thereafter, the data of the PDC is moved to the SDC. When the data of the second flag cell FC2 is “1” (when not written), the read level is changed and the data is read from the cell again.

(第2ページリード)
図18(b)は、第2ページリードのダイアグラムを示している。第2ページリードでは、先ず、アドレスを指定し、図3に示す2ページを選択する。図1(b)(c)に示すように、第2ページの書き込み前と後で、閾値電圧の分布が変わっている。しかし、第2ページの書き込み後は、図1(c)に示すような分布になっている。このため、ワード線の電位を“a”、“b”、“c”と三回替えて読み出し動作をしなくてはならない。しかし、書き込み時、“c”でのベリファイは、“b”でのベリファイの後に続けてワード線の電位を変更させるのみで行っていた。したがって、リード動作もベリファイ動作と同じ動作であるほうが望ましいため、“b”、“c”のリード動作は、同時に行なう。
(2nd page lead)
FIG. 18B shows a diagram of the second page lead. In the second page read, first, an address is specified and two pages shown in FIG. 3 are selected. As shown in FIGS. 1B and 1C, the distribution of threshold voltages changes before and after the writing of the second page. However, after the second page is written, the distribution is as shown in FIG. For this reason, the read operation must be performed by changing the word line potential to “a”, “b”, and “c” three times. However, at the time of writing, the verification at “c” is performed only by changing the potential of the word line after the verification at “b”. Therefore, since it is desirable that the read operation is the same as the verify operation, the read operations of “b” and “c” are performed simultaneously.

すなわち、先ず、ワード線電位を“b”“c”として同時に読み出しを行ない(S81)。この後、ワード線電位を“a”として読み出し動作を行なう(S82)。メモリセルの閾値電圧がワード線電位“a”より低いか、ワード線電位“b”より高くワード線電位“c”より低い場合、データを“1”とする。また、メモリセルの閾値電圧がワード線電位“a”より高くワード線電位“b”より低いか、ワード線電位“c”より高く場合、データを“0”とする。第2ページ書込み前において、第2ページのデータは“1”が出力されるべきである。しかし、図1(a)に示す閾値電圧分布になっている。このため、第2ページの書き込み後と同じ読み出し動作をすると出力データが“0”となることもある。したがって、第1のフラグセルFC1のデータが“0”か“1”であるかを判別する(S83)。この結果、第1のフラグセルFC1のデータが“1”で、第2ページの書き込みが行なわれていない場合、出力データを“1”に固定する(S84)。出力データを“1”に固定するには、データ記憶回路の信号PRSTをハイレベルとし、SDCを“1”に設定する。あるいは、図2に示すデータ入出力バッファよりデータ“1”しか出力させないようにする。また、第1のフラグセルFC1のデータが“0”の場合、読み出したデータを出力する(S85)。   That is, first, the word line potential is set to “b” and “c” and reading is simultaneously performed (S81). Thereafter, the read operation is performed with the word line potential set to “a” (S82). When the threshold voltage of the memory cell is lower than the word line potential “a” or higher than the word line potential “b” and lower than the word line potential “c”, the data is set to “1”. If the threshold voltage of the memory cell is higher than the word line potential “a” and lower than the word line potential “b” or higher than the word line potential “c”, the data is set to “0”. Before writing the second page, “1” should be output as the data of the second page. However, the threshold voltage distribution shown in FIG. For this reason, when the same read operation as that after the second page is written, the output data may become “0”. Therefore, it is determined whether the data of the first flag cell FC1 is “0” or “1” (S83). As a result, when the data in the first flag cell FC1 is “1” and the second page is not written, the output data is fixed to “1” (S84). In order to fix the output data to “1”, the signal PRST of the data storage circuit is set to the high level and the SDC is set to “1”. Alternatively, only data “1” is output from the data input / output buffer shown in FIG. If the data in the first flag cell FC1 is “0”, the read data is output (S85).

第2ページリードは、具体的には、次のような動作を実行する。   Specifically, the second page read performs the following operation.

(リード動作:第2ページリード第1回目)
第2ページのリード動作の1回目は、プログラムベリファイ時の“b”“c”同時ベリファイと同じように、ビット線をプリチャージした後、ワード線にリード電位“b”を供給する。この状態で、メモリセルからデータを読み出し、途中でワード線の電位をリード電位“c”に変更して読み出し動作をする(S81)。
(Read operation: 2nd page read 1st time)
In the first read operation of the second page, the bit line is precharged and then the read potential “b” is supplied to the word line in the same manner as the “b” “c” simultaneous verify at the program verify. In this state, data is read from the memory cell, and the word line potential is changed to the read potential “c” in the middle to perform a read operation (S81).

先ず、選択されているブロック内の非選択ワード線及びセレクト線SG1に読み出し電圧Vreadを供給し、図6に示すデータ記憶回路の信号BLPREを1V+Vth、BLCLAMPをVdd+Vthとして、ビット線をプリチャージする。この後、メモリセルのソース側のセレクト線SG2をハイレベルにする。閾値電圧が電位“b”より高いセルはオフするため、ビット線はハイレベルのままである。また、閾値電圧が電位“b”より低いセルはオンするため、ビット線がVssとなる。   First, the read voltage Vread is supplied to the non-selected word line and the select line SG1 in the selected block, and the bit line is precharged by setting the signal BLPRE of the data storage circuit shown in FIG. 6 to 1V + Vth and BLCLAMP to Vdd + Vth. Thereafter, the select line SG2 on the source side of the memory cell is set to the high level. Since the cell whose threshold voltage is higher than the potential “b” is turned off, the bit line remains at the high level. In addition, since the cell whose threshold voltage is lower than the potential “b” is turned on, the bit line becomes Vss.

次に、データ記憶回路の信号BLPREをVdd+Vthとしてトランジスタ61uをオンとすることにより、TDCのノードN3をVddにプリチャージする。この後、信号BLCLAMPを0.9V+Vthとしてトランジスタ61tをさせる。TDCのノードN3はビット線がローレベルの場合ローレベルとなり、ビット線がハイレベルの場合ハイレベルとなる。次に、信号BLC1をVsg(Vdd+Vth)としてTDCの電位をPDCに取りこむ。   Next, the signal BLPRE of the data storage circuit is set to Vdd + Vth to turn on the transistor 61u, thereby precharging the node N3 of the TDC to Vdd. Thereafter, the signal BLCLAMP is set to 0.9 V + Vth to cause the transistor 61t. The node N3 of the TDC is at a low level when the bit line is at a low level, and is at a high level when the bit line is at a high level. Next, the signal BLC1 is set to Vsg (Vdd + Vth), and the potential of the TDC is taken into the PDC.

次に、ワード線電位を“c”に変更する。閾値電圧が電位“c”より高いセルはオフするため、ビット線はハイレベルのままである。また、閾値電圧が電位“b”より低いセルはオンするため、ビット線がVssとなる。このビット線放電時間中に、信号DTG=Vdd+Vthとして、PDCのデータをDDCにコピーする。   Next, the word line potential is changed to “c”. Since the cell having the threshold voltage higher than the potential “c” is turned off, the bit line remains at the high level. In addition, since the cell whose threshold voltage is lower than the potential “b” is turned on, the bit line becomes Vss. During this bit line discharge time, the data of PDC is copied to DDC as signal DTG = Vdd + Vth.

次に、データ記憶回路10の信号BLPREをVdd+Vthとしてトランジスタ61uをオンとすることにより、TDCのノードN3をVddにプリチャージする。この後、信号BLCLAMPを0.9V+Vthとしてトランジスタ61tをさせる。TDCのノードN3はビット線がローレベルの場合ローレベルとなり、ビット線がハイレベルの場合ハイレベルとなる。次に、信号BLC1をVsg(Vdd+Vth)としてTDCの電位をPDCに取りこむ。   Next, the signal BLPRE of the data storage circuit 10 is set to Vdd + Vth to turn on the transistor 61u, thereby precharging the node N3 of the TDC to Vdd. Thereafter, the signal BLCLAMP is set to 0.9 V + Vth to cause the transistor 61t. The node N3 of the TDC is at a low level when the bit line is at a low level, and is at a high level when the bit line is at a high level. Next, the signal BLC1 is set to Vsg (Vdd + Vth), and the potential of the TDC is taken into the PDC.

(リード動作:第2ページリード第2回目)
第2ページのリード動作の2回目は選択ワード線にリード電位“a”を供給し、読み出し動作をする(S82)。
(Read operation: 2nd page read 2nd time)
In the second read operation of the second page, the read potential “a” is supplied to the selected word line, and the read operation is performed (S82).

先ず、選択されているブロック内の非選択ワード線及びセレクト線SG1に読み出し電圧Vreadを供給する。この状態において、データ記憶回路10の信号BLPRE、BLCLAMPを1V+Vthとし、ビット線をプリチャージする。この後、メモリセルのソース側のセレクト線SG2をハイレベルにする。閾値電圧がワード線電位“a”より高いセルはオフするためビット線はハイレベルのままである。また、閾値電圧がワード線電位“a”より低いセルはオンするためビット線がVssとなる。   First, the read voltage Vread is supplied to the non-selected word line and the select line SG1 in the selected block. In this state, the signals BLPRE and BLCLAMP of the data storage circuit 10 are set to 1V + Vth, and the bit line is precharged. Thereafter, the select line SG2 on the source side of the memory cell is set to the high level. Since the cell whose threshold voltage is higher than the word line potential “a” is turned off, the bit line remains at the high level. Further, since the cell whose threshold voltage is lower than the word line potential “a” is turned on, the bit line becomes Vss.

次に、データ記憶回路10の信号BLPREをVdd+Vthとすることにより、TDCのノードN3をVddにプリチャージした後、信号BLCLAMPをVdd+Vthとしてトランジスタ61tをオンさせる。TDCのノードN3はビット線がローレベルの場合ローレベルとなり、ビット線がハイレベルの場合ハイレベルとなる。   Next, by setting the signal BLPRE of the data storage circuit 10 to Vdd + Vth, the node N3 of the TDC is precharged to Vdd, and then the signal BLCLAMP is set to Vdd + Vth to turn on the transistor 61t. The node N3 of the TDC is at a low level when the bit line is at a low level, and is at a high level when the bit line is at a high level.

このビット線放電中に、信号VPRE=Vss、信号BLPREをVdd+Vthとし、としTDCを一旦Vssにした後、信号REG=Vdd+Vth、信号VREG=Vddとし、DDC=ハイレベルの場合、TDCをハイレベルとする。つまりDDCのデータをTDCにコピーする。次に、信号DTG=Vdd+VthとしてPDCのデータをDDCにコピーした後、信号VREG=Vss、信号REG=Vddとし、DDCがハイレベルの場合強制的にTDCをローレベルにする。この後、信号BLC1=Vdd+Vthとして、TDCの電位をPDCに取りこむ。ここでPDCがハイレベルとなるのは、第1回目のリードで“b”レベルを超え、“c”レベル以下の場合であり、ローレベルとなるのは、第1回目のリードで“b”レベル以下、又は“c”レベル以上の場合である。   During this bit line discharge, signal VPRE = Vss, signal BLPRE is set to Vdd + Vth, TDC is once set to Vss, signal REG = Vdd + Vth, signal VREG = Vdd, and when DDC = high level, TDC is set to high level. To do. That is, the DDC data is copied to the TDC. Next, after the PDC data is copied to the DDC with the signal DTG = Vdd + Vth, the signal VREG = Vss and the signal REG = Vdd are set. When the DDC is at the high level, the TDC is forcibly set to the low level. Thereafter, the potential of TDC is taken into the PDC as a signal BLC1 = Vdd + Vth. Here, the PDC becomes high level when it exceeds the “b” level at the first read and is below the “c” level, and it becomes “b” at the first read. This is the case below the level or above the “c” level.

次に、データ記憶回路10の信号BLPREをVdd+Vthとしてトランジスタ61uをオンとすることにより、TDCのノードN3をVddにプリチャージする。この後、信号BLCLAMPを0.9V+Vthとしてトランジスタ61tをさせる。TDCのノードN3はビット線がローレベルの場合ローレベルとなり、ビット線がハイレベルの場合ハイレベルとなる。次に、信号DTG=Vdd+Vth、信号REG=Vdd、信号VREG=Vssとして、PDCがハイレベル場合強制的に、TDCをVssにする。次に、信号BLC1をVsg(Vdd+Vth)としてTDCの電位をPDCに取りこむ。この結果、PDCがハイレベルとなるのはメモリセルの閾値電圧が、ワード線電位“a”より高く、ワード線電位“b”より低い場合と、ワード線電位“c”より高い場合である。この後、PDCのデータをSDCに移動させる。   Next, the signal BLPRE of the data storage circuit 10 is set to Vdd + Vth to turn on the transistor 61u, thereby precharging the node N3 of the TDC to Vdd. Thereafter, the signal BLCLAMP is set to 0.9 V + Vth to cause the transistor 61t. The node N3 of the TDC is at a low level when the bit line is at a low level, and is at a high level when the bit line is at a high level. Next, the signal DTG = Vdd + Vth, the signal REG = Vdd, and the signal VREG = Vss are forcibly set to Vss when the PDC is at a high level. Next, the signal BLC1 is set to Vsg (Vdd + Vth), and the potential of the TDC is taken into the PDC. As a result, the PDC goes high when the threshold voltage of the memory cell is higher than the word line potential “a”, lower than the word line potential “b”, or higher than the word line potential “c”. Thereafter, the PDC data is moved to the SDC.

第1のフラグセルFC1のデータが“1”の場合(書き込まれていない場合)、第2ページは、書き込まれていない。このため、出力データを“1”に固定しデータを出力する(S84)。   When the data of the first flag cell FC1 is “1” (when not written), the second page is not written. Therefore, the output data is fixed to “1” and the data is output (S84).

尚、上記説明では、1回のビット線のプリチャージでワード線の電位を“b”“c”と変化させてメモリセルのデータを読み出し、再度、ビット線をプリチャージし、ワード線の電位を“a”として読み出していたが、1回のビット線のプリチャージでワード線の電位を“a”“b”“c”と変化させてメモリセルのデータを読み出すことも可能である。   In the above description, the word line potential is changed to “b” and “c” by one precharge of the bit line, the memory cell data is read, the bit line is precharged again, and the word line potential is recharged. However, it is also possible to read the memory cell data by changing the potential of the word line to “a”, “b”, and “c” by precharging the bit line once.

(イレーズ)
消去動作は、先ず、アドレスを指定し、図3の破線で示すブロックを選択する。次に、セルが形成されたウエルの電位を高電圧(約20V)にし、選択ブロックのワード線をVss、非選択ブロックのワード線をフローティングにする。すると、選択ブロックのセルとウエル間に高電圧が加わり、セルに記憶されたデータが消去される。一方、非選択ブロックにおいて、ワード線はフローティング状態であるため、ウエルを高電圧にすると、ワード線も高電圧になる。このため、非選択ブロックのメモリセルに記憶されたデータは消去されない。
(Erase)
In the erase operation, first, an address is designated, and a block indicated by a broken line in FIG. Next, the potential of the well in which the cell is formed is set to a high voltage (about 20 V), the word line of the selected block is set to Vss, and the word line of the non-selected block is floated. Then, a high voltage is applied between the cell and the well of the selected block, and the data stored in the cell is erased. On the other hand, since the word line is in a floating state in the non-selected block, when the well is set to a high voltage, the word line also becomes a high voltage. For this reason, data stored in the memory cells of the non-selected block is not erased.

消去動作を行なうと、メモリセルのデータは“0”となり、第1ページ、第2ページの何れでリードを行なってもデータ“1”が出力される。   When the erase operation is performed, the data in the memory cell becomes “0”, and data “1” is output regardless of whether reading is performed on the first page or the second page.

上記第1の実施形態によれば、第2ページのプログラムベリファイにおいて、ベリファイ電圧”b’”“c’”によるデータ“2”、“3”のベリファイを同時に行なっている。このため、2つのベリファイを行なう際に、1回ビット線をプリチャージし、ワード線電位を“b’”及び“c’”に設定するだけでよい。したがって、長時間を要するビット線のプリチャージの回数を削減することができるため、ベリファイ速度を向上できる。   According to the first embodiment, in the program verify of the second page, the data “2” and “3” are verified at the same time by the verify voltages “b ′” and “c ′”. Therefore, when performing two verifications, it is only necessary to precharge the bit line once and set the word line potential to “b ′” and “c ′”. Accordingly, the number of bit line precharges that require a long time can be reduced, and the verify speed can be improved.

また、第2ページの読み出し動作において、1回ビット線をプリチャージし、ワード線電位を“b”及び“c”に設定することにより、データ“2”、“3”を読み出している。したがって、プリチャージ回数を削減することができるため、読み出し速度を向上できる。   In the read operation for the second page, data “2” and “3” are read by precharging the bit line once and setting the word line potential to “b” and “c”. Therefore, since the number of precharges can be reduced, the reading speed can be improved.

さらに、データのプログラムベリファイ動作と読み出し動作は、ビット線をプリチャージした後、ワード線の電位を変化させている。このため、プログラムベリファイ動作と読み出し動作を同じ条件で行なうことができるため、読み出し精度を向上することが可能である。   Further, in the program verify operation and read operation of data, the potential of the word line is changed after precharging the bit line. For this reason, since the program verify operation and the read operation can be performed under the same conditions, the read accuracy can be improved.

また、第2ページ書き込みにおいて、ベリファイ“a’”の実行回数を規定する最大ループ回数を設定し、カウンタ(PC)の値が最大ループ回数に達した場合、ベリファイ“a’”の動作を終了させている。このため、第2ページの書き込み時間を短縮することができる。   In the second page write, the maximum number of loops that defines the number of times of execution of verify “a ′” is set. When the counter (PC) value reaches the maximum number of loops, the operation of verify “a ′” is terminated. I am letting. For this reason, the writing time of the second page can be shortened.

さらに、上記第1の実施形態によれば、本来の閾値電圧より低い電位により、第1ページのデータをメモリセルに書き込み、第2ページのデータを書き込む前に隣接するメモリセルに第1ページのデータを書き込み、隣接するメモリセルの書き込み後、第2ページのデータをメモリセルに書き込み、記憶データに対応した本来の閾値電圧に設定している。このため、隣接するメモリセルのFG−FG間容量の影響を考慮して、第1ページのデータをメモリセルに書き込んでいるため、多値のデータに対応する閾値電圧を正確に設定することができる。   Furthermore, according to the first embodiment, the first page data is written to the memory cell with a potential lower than the original threshold voltage, and the first page data is written to the adjacent memory cell before the second page data is written. After the data is written and the adjacent memory cell is written, the second page data is written into the memory cell, and the original threshold voltage corresponding to the stored data is set. For this reason, the first page data is written in the memory cell in consideration of the influence of the FG-FG capacity of the adjacent memory cell, so that the threshold voltage corresponding to the multivalued data can be set accurately. it can.

また、第2ページのデータを書き込む際、フラグセルにデータを書き込み、各ページのデータを読み出す際、フラグセルに記憶されたデータに応じて外部に出力されるデータを制御している。したがって、各ページのデータを確実に出力することができる。   In addition, when data of the second page is written, data is written to the flag cell, and when data of each page is read, data output to the outside is controlled according to the data stored in the flag cell. Therefore, the data of each page can be reliably output.

さらに、従来、例えばメモリセルから読み出したデータの一部を外部から入力したデータに変えて書き込む、所謂ページコピーを行う場合、図6に破線で示すように、インバータ回路62cとインバータ回路62dの間にトランジスタ62eが挿入され、インバータ回路62cとトランジスタ62eにトランジスタ62fが並列接続されていた。このような構成において、従来は、ページコピー時に、プログラムのコマンドが入力されると、メモリセルから読み出されたデータは、書き込み時にデータ入力端子5aから供給されたデータと論理レベルが反転してSDCにラッチされる。このため、データ入力端子5aから供給されるデータと、SDCにラッチされたデータとの論理レベルを一致させる必要がある。したがって、ページコピー時に、相補的な信号φ、/φにより、トランジスタ62eをオンし、トランジスタ62fをオフとして、書き込みデータを反転してSDCに供給していた。   Furthermore, conventionally, for example, when performing so-called page copy, in which a part of data read from a memory cell is changed to data inputted from the outside and written, as shown by a broken line in FIG. 6, between the inverter circuit 62c and the inverter circuit 62d. The transistor 62e is inserted, and the transistor 62f is connected in parallel to the inverter circuit 62c and the transistor 62e. In such a configuration, conventionally, when a program command is input during page copying, the data read from the memory cell is inverted in logic level from the data supplied from the data input terminal 5a during writing. Latched to SDC. For this reason, it is necessary to match the logic levels of the data supplied from the data input terminal 5a and the data latched by the SDC. Therefore, at the time of page copy, the transistor 62e is turned on by the complementary signals φ and / φ, the transistor 62f is turned off, and the write data is inverted and supplied to the SDC.

しかし、上記第1の実施形態によれば、ページコピーを行なう場合、メモリセルから読み出されたデータは反転された後、SDCにラッチされ、データ入力端子5aからSDCの供給されるデータと論理レベルが一致されている。このため、データ入力端子5aとSDCの間に従来のようなトランジスタ62e,62fを設ける必要がない。したがって、回路構成を簡単できる利点を有している。   However, according to the first embodiment, when page copy is performed, the data read from the memory cell is inverted and then latched in the SDC, and the data and logic supplied from the data input terminal 5a to the SDC. The levels are matched. Therefore, it is not necessary to provide conventional transistors 62e and 62f between the data input terminal 5a and the SDC. Therefore, there is an advantage that the circuit configuration can be simplified.

尚、第1の実施形態において、第2ページ(アッパーページ)のデータをメモリセルに書き込むとき、プログラムとベリファイ(a*,a’)と、プログラムベリファイ(b’,c’)を分けて行っていた。しかし、プログラムベリファイ(b’,c’)のように、一回のビット線充電後、ワード線電位をa*,a’,b’,c’と次々に上昇することにより、これらを1度にベリファイすることも可能である。   In the first embodiment, when the data of the second page (upper page) is written to the memory cell, the program, verify (a *, a ′), and program verify (b ′, c ′) are performed separately. It was. However, as in the program verify (b ′, c ′), after the bit line is charged once, the word line potential is increased one after another by a *, a ′, b ′, c ′, thereby once. It is also possible to perform verification.

また、第2ページのリード時、リード(b,c)とリード(a)を分けて行っていたが、リード(b,c)の時のように、一回のビット線充電後、ワード線電位をa,b,cと次々に上昇することにより、これらのデータを1度に読み出すことも可能である。   Also, when reading the second page, the read (b, c) and the read (a) are performed separately. However, as in the case of the read (b, c), after the bit line is charged once, the word line It is also possible to read out these data at a time by increasing the potential one after another as a, b, and c.

(第2の実施形態)
図19は、第2の実施形態を示すものであり、8値(3ビット)のデータを記憶するNANDフラッシュメモリのメモリセルアレイ1及びビット線制御回路2を示している。図19に示す構成は、図3に示す4値(2ビット)の構成とほぼ同様であるため、異なる部分についてのみ説明する。
(Second Embodiment)
FIG. 19 shows the second embodiment, and shows a memory cell array 1 and a bit line control circuit 2 of a NAND flash memory that stores 8-level (3-bit) data. The configuration shown in FIG. 19 is almost the same as the 4-level (2-bit) configuration shown in FIG. 3, and therefore only different parts will be described.

図19において、外部アドレスにより、1本のワード線が選択されると、破線で示す、1つのセクタが選択される。1セクタは3ページにより構成される。この3ページはアドレスによって切り替えられる。すなわち、1つのメモリセルに3ビットのデータを記憶することができるため、3ビットの切り替えはアドレス(第1ページ、第2ページ、第3ページ)によって行なう。また、1セクタは5つのフラグセルFC1、FC2、FC3、FC4、FC5を有している(図19は、フラグセルFC1とFC5のみを示している)。このため、1本のワード線が選択されると、5つのフラグセルFC1、FC2、FC3、FC4、FC5が同時に選択される。各フラグセルFC1〜FC5はビット線を介してフラグ用データ記憶回路10a、10b、10c、10d、10eに接続されている(図19は、フラグ用データ記憶回路10a、10eのみを示している)。フラグセルFC1、FC2は、第2ページの書き込みが行なわれていることを示すデータを記憶し、フラグセルFC3、FC4、FC5は、第3ページの書き込みが行なわれていることを示すデータを記憶する。   In FIG. 19, when one word line is selected by an external address, one sector indicated by a broken line is selected. One sector is composed of three pages. These three pages are switched by address. That is, since 3-bit data can be stored in one memory cell, 3-bit switching is performed by an address (first page, second page, third page). One sector includes five flag cells FC1, FC2, FC3, FC4, and FC5 (FIG. 19 shows only flag cells FC1 and FC5). Therefore, when one word line is selected, five flag cells FC1, FC2, FC3, FC4, and FC5 are simultaneously selected. Each of the flag cells FC1 to FC5 is connected to the flag data storage circuits 10a, 10b, 10c, 10d, and 10e via bit lines (FIG. 19 shows only the flag data storage circuits 10a and 10e). The flag cells FC1 and FC2 store data indicating that the second page is being written, and the flag cells FC3, FC4, and FC5 store data indicating that the third page is being written.

しかし、1つのメモリセルに3ビットのデータを記憶することができるため、5つのフラグセルを用いず、3つのフラグセルにより、第2ページと第3ページの書き込みが行なわれていることを示すデータを記憶することも可能である。   However, since 3-bit data can be stored in one memory cell, data indicating that the second page and the third page are written by three flag cells without using five flag cells. It is also possible to memorize.

また、信頼性を向上させるため、フラグセルFC1〜FC5を、それぞれ複数個具備し、これら複数セルに同一データを記憶し、読み出し時に、複数のフラグセルから読み出したデータを多数決により決めることもできる。   In order to improve reliability, a plurality of flag cells FC1 to FC5 can be provided, the same data can be stored in these cells, and the data read from the plurality of flag cells can be determined by majority decision at the time of reading.

第2の実施形態の動作について説明する。   The operation of the second embodiment will be described.

消去動作は、4値の場合と同じである。   The erase operation is the same as in the case of four values.

図20(a)(b)(c)、図21(a)(b)は、メモリセルのデータとメモリセルの閾値電圧の関係を示している。消去動作を行なうとメモリセルのデータは“0”となる。図20(a)に示すように、第1ページの書き込みにより、メモリセルのデータはデータ“0”とデータ“4”になる。この後、第1ページに隣接するセルにデータが書き込まれるとデータ“4”の閾値電圧の分布が広がる(図20(b))。   FIGS. 20A, 20B and 20C, and FIGS. 21A and 21B show the relationship between the memory cell data and the threshold voltage of the memory cell. When the erase operation is performed, the data in the memory cell becomes “0”. As shown in FIG. 20A, the data in the memory cell becomes data “0” and data “4” by writing the first page. Thereafter, when data is written in a cell adjacent to the first page, the threshold voltage distribution of the data “4” spreads (FIG. 20B).

第2ページの書き込み後、メモリセルのデータはデータ“0”、“2”、“4”、“6”となる(図20(c))。この後、隣接セルにデータが書き込まれると、データ“0”、“2”、“4”、“6”の閾値分布が広がる(図21(a))。   After the second page is written, the data in the memory cell becomes data “0”, “2”, “4”, “6” (FIG. 20C). Thereafter, when data is written in the adjacent cell, the threshold distribution of the data “0”, “2”, “4”, “6” spreads (FIG. 21A).

第3ページの書き込み後、メモリセルのデータはデータ“0”〜“7”となる(図21(b))。本実施形態において、メモリセルのデータは閾値電圧の低いほうから高い方へと、定義されている。   After writing the third page, the data in the memory cell becomes data “0” to “7” (FIG. 21B). In the present embodiment, the memory cell data is defined from the lower threshold voltage to the higher threshold voltage.

図22(a)(b)は、本実施形態における2つの書き込み順序の例を示している。ブロック内において、ソース線に近いメモリセルからページごとに書き込み動作が行なわれる。図22(a)(b)は、説明の便宜上、ワード線を4本としている。図22(a)に示す書き込み順序は、図7に示す書き込み順序と類似している。これに対して、図22(b)に示す書き込み順序は、図22(a)と若干相違している。すなわち、第1ページの書き込み後、第2ページは隣接のセルを初めに書くのではなく、同じセルに第2ページまで書き込む。この後、第3ページの書き込みを行なう前に、隣接セルの第2ページまで、書き込みを行なった後、第3ページの書き込みを行なっている。このように、第3ページの隣接セルの影響を考慮した書き込みをすることも可能である。   22A and 22B show examples of two write orders in the present embodiment. In the block, a write operation is performed for each page from a memory cell close to the source line. 22A and 22B, the number of word lines is four for convenience of explanation. The write order shown in FIG. 22A is similar to the write order shown in FIG. On the other hand, the writing order shown in FIG. 22B is slightly different from that shown in FIG. That is, after writing the first page, the second page does not write adjacent cells first, but writes up to the second page in the same cell. Thereafter, before writing the third page, after writing to the second page of the adjacent cell, the third page is written. In this way, it is possible to perform writing in consideration of the influence of adjacent cells on the third page.

第3ページのワード線のリード電位は、本来“a”,“b”,“c”,“d”,“e”,“f”,“g”とし、ベリファイ電位を“a’”,“b’”,“c’”,“d’”,“e’”,“f’”,“g’”とする。第2ページのリード電位は、本来のリード電位より低い値“b*”(=“a”),“d*”,“f*”とし、第2ページでのベリファイ電位はこれらより少し高い値、“b*’”,“d*’”,“f*’”とする。第1ページのリード電位は、本来のリード電位より低い電位“d**”(=“a”)とし、第1ページでのベリファイ電位はこれらより少し高い電位“d**’”とする。   The read potential of the word line of the third page is originally “a”, “b”, “c”, “d”, “e”, “f”, “g”, and the verify potential is “a ′”, “ b ′ ”,“ c ′ ”,“ d ′ ”,“ e ′ ”,“ f ′ ”,“ g ′ ”. The read potential on the second page is set to values “b *” (= “a”), “d *”, “f *” lower than the original read potential, and the verify potential on the second page is slightly higher than these values. , “B * ′”, “d * ′”, and “f * ′”. The read potential on the first page is set to a potential “d **” (= “a”) lower than the original read potential, and the verify potential on the first page is set to a potential “d ** ′” slightly higher than these.

(プログラム及びプログラムベリファイ)
プログラム動作は、先ず、アドレスを指定し、図19に示す3ページを選択する。本メモリは、3ページのうち、第1ページ、第2ページ、第3ページの順でしか、プログラムできない。第1ページ及び第2ページのプログラムは、4値の場合と同様である。
(Program and program verify)
In the program operation, first, an address is designated and three pages shown in FIG. 19 are selected. This memory can be programmed only in the order of the first page, the second page, and the third page among the three pages. The programs for the first page and the second page are the same as in the case of four values.

図20(a)(b)(c)に示す4値のメモリセルのデータとメモリセルの閾値電圧は、図1(a)(b)(c)に対応している。また、プログラム及びプログラムベリファイのブロックダイアグラムは、図8、図9と同様であるため省略する。但し、メモリセルのデータの定義及びワード線の電位は、4値の場合、“0”、“1”、“2”、“3”及び“a”、“b”、“c”であるのに対し、8値の場合、“0”、“2”、“4”、“6”及び“b”、“d”、“f”となっている。   The data of the quaternary memory cell and the threshold voltage of the memory cell shown in FIGS. 20A, 20B, and 20C correspond to FIGS. 1A, 1B, and 1C. The block diagrams of the program and program verify are the same as those shown in FIGS. However, the definition of the data in the memory cell and the potential of the word line are “0”, “1”, “2”, “3” and “a”, “b”, “c” in the case of four values. On the other hand, in the case of 8 values, they are “0”, “2”, “4”, “6” and “b”, “d”, “f”.

(第1ページプログラム)
第1ページのプログラムのブロックダイアグラムは、図8と同様である。しかし、前述したように、ワード線電位の定義が変更されている。
(First page program)
The block diagram of the program on the first page is the same as in FIG. However, as described above, the definition of the word line potential is changed.

(隣接セルプログラム)
図22(a)に示すように、メモリセル1の第1ページに1ビットのデータの書き込み後、メモリセル1とワード方向に隣接したメモリセル2の第1ページが書き込まれる。次いで、メモリセル1とビット方向に隣接したメモリセル3の第1ページの書き込み、メモリセル1と対角に隣接したメモリセル4の第1ページの書き込みが行なわれる。これらの書き込み動作が行なわれると、書き込みデータによっては、FG−FG間容量によって、メモリセル1の閾値電圧が上がる。このため、メモリセル1のデータ“0”とデータ“4”の閾値電圧分布は図20(b)のように閾値電圧の高いほうに広がる。
(Adjacent cell program)
As shown in FIG. 22A, after writing 1-bit data to the first page of the memory cell 1, the first page of the memory cell 2 adjacent to the memory cell 1 in the word direction is written. Next, the first page of the memory cell 3 adjacent to the memory cell 1 in the bit direction is written, and the first page of the memory cell 4 diagonally adjacent to the memory cell 1 is written. When these write operations are performed, the threshold voltage of the memory cell 1 increases due to the FG-FG capacitance depending on the write data. For this reason, the threshold voltage distribution of data “0” and data “4” of the memory cell 1 spreads to the higher threshold voltage as shown in FIG.

この後、再びメモリセル1の第2ページに1ビットのデータが書き込まれる。   Thereafter, 1-bit data is written to the second page of the memory cell 1 again.

(第2ページプログラム)
第2ページのプログラムのブロックダイアグラムは、図9と同様であるが、前述したように、ワード線電位の定義が変更されている。また、データロード、内部リード後のデータキャッシュ内のデータ及びデータキャッシュ設定後のデータキャッシュ内のデータは、同様である。第2ページの書き込みにおいて、フラグセルFC1は、ベリファイ電位“b*’”まで書き込まれ、フラグセルFC2は、ベリファイ電位“d*’”まで書き込まれる。
(2nd page program)
The block diagram of the program on the second page is the same as that of FIG. 9, but the definition of the word line potential is changed as described above. The same applies to data in the data cache after data load, internal read, and data in the data cache after data cache setting. In writing the second page, the flag cell FC1 is written to the verify potential “b * ′”, and the flag cell FC2 is written to the verify potential “d * ′”.

(隣接セルプログラム)
図22(a)に示すように、メモリセル1の第1ページ及び第2ページにデータの書き込み後、メモリセル2の第2ページ、メモリセル5、6の第1ページ及びメモリセル3、4の第2ページにデータが書き込まれる。これらの書き込み動作が行なわれると、書き込みデータによっては、FG−FG間容量によって、メモリセル1の閾値電圧が上がる。このため、メモリセル1のデータ“2”、データ“4”、データ“6”の閾値電圧分布は図21(a)のように広がる。
(Adjacent cell program)
As shown in FIG. 22A, after writing data to the first page and the second page of the memory cell 1, the second page of the memory cell 2, the first page of the memory cells 5 and 6, and the memory cells 3, 4 Data is written to the second page. When these write operations are performed, the threshold voltage of the memory cell 1 increases due to the FG-FG capacitance depending on the write data. Therefore, the threshold voltage distribution of the data “2”, data “4”, and data “6” of the memory cell 1 is widened as shown in FIG.

この後、再びメモリセル1の第3ページに1ビットのデータが書き込まれる。   Thereafter, 1-bit data is written to the third page of the memory cell 1 again.

(第3ページプログラム)
図23は、第3ページのプログラムのブロックダイアグラムを示している。第3ページのプログラム動作も、先ずアドレスを指定し、図19に示す3ページを選択する。
(3rd page program)
FIG. 23 shows a block diagram of the program on the third page. In the program operation of the third page, first, an address is designated, and the third page shown in FIG.

次に、データ記憶回路10をリセットし(S91)、書き込みデータを外部より入力して全てのデータ記憶回路10のSDCに記憶する(S92)。外部よりデータ“1”(書き込みを行なわない)が入力されると、図6に示すデータ記憶回路10のSDCは、ローレベルになり、データ“0”(書き込みを行なう)が入力されるとハイレベルとなる。この後、書き込みコマンドが入力されると、第3ページのプログラムであるので、フラグセルFC3〜FC5にデータの書き込みを行なうため、フラグセル用のデータ記憶回路10a、10bに所定のデータが入力される。   Next, the data storage circuit 10 is reset (S91), and write data is input from the outside and stored in the SDCs of all the data storage circuits 10 (S92). When data “1” (not written) is input from the outside, the SDC of the data storage circuit 10 shown in FIG. 6 becomes low level, and when data “0” (written) is input, the SDC is high. Become a level. Thereafter, when a write command is input, since it is a program of the third page, predetermined data is input to the data storage circuits 10a and 10b for flag cells in order to write data to the flag cells FC3 to FC5.

第3ページのプログラムは、図21(b)に示すように、メモリセルのデータが“0”の場合で、外部から入力されるデータが“1”の場合、メモリセルのデータを“0”のままとし、外部から入力されるデータが“0”の場合、メモリセルのデータを“1”にする。   As shown in FIG. 21B, the program on the third page has the memory cell data “0” when the memory cell data is “0” and the externally input data is “1”. If the data input from the outside is “0”, the data in the memory cell is set to “1”.

メモリセルのデータが“2”の場合で、外部から入力されるデータが“0”の場合、メモリセルのデータを“2”のままである。しかし、第2ページの書き込み時において、メモリセルのデータが“2”に達したかどうかをベリファイする際、通常より低いベリファイ電位“b*’”を用いた。このため、データ“2”を記憶するメモリセルは、本来のベリファイ電位である“b’”の電位まで書き込む。メモリセルのデータが“2”の場合で、外部から入力されるデータが“1”の場合、メモリセルのデータを“3”にする。   When the data in the memory cell is “2” and the data input from the outside is “0”, the data in the memory cell remains “2”. However, when verifying whether or not the data in the memory cell has reached “2” at the time of writing the second page, a verify potential “b * ′” lower than usual is used. Therefore, the memory cell storing the data “2” writes up to the potential “b ′” which is the original verify potential. When the data in the memory cell is “2” and the data input from the outside is “1”, the data in the memory cell is set to “3”.

メモリセルのデータが“4”の場合で、外部から入力されるデータが“1”の場合、メモリセルのデータは“4”のままである。しかし、第2ページの書き込み時において、メモリセルのデータが“4”に達したかどうかをベリファイする際、通常より低いベリファイ電位“d*’”を用いた。このため、データ“4”を記憶するメモリセルは、本来のベリファイ電位である“d’”の電位まで書き込む。メモリセルのデータが“4”の場合で、外部から入力されるデータが“0”の場合、メモリセルのデータを“5”にする。   When the data in the memory cell is “4” and the data input from the outside is “1”, the data in the memory cell remains “4”. However, when verifying whether or not the data in the memory cell has reached “4” at the time of writing the second page, a verify potential “d * ′” lower than usual is used. For this reason, the memory cell storing the data “4” writes up to the potential “d ′” which is the original verify potential. When the data in the memory cell is “4” and the data input from the outside is “0”, the data in the memory cell is set to “5”.

メモリセルのデータが“6”の場合で、外部から入力されるデータが“0”の場合、メモリセルのデータを“6”のままである。しかし、第2ページの書き込み時において、メモリセルのデータが“6”に達したかどうかをベリファイする際、通常より低いベリファイ電位“f*’”を用いた。このため、データ“6”を記憶するメモリセルは、本来のベリファイ電位である“f’”の電位まで書き込む。メモリセルのデータが“6”の場合で、外部から入力されるデータが“1”の場合、メモリセルのデータを“7”にする。   When the data in the memory cell is “6” and the data input from the outside is “0”, the data in the memory cell remains “6”. However, when verifying whether or not the data in the memory cell has reached “6” at the time of writing the second page, a verify potential “f * ′” lower than usual is used. For this reason, the memory cell storing the data “6” writes up to the potential of “f ′” which is the original verify potential. When the data in the memory cell is “6” and the data input from the outside is “1”, the data in the memory cell is set to “7”.

第2ページの書き込みにおいて、フラグセルFC1は、ベリファイ電位“b*’”まで書き込まれ、フラグセルFC2は、ベリファイ電位“d*’”まで書き込まれる。第3ページの書き込みで、フラグセルFC3は、ベリファイ電位“a’”まで書き込まれ、フラグセルFC4は、ベリファイ電位“b’”まで書き込まれ、フラグセルFC5は、ベリファイ電位“d’”書き込まれる。   In writing the second page, the flag cell FC1 is written to the verify potential “b * ′”, and the flag cell FC2 is written to the verify potential “d * ′”. In the third page write, the flag cell FC3 is written to the verify potential “a ′”, the flag cell FC4 is written to the verify potential “b ′”, and the flag cell FC5 is written to the verify potential “d ′”.

(第3ページ第1回目プログラム)
第3ページのプログラムは、メモリセルにデータ“1”〜“7”を書き込む。これらのデータを同時にプログラムすることも可能であるが、本実施形態では、先ず、メモリセルにデータ“4”〜“7”の4つのデータを書き込む。この後、メモリセルにデータ“1”〜“3”を書き込む。以下、具体的に説明する。
(3rd page 1st program)
The program on the third page writes data “1” to “7” to the memory cells. Although it is possible to program these data simultaneously, in this embodiment, first, four data “4” to “7” are written in the memory cell. Thereafter, data “1” to “3” are written in the memory cells. This will be specifically described below.

(内部データリード1及びデータキャッシュ設定1)(S93、S94)
メモリセルへデータを書き込む前に、第2ページのメモリセルのデータが“4”又は“6”か、“0”又は“2”であるかの判断と、メモリセルのデータが“6”か、データが“0”、“2”、“4”のいずれであるかを判断する。このため、ワード線の電位を“d*”、“f*”に順次設定し、内部リード動作を行なう(S93)。
(Internal data read 1 and data cache setting 1) (S93, S94)
Before writing data to the memory cell, it is determined whether the memory cell data on the second page is “4” or “6”, “0” or “2”, and whether the memory cell data is “6”. Whether the data is “0”, “2”, or “4” is determined. For this reason, the potential of the word line is sequentially set to “d *” and “f *”, and an internal read operation is performed (S93).

図25(a)は内部リード後のデータキャッシュの状態を示している。この後、データキャッシュを操作することにより、図25(b)に示すように、データキャッシュを設定する。さらに、例えばカウンタ(PC)をゼロに初期設定し、第5のフラグセルのデータをロードする(S94)。   FIG. 25A shows the state of the data cache after the internal read. Thereafter, by operating the data cache, the data cache is set as shown in FIG. Further, for example, the counter (PC) is initialized to zero, and the data of the fifth flag cell is loaded (S94).

図25(b)において、メモリセルのデータを“0”〜“3”にする場合、PDCはハイレベル。メモリセルのデータを“4”とする場合、PDCはローレベル、DDCはローレベル、SDCはハイレベルに設定する。メモリセルのデータを“5”とする場合、PDCはローレベル、DDCはハイレベル、SDCはハイレベルに設定する。メモリセルのデータを“6”とする場合、PDCはローレベル、DDCはハイレベル、SDCはローレベルに設定する。メモリセルのデータを“7”とする場合、PDC、DDC、SDCをいずれもローレベルに設定する。   In FIG. 25B, when the data in the memory cell is set to “0” to “3”, the PDC is at the high level. When the data in the memory cell is “4”, the PDC is set to the low level, the DDC is set to the low level, and the SDC is set to the high level. When the data in the memory cell is “5”, the PDC is set to the low level, the DDC is set to the high level, and the SDC is set to the high level. When the data in the memory cell is “6”, the PDC is set to the low level, the DDC is set to the high level, and the SDC is set to the low level. When the data in the memory cell is “7”, all of PDC, DDC, and SDC are set to a low level.

(プログラム:第1回目)(S95)
次いで、カウンタ(PC)をカウントアップした後、メモリセルにデータが書き込まれる。第2の実施形態においても、第1の実施形態と同様、カウンタの値と予め定められたベリファイ開始回数を用いて、不要なベリファイがスキップされる。
(Program: 1st) (S95)
Next, after counting up the counter (PC), data is written into the memory cell. Also in the second embodiment, unnecessary verification is skipped using the counter value and a predetermined number of verification starts, as in the first embodiment.

先ず、信号BLC1をVsgとすると、PDCがデータ“0”の場合、ビット線がVssとなり、データ“1”の場合、ビット線はVddになる。次に、信号BLC1=Vssとした後、信号VREG=Vdd、信号REG=中間電位+Vth(1V+Vth)とする。すると、DDCがデータ“1”の場合、ビット線が中間電位となり、DDCがデータ“0”の場合、ビット線はプリチャージされない。この結果、メモリセルにデータ“4”,“7”を書き込んでいるときのみビット線はVss、メモリセルにデータ“5”,“6”を書き込んでいる場合、ビット線は中間電位(1V)、メモリセルのデータが“0”〜“3”の場合(書き込みしない場合)、ビット線はVddになる。ここで、選択ワード線をVpgm、非選択ワード線をVpassとすると、ビット線がVddの場合、書き込みが行なわれない。また、ビット線がVssの場合、書き込みが起こり、ビット線が中間電位(1V)の場合、少しだけ書き込まれる。したがって、メモリセルにデータ“5”,“6”を書き込んでいるセルは、あまり書き込まれない可能性がある。しかし、メモリセルのデータ“6”とデータ“7”のベリファイを一括して行なうため、出来るだけ同時に書き込まれたほうが書き込み時間が早く終わる。このため、ビット線に中間電位を供給する。   First, when the signal BLC1 is Vsg, when the PDC is data “0”, the bit line is Vss, and when the data is “1”, the bit line is Vdd. Next, after setting the signal BLC1 = Vss, the signal VREG = Vdd and the signal REG = intermediate potential + Vth (1V + Vth). Then, when the DDC is data “1”, the bit line has an intermediate potential, and when the DDC is data “0”, the bit line is not precharged. As a result, only when data “4” and “7” are written in the memory cell, the bit line is Vss, and when data “5” and “6” are written in the memory cell, the bit line is at the intermediate potential (1 V). When the data in the memory cell is “0” to “3” (when writing is not performed), the bit line becomes Vdd. Here, if the selected word line is Vpgm and the non-selected word line is Vpass, writing is not performed when the bit line is Vdd. In addition, when the bit line is Vss, writing occurs, and when the bit line is at the intermediate potential (1 V), writing is slightly performed. Therefore, there is a possibility that the cells in which the data “5” and “6” are written in the memory cells are not so much written. However, since the data “6” and data “7” of the memory cell are verified all at once, the writing time ends earlier when they are written at the same time. For this reason, an intermediate potential is supplied to the bit line.

(a)この後、ベリファイ電圧“d’”を設定して書き込みベリファイが行なわれる(S96,S97)。このベリファイにおいて、信号BLC2をハイレベルとし、信号BLCLAMPを所定の電位に設定すると、ビット線がプリチャージされる。このとき、プリチャージされるのは、SDCがハイレベル、つまり、データ“5”、“4”を書き込んでいるメモリセルのみである。 (A) Thereafter, the verify voltage “d ′” is set and the write verify is performed (S96, S97). In this verification, when the signal BLC2 is set to a high level and the signal BLCLAMP is set to a predetermined potential, the bit line is precharged. At this time, only the memory cells in which the SDC is at a high level, that is, data “5” and “4” are written, are precharged.

次に、ワード線にベリファイ電位“d’”を供給し、ビット線を放電する。ビット線の放電中に信号VREG=Vss、信号REG=VDDとする。DDCがハイレベルの場合、ビット線を放電する。したがって、ビット線がプリチャージされるのはデータ“4”を書き込むメモリセルのみである。   Next, the verify potential “d ′” is supplied to the word line, and the bit line is discharged. During the discharge of the bit line, the signal VREG = Vss and the signal REG = VDD are set. When DDC is high, the bit line is discharged. Therefore, the bit line is precharged only in the memory cell to which data “4” is written.

次に、ビット線の放電中にDDCのデータをTDCに移す。この後、PDCのデータをDDCに移し、TDCのデータをPDCに移す。次いで、TDCをVddに充電する。この後、信号BLCLAMPを所定の電位に設定する。すると、TDCがハイレベルになるのは、メモリセルにデータ“4”が書き込まれていてベリファイ電位“d’”に達した時だけである。   Next, DDC data is transferred to TDC during the discharge of the bit line. Thereafter, the PDC data is transferred to the DDC, and the TDC data is transferred to the PDC. The TDC is then charged to Vdd. Thereafter, the signal BLCLAMP is set to a predetermined potential. Then, the TDC becomes high level only when data “4” is written in the memory cell and the verify potential “d ′” is reached.

次に、信号VREGをハイレベルとし、信号REGをVsgとすると、DDCのデータがハイレベルの場合、強制的にTDCがハイレベルとなる。したがって、TDCがVddになるのは、メモリセルにデータ“4”を書き込んでいてベリファイ電位“d’”に達した時と、書き込み非選択の場合である。信号DTGをVsgとし、PDCのデータをDDCにコピーした後、信号BLC1をVsgとしてTDCの電位をPDCに取りこむ。   Next, when the signal VREG is set to high level and the signal REG is set to Vsg, when the data of the DDC is high level, the TDC is forcibly set to high level. Therefore, TDC becomes Vdd when data “4” is written in the memory cell and the verify potential “d ′” is reached, and when writing is not selected. After the signal DTG is set to Vsg and the data of the PDC is copied to the DDC, the signal BLC1 is set to Vsg and the potential of the TDC is taken into the PDC.

(b)この後、ベリファイ電圧“e’”を設定して書き込みベリファイが行なわれる(S98,S99,S100)。 (B) Thereafter, the verify voltage “e ′” is set and the write verify is performed (S98, S99, S100).

このベリファイにおいて、信号VPRE=ハイレベル、信号BLCLAMPを所定の電位に設定すると、ビット線がプリチャージされる。次に、ワード線にベリファイ電位“e’”を供給し、ビット線を放電する。次に、このビット線の放電中にDDCのデータをTDCに移す。この後、PDCのデータをDDCに移し、TDCのデータをPDCに移す。次いで、TDCをVddに充電する。この後、信号BLCLAMPを所定の電位に設定する。すると、TDCがハイレベルになるのは、セルの閾値電圧がベリファイ電位“e’”以上の場合である。ここで、信号BLC2をVth+0.5Vとすると、SDCが“0”の場合(メモリセルのデータ“6”に書き込んでいる場合とメモリセルのデータ“7”に書き込んでいる場合)、TDCはVssになる。したがって、TDCがVddになるのは、メモリセルのデータが“5”に書き込まれていてベリファイ電位“e’”に達した時である。   In this verification, when the signal VPRE = high level and the signal BLCLAMP are set to a predetermined potential, the bit line is precharged. Next, the verify potential “e ′” is supplied to the word line, and the bit line is discharged. Next, DDC data is transferred to TDC during the discharge of the bit line. Thereafter, the PDC data is transferred to the DDC, and the TDC data is transferred to the PDC. The TDC is then charged to Vdd. Thereafter, the signal BLCLAMP is set to a predetermined potential. Then, the TDC becomes high level when the threshold voltage of the cell is equal to or higher than the verify potential “e ′”. Here, when the signal BLC2 is set to Vth + 0.5V, when the SDC is “0” (when data is written to the memory cell data “6” and when data is written to the memory cell data “7”), the TDC is Vss. become. Therefore, TDC becomes Vdd when the data of the memory cell is written to “5” and reaches the verify potential “e ′”.

次に、信号VREGをハイレベルとし、信号REGをVsgとすると、DDCのデータがハイレベルの場合、強制的にTDCがハイレベルとなる。したがって、TDCがVddになるのは、メモリセルにデータ“5”を書き込んでいてベリファイ電位“e’”に達した時と、書き込み非選択の場合である。信号DTGをVsgとし、PDCのデータをDDCにコピーした後、信号BLC1をVsgとしてTDCの電位をPDCに取りこむ。   Next, when the signal VREG is set to high level and the signal REG is set to Vsg, when the data of the DDC is high level, the TDC is forcibly set to high level. Therefore, TDC becomes Vdd when data “5” is written in the memory cell and the verify potential “e ′” is reached, and when writing is not selected. After the signal DTG is set to Vsg and the data of the PDC is copied to the DDC, the signal BLC1 is set to Vsg and the potential of the TDC is taken into the PDC.

(c)ベリファイ電位“f’”を用いたベリファイは、第1の実施形態のベリファイ電位“b”を用いたベリファイと同様である。但し、ベリファイ時のワード線電位は“f’”である(S101,S102,S103)。 (C) The verification using the verification potential “f ′” is the same as the verification using the verification potential “b” in the first embodiment. However, the word line potential at the time of verification is “f ′” (S101, S102, S103).

(d)ベリファイ電位“f’”“g’”同時ベリファイは、第1の実施形態のベリファイ電位“b”“c”同時ベリファイと同様である。但し、ベリファイ時のワード線電位は“f’”“g’”である。 (D) The verify potential “f ′” “g ′” simultaneous verify is the same as the verify potential “b” “c” simultaneous verify of the first embodiment. However, the word line potential at the time of verification is “f ′” “g ′”.

このようにして、全てのPDCのデータが“1”になるまで、プログラムとベリファイ動作を繰り返す(S106、S107)。しかし、書き込み動作において、DDCのデータが“1”の場合、つまり、メモリセルにデータ“5”を書き込んでいる場合と、メモリセルにデータ“6”を書き込んでいる場合、ビット線を中間電位にして書き込み動作をする。また、プログラムとベリファイ動作を繰り返す毎に、プログラム電圧Vpgmを少しずつ上昇させる。第1回目プログラムにより、メモリセルにデータ“4”〜“7”の4つが書き込まれる。   In this way, the program and verify operation are repeated until the data of all PDCs becomes “1” (S106, S107). However, in the write operation, when the data of the DDC is “1”, that is, when data “5” is written in the memory cell and when data “6” is written in the memory cell, the bit line is set to the intermediate potential. And write operation. Further, each time the program and verify operations are repeated, the program voltage Vpgm is gradually increased. According to the first program, four data “4” to “7” are written in the memory cell.

上記説明では、1回のプログラムの後、4つのベリファイを行なっていた。しかし、プログラムの初期のループでは、閾値電圧が上がらない。このため、初めは、ベリファイ電位“d’”を用いたベリファイのみ行なう。次に、ベリファイ電位“d’”とベリファイ電位“e’”を用いたベリファイを行なう。次に、ベリファイ電位“d’”とベリファイ電位“e’”ベリファイ電位“f’”のみを用いたベリファイを行なう。最後に、ベリファイ電位“d’”とベリファイ電位“e’”を用いたベリファイと、ベリファイ電位“f’”とベリファイ電位“g’”を同時にベリファイする“f’、g’”同時ベリファイを行なうことも可能である。   In the above description, four verifications are performed after one program. However, the threshold voltage does not increase in the initial loop of the program. Therefore, at first, only the verification using the verification potential “d ′” is performed. Next, verify using the verify potential “d ′” and the verify potential “e ′” is performed. Next, verify is performed using only the verify potential “d ′”, the verify potential “e ′”, and the verify potential “f ′”. Finally, verify using the verify potential “d ′” and the verify potential “e ′”, and “f ′ and g ′” simultaneous verify that simultaneously verify the verify potential “f ′” and the verify potential “g ′” are performed. It is also possible.

また、プログラムの終了近くのループでは、データ“4”への書き込みは終了している。このため、ベリファイ電位“d’”を用いたベリファイ動作を省略し、ベリファイ電位“d’”とベリファイ電位“e’”用いたベリファイ動作を省略することも可能である。   Further, in the loop near the end of the program, the writing to the data “4” is completed. Therefore, the verify operation using the verify potential “d ′” can be omitted, and the verify operation using the verify potential “d ′” and the verify potential “e ′” can be omitted.

第3ページ第1回目プログラムにおいて、フラグセルFC5は、ベリファイ電位“d’”に書き込まれる。   In the third page first program, the flag cell FC5 is written to the verify potential “d ′”.

(第2回目プログラム)(S108〜S121)
第2回目プログラムにより、メモリセルにデータ“1”〜“3”の3つが書き込まれるが、データ“1”を書き込むメモリセルには、全く書き込みが行なわれていない。このため、第1の実施形態と同様に、本来のベリファイ電位より低いベリファイ電位“a*’”を設け、このベリファイ電位を超えたセルに対して、ビット線に中間電位を供給する。これにより、書き込みスピードを遅くし、閾値分布を狭くする。また、メモリセルのデータ“2”とデータ“3”のベリファイは一括して行なうため、出来るだけ同時に書き込まれたほうが書き込み時間が早く終わる。したがって、メモリセルにデータ“2”を書き込んでいる場合にも、ビット線に中間電位を供給することにより、書き込みスピードを遅くする。
(Second program) (S108 to S121)
By the second program, three data “1” to “3” are written in the memory cell, but no data is written in the memory cell in which the data “1” is written. Therefore, as in the first embodiment, a verify potential “a * ′” lower than the original verify potential is provided, and an intermediate potential is supplied to the bit line for cells exceeding this verify potential. This slows down the writing speed and narrows the threshold distribution. In addition, since the data “2” and data “3” of the memory cell are verified in a lump, the writing time ends earlier if they are written simultaneously as much as possible. Therefore, even when data “2” is written in the memory cell, the write speed is reduced by supplying the intermediate potential to the bit line.

(内部データリード2及びデータキャッシュ設定2)(S109、S110)
第3のフラグセルのデータをロードした後(S108)、セルへの書き込みの前に、ワード線の電位を“b*(=a)”、“d*”に順次設定し、内部リード動作を行なう(S109)。
(Internal data read 2 and data cache setting 2) (S109, S110)
After the data of the third flag cell is loaded (S108), the potential of the word line is sequentially set to "b * (= a)" and "d *" before writing to the cell, and the internal read operation is performed. (S109).

この後、データキャッシュを操作することにより、図26に示すように、データキャッシュを設定する(S110)。すなわち、メモリセルにデータ“0”を書き込む場合、PDCはハイレベル、DDCはハイレベル、SDCはハイレベルに設定する。メモリセルにデータ“1”を書き込む場合、PDCはローレベル、DDCはローレベル、SDCはハイレベルに設定する。メモリセルにデータ“2”を書き込む場合、PDCはローレベル、DDCはハイレベル、SDCはローレベルに設定する。メモリセルにデータ“3”を書き込む場合、PDCはローレベル、DDCはローレベル、SDCはローレベルに設定する。メモリセルにデータ“4”〜“7”を書き込む場合、PDCは全てハイレベルに設定する。   Thereafter, by operating the data cache, the data cache is set as shown in FIG. 26 (S110). That is, when data “0” is written in the memory cell, the PDC is set to the high level, the DDC is set to the high level, and the SDC is set to the high level. When data “1” is written to the memory cell, PDC is set to low level, DDC is set to low level, and SDC is set to high level. When data “2” is written to the memory cell, PDC is set to low level, DDC is set to high level, and SDC is set to low level. When writing data “3” to the memory cell, PDC is set to low level, DDC is set to low level, and SDC is set to low level. When data “4” to “7” are written to the memory cells, all the PDCs are set to a high level.

ここで、例えばカウンタ(PC)をゼロに初期設定し、さらに、第4のフラグセルのデータをロードする。   Here, for example, the counter (PC) is initialized to zero, and the data of the fourth flag cell is loaded.

(プログラム:第2回目)(S111)
次いで、例えばカウンタ(PC)をカウントアップした後、メモリセルにデータが書き込まれる。先ず、信号BLC1をVsgとすると、PDCがデータ“0”の場合、ビット線がVssとなり、データ“1”の場合、ビット線はVddになる。次に、信号BLC1=Vssとした後、信号VREG=Vdd、信号REG=中間電位+Vth(1V+Vth)とする。すると、DDCがデータ“1”の場合、ビット線が中間電位(1V)となり、DDCがデータ“0”の場合、ビット線はプリチャージされない。この結果、メモリセルにデータ“3”を書き込んでいる時と、メモリセルにデータ“1”を書き込んでいて本来のベリファイ電位より低いベリファイ電位“a*’”以下の場合、ビット線は、Vssである。メモリセルにデータ“2”を書き込んでいる時と、メモリセルにデータ“1”を書き込んでいて本来のベリファイ電位より低いベリファイ電位“a*’”を越えている場合、ビット線は中間電位(1V)、メモリセルのデータが“0”、“4”〜“3”の場合(書き込みしない場合)、ビット線はVddになる。ここで、選択ワード線をVpgm、非選択ワード線をVpassとすると、ビット線がVddの場合、書き込みが行なわれない。また、ビット線がVssの場合、書き込みが起こり、ビット線が中間電位(1V)の場合、少しだけ書き込まれる。しかし、メモリセルにデータ“2”とデータ“3”を書き込む場合のベリファイは一括して行なうため、出来るだけ同時に書き込まれたほうが書き込み時間が早く終わる。したがって、ビット線に中間電位を供給する。
(Program: 2nd) (S111)
Next, for example, after counting up a counter (PC), data is written in the memory cell. First, when the signal BLC1 is Vsg, when the PDC is data “0”, the bit line is Vss, and when the data is “1”, the bit line is Vdd. Next, after setting the signal BLC1 = Vss, the signal VREG = Vdd and the signal REG = intermediate potential + Vth (1V + Vth). Then, when the DDC is data “1”, the bit line becomes an intermediate potential (1 V), and when the DDC is data “0”, the bit line is not precharged. As a result, when data “3” is written to the memory cell and when data “1” is written to the memory cell and the verify potential is “a * ′” lower than the original verify potential, the bit line is Vss. It is. When data “2” is written to the memory cell and when data “1” is written to the memory cell and the verify potential “a * ′” lower than the original verify potential is exceeded, the bit line has an intermediate potential ( 1V), when the data of the memory cell is “0”, “4” to “3” (when writing is not performed), the bit line becomes Vdd. Here, if the selected word line is Vpgm and the non-selected word line is Vpass, writing is not performed when the bit line is Vdd. In addition, when the bit line is Vss, writing occurs, and when the bit line is at the intermediate potential (1 V), writing is slightly performed. However, since the verify operation when data “2” and data “3” are written to the memory cell is performed in a lump, the write time ends earlier when data is simultaneously written as much as possible. Therefore, an intermediate potential is supplied to the bit line.

(e)ベリファイ電位“a’、a*’”を用いたベリファイは、第1の実施形態のベリファイ電位“a’、a*’”を用いたベリファイと同様である(S112、S113、S114)。 (E) The verification using the verification potentials “a ′, a * ′” is the same as the verification using the verification potentials “a ′, a * ′” in the first embodiment (S112, S113, S114). .

(f)ベリファイ電位“b’”のみを用いたベリファイは、第1の実施形態のベリファイ電位“b’”のみを用いたベリファイと同様である(S115、S116、S117)。 (F) The verification using only the verification potential “b ′” is the same as the verification using only the verification potential “b ′” in the first embodiment (S115, S116, S117).

(g)ベリファイ電位”b’”“c’”同時ベリファイは、第1の実施形態のベリファイ電位“b”、“c”同時ベリファイと同様である(S118、S119)。 (G) The verify potential “b ′” “c ′” simultaneous verify is the same as the verify potential “b”, “c” simultaneous verify of the first embodiment (S118, S119).

PDCがローレベルの場合、再び書き込み動作を行ない全てのデータ記憶回路のPDCのデータがハイレベルになるまでこのプログラム動作とベリファイ動作が繰り返される(S120、S121)。   When the PDC is at the low level, the write operation is performed again, and the program operation and the verify operation are repeated until the data in the PDC of all the data storage circuits becomes the high level (S120, S121).

上記説明では、1回のプログラムの後、3つのベリファイを行なっていた。しかし、プログラムの初期のループでは、閾値電圧が上がらないため、初めは、ベリファイ電位“a’、a*’”を用いたベリファイのみ行ない、次に、ベリファイ電位“a’、a*’”を用いたベリファイとベリファイ電位“b’”を行ない、最後に、ベリファイ電位“a’、a*’”を用いたベリファイとベリファイ電位”b’”“c’”同時ベリファイを行なうことも可能である。   In the above description, three verifications are performed after one program. However, since the threshold voltage does not increase in the initial loop of the program, first, only the verify using the verify potential “a ′, a * ′” is performed, and then the verify potential “a ′, a * ′” is applied. It is also possible to perform the verification and the verification potential “b ′” used, and finally perform the verification using the verification potentials “a ′ and a * ′” and the verification potential “b ′” and “c ′” simultaneously. .

また、プログラムの終了近くのループにおいて、データ“1”への書き込みは終了しているため、これらのベリファイ動作は省略することもできる。データ“1”のベリファイが不用になると、SDCでデータを保持する必要がなくなる。このため、次の書き込みのためのデータを外部より読み込み、SDCに記憶しておくことも可能である。このような構成とした場合、さらなる高速動作が可能である。   Further, since the writing to the data “1” is completed in the loop near the end of the program, these verify operations can be omitted. If the verification of the data “1” becomes unnecessary, it is not necessary to hold the data in the SDC. Therefore, it is possible to read data for the next writing from the outside and store it in the SDC. With such a configuration, further high-speed operation is possible.

第3ページ第2回目プログラムにおいて、フラグセルFC3は、ベリファイ電位“a’”まで書き込まれ、フラグセルFC4は、ベリファイ電位“b’”まで書き込まれる。   In the second page second program, the flag cell FC3 is written to the verify potential “a ′”, and the flag cell FC4 is written to the verify potential “b ′”.

(第1ページリード)
図27(a)は、第1ページのリード動作を示すダイアグラムである。
(First page lead)
FIG. 27A is a diagram showing the read operation of the first page.

先ず、アドレスを指定し、図19に示す3ページを選択する。図20(a)(b)(c)、図21(a)(b)に示すように、第2ページの書き込み前と後、及び第3ページの書き込み前と後で、閾値電圧の分布が変わっている。したがって、先ず、ワード線の電位を“d”として読み出し動作を行なう(S131)。この後、第3ページが書き込まれているかどうかをフラグセルFC5のデータから判別する(S132)。フラグセルが複数ある場合は、これらの多数決により判断する。   First, an address is designated and the three pages shown in FIG. 19 are selected. As shown in FIGS. 20A, 20B, and 21C, FIGS. 21A and 21B, the threshold voltage distribution is before and after the second page write and before and after the third page write. It has changed. Therefore, first, the read operation is performed with the word line potential set to “d” (S131). Thereafter, it is determined from the data of the flag cell FC5 whether the third page is written (S132). If there are a plurality of flag cells, the decision is made by these majority decisions.

フラグセルFC5から読み出されたデータが“0”場合、第3ページのデータが書き込まれている。閾値分布は図21(b)となっているため、ワード線の電位を“d”で読み出した結果が、既にデータ記憶回路10に読み出されている。このため、これらのデータを外部に出力すればよい(S133)。   When the data read from the flag cell FC5 is “0”, the third page data is written. Since the threshold distribution is shown in FIG. 21B, the result of reading the potential of the word line with “d” has already been read to the data storage circuit 10. For this reason, these data may be output to the outside (S133).

一方、フラグセルFC5から読み出されたデータが“1”場合、第3ページのデータが書き込まれていない。したがって、ワード線の電位を“d*”として読み出し動作を行なう(S134)。第2ページが書き込まれているかどうかフラグセルFC2から読み出されたデータに基づき判別する(S135)。フラグセルが複数ある場合は、これらの多数決により判断する。   On the other hand, when the data read from the flag cell FC5 is “1”, the data of the third page is not written. Therefore, the read operation is performed with the word line potential set to “d *” (S134). It is determined whether or not the second page is written based on the data read from the flag cell FC2 (S135). If there are a plurality of flag cells, the decision is made by these majority decisions.

フラグセルFC2から読み出されたデータが“0”場合、第2ページのデータが書き込まれている。閾値分布は図20(c)となっているため、ワード線の電位を“d*”で読み出した結果が、既にデータ記憶回路10に読み出されている。このため、これらのデータを外部に出力すればよい(S133)。   When the data read from the flag cell FC2 is “0”, the data of the second page is written. Since the threshold distribution is shown in FIG. 20C, the result of reading the potential of the word line with “d *” has already been read to the data storage circuit 10. For this reason, these data may be output to the outside (S133).

一方、フラグセルFC2から読み出されたデータが“1”の場合、第2ページのデータが書き込まれていない。したがって、ワード線の電位を“a”として読み出し動作を行ない読み出した結果を外部に出力すればよい(S136)。   On the other hand, when the data read from the flag cell FC2 is “1”, the data of the second page is not written. Therefore, the read operation is performed with the word line potential set to “a” and the read result is output to the outside (S136).

(第2ページリード)
図27(b)は、第2ページのリード動作を示すダイアグラムである。
(2nd page lead)
FIG. 27B is a diagram showing the read operation of the second page.

先ず、アドレスを指定し、図19に示す3ページを選択する。図20(a)〜(c)、図21(a)(b)に示すように、第2ページの書き込み前と後、及び第3ページの書き込み前と後で、閾値電圧の分布が変わっている。したがって、先ず、ワード線の電位を“b”として読み出し動作を行なう(S141)。この後、第3ページが書き込まれているかどうかフラグセルFC4から読み出したデータにより判別する(S142)。フラグセルが複数ある場合は、これらの多数決により判断する。   First, an address is designated and the three pages shown in FIG. 19 are selected. As shown in FIGS. 20A to 20C and FIGS. 21A and 21B, the threshold voltage distribution changes before and after writing the second page and before and after writing the third page. Yes. Therefore, first, the read operation is performed with the word line potential set to “b” (S141). Thereafter, whether or not the third page is written is determined based on the data read from the flag cell FC4 (S142). If there are a plurality of flag cells, the decision is made by these majority decisions.

フラグセルFC4から読み出されたデータが“0”場合、第3ページのデータが書き込まれている。閾値分布は図21(b)となっている。このため、ワード線電位“b”、“d”、“f”でメモリセルからデータを読み出す必要がある。しかし、ワード線電位“b”の読み出し結果は、既にデータ記憶回路に読み出されている。このため、ワード線電位“d”、“f”によりデータを読み出し、出力すればよい(S143、S144)。ワード線電位“d”、“f”による読み出しは、第1の実施形態の“b、c”同時リードと同様である。   When the data read from the flag cell FC4 is “0”, the third page data is written. The threshold distribution is shown in FIG. Therefore, it is necessary to read data from the memory cell with the word line potentials “b”, “d”, and “f”. However, the read result of the word line potential “b” has already been read to the data storage circuit. For this reason, it is only necessary to read and output data by the word line potentials “d” and “f” (S143, S144). Reading by the word line potentials “d” and “f” is the same as the “b, c” simultaneous reading in the first embodiment.

一方、フラグセルFC4から読み出されたデータが“1”の場合、第3ページのデータが書き込まれていない。したがって、ワード線の電位を“a”として読み出し動作を行なう(S145)。フラグセルFC1から読み出されてデータにより、第2ページが書き込まれているかどうかを判別する(S146)。フラグセルが複数ある場合、これらの多数決により判断する。   On the other hand, when the data read from the flag cell FC4 is “1”, the third page data is not written. Therefore, the read operation is performed with the word line potential set to “a” (S145). It is determined whether or not the second page is written based on the data read from the flag cell FC1 (S146). If there are a plurality of flag cells, the decision is made by these majority decisions.

フラグセルFC1から読み出されたデータが“0”の場合、第2ページのデータが書き込まれている。閾値分布は図20(c)となっているため、ワード線電位“b*”、“d*”、“f*”で読み出す必要がある。しかし、ワード線電位“b*”の読み出し結果は、既にデータ記憶回路10に読み出されている。このため、ワード線電位“d*”、“f*”でデータを読み出し出力する(S144)。ワード線電位“d*”、“f*”でのリードは、第1の実施形態の“b、c”同時リードと同様である。   When the data read from the flag cell FC1 is “0”, the data of the second page is written. Since the threshold distribution is as shown in FIG. 20 (c), it is necessary to read with the word line potentials “b *”, “d *”, and “f *”. However, the read result of the word line potential “b *” has already been read to the data storage circuit 10. For this reason, data is read and output at the word line potentials “d *” and “f *” (S144). Reading at the word line potentials “d *” and “f *” is the same as the “b, c” simultaneous reading in the first embodiment.

一方、フラグセルFC1から読み出されたデータが“1”の場合、第2ページのデータが書き込まれていない。したがって、データを“1”に固定して外部に出力すればよい(S148)。   On the other hand, when the data read from the flag cell FC1 is “1”, the data of the second page is not written. Therefore, the data may be fixed to “1” and output to the outside (S148).

(第3ページリード)
図28は、第2ページのリード動作を示すダイアグラムである。
(3rd page lead)
FIG. 28 is a diagram showing the read operation of the second page.

先ず、アドレスを指定し、図19に示す3ページを選択する。図20(a)(b)(c)、図21(a)(b)に示すように、第2ページの書き込み前と後、及び第3ページの書き込み前と後で、閾値電圧の分布が変わっている。したがって、ワード線電位“e、g”として読み出し(S151)、次いでワード線電位“a、c”として読み出し動作を行なう(S152)。この後、フラグセルFC3から読み出されたデータに基づき、第3ページが書き込まれているかどうかを判別する(S153)。フラグセルが複数ある場合は、これらの多数決により判断する。ワード線電位“e、g”、ワード線電位“a、c”のリード動作はは、第1の実施形態と同様である。   First, an address is designated and the three pages shown in FIG. 19 are selected. As shown in FIGS. 20A, 20B, and 21C, FIGS. 21A and 21B, the threshold voltage distribution is before and after the second page write and before and after the third page write. It has changed. Therefore, reading is performed as the word line potential “e, g” (S151), and then the reading operation is performed as the word line potential “a, c” (S152). Thereafter, based on the data read from the flag cell FC3, it is determined whether or not the third page has been written (S153). If there are a plurality of flag cells, the decision is made by these majority decisions. The read operation of the word line potential “e, g” and the word line potential “a, c” is the same as in the first embodiment.

フラグセルFC3から読み出されたデータが“0”場合、第3ページのデータが書き込まれている。閾値分布は図21(b)となっている。このため、ワード線電位“e、g”、ワード線電位“a、c”によりデータ記憶回路に読み出されているデータを出力すればよい(S154)。一方、フラグセルFC3から読み出されたデータが“1”の場合、第3ページのデータが書き込まれていない。このため、データを“1”に固定して外部に出力すればよい(S155)。   When the data read from the flag cell FC3 is “0”, the data of the third page is written. The threshold distribution is shown in FIG. For this reason, it is only necessary to output the data read to the data storage circuit by the word line potential “e, g” and the word line potential “a, c” (S154). On the other hand, when the data read from the flag cell FC3 is “1”, the data of the third page is not written. For this reason, the data may be fixed to “1” and output to the outside (S155).

(イレーズ)
消去動作は、第1の実施形態と同様であるため、説明は省略する。
(Erase)
Since the erase operation is the same as that of the first embodiment, the description thereof is omitted.

上記第2の実施形態によれば、8値(3ビット)のデータを確実且つ高速に書き込み、読み出すことができる。しかも、第3ページの書き込みにおいて、1回ビット線をプリチャージした状態において、ワード線の電位を変えることにより、複数の閾値電圧を一括してベリファイしている。このため、第3ページのプログラムベリファイを高速化することが可能である。   According to the second embodiment, 8-level (3-bit) data can be written and read reliably and at high speed. In addition, in the writing of the third page, a plurality of threshold voltages are collectively verified by changing the potential of the word line in a state where the bit line is precharged once. Therefore, it is possible to speed up the program verification of the third page.

第2の実施形態に示す、8値(3ビット)のNAND型フラッシュメモリは、第3ページの書き込み時、第1回目の書き込みで、データ“4”〜“7”を書き込み、第2回目の書き込みでデータ“1”〜“3”を書き込んだ。しかし、これに限定されるものではなく、先ず、データ“2”、“4”、“6”を書き込み、この後、データ“1”、“3”、“5”、“7”を書き込むことも可能である。   The 8-level (3-bit) NAND flash memory shown in the second embodiment writes data “4” to “7” in the first write when the third page is written, Data “1” to “3” were written. However, the present invention is not limited to this. First, data “2”, “4”, “6” are written, and then data “1”, “3”, “5”, “7” are written. Is also possible.

このような書き込みにおいても、第1の実施形態と同様の効果を得ることができる。   Even in such writing, the same effect as in the first embodiment can be obtained.

(第3の実施形態)
第2の実施形態において、フラグセルFC1〜FC5は次のように書き込まれていた。すなわち、第2ページの書き込みにおいて、フラグセルFC1は、ベリファイ電位“b*’”まで書き込まれ、フラグセルFC2は、ベリファイ電位“d*’”まで書き込まれ、第3ページの書き込みにおいて、フラグセルFC3は、ベリファイ電位“a’”まで書き込まれ、フラグセルFC4は、ベリファイ電位“b’”まで書き込まれ、フラグセルFC5は、ベリファイ電位“d’”まで書き込まれていた。このため、第2の実施形態は、5つのフラグセルを用いていた。しかし、フラグセルFC4をフラグセルFC1により代替し、フラグセルFC5をフラグセルFC2により代替することが可能である。このため、図19に示す回路は、3つのフラグ用データ記憶回路と、3つのフラグセルFC1、FC2、FC3により構成することが可能である。
(Third embodiment)
In the second embodiment, the flag cells FC1 to FC5 are written as follows. That is, in the second page write, the flag cell FC1 is written to the verify potential “b * ′”, the flag cell FC2 is written to the verify potential “d * ′”, and in the third page write, the flag cell FC3 is The write is performed up to the verify potential “a ′”, the flag cell FC4 is written up to the verify potential “b ′”, and the flag cell FC5 is written up to the verify potential “d ′”. For this reason, the second embodiment uses five flag cells. However, the flag cell FC4 can be replaced by the flag cell FC1, and the flag cell FC5 can be replaced by the flag cell FC2. Therefore, the circuit shown in FIG. 19 can be constituted by three flag data storage circuits and three flag cells FC1, FC2, and FC3.

上記構成において、第1、第2ページの書き込み動作は、第2の実施形態と同様であり、第3のページの書き込み動作が若干異なっている。   In the above configuration, the first and second page write operations are the same as in the second embodiment, and the third page write operation is slightly different.

図29、図30は、第3ページの書き込み動作を示している。図29に示す第3ページ第1回目の書き込みにおいて、図23と異なるのは、内部リード(S93)後のフラグセルデータのロードである。第2の実施形態は、第5のフラグセルFC5にデータをロードしていた(S94)。これに対して、第3の実施形態は、内部リード(S93)後、フラグセルFC2にデータをロードする(S151)。   29 and 30 show a third page write operation. In the first write of the third page shown in FIG. 29, the difference from FIG. 23 is the loading of flag cell data after the internal read (S93). In the second embodiment, data is loaded into the fifth flag cell FC5 (S94). In contrast, in the third embodiment, data is loaded into the flag cell FC2 after the internal read (S93) (S151).

また、図29に示す第3ページ第2回目の書き込みにおいて、図24と異なるのは、内部リード(S109)後のフラグセルデータのロードである。第2の実施形態は、第4のフラグセルFC4にデータをロードしていた(S110)。これに対して、第3の実施形態は、内部リード(S93)後、フラグセルFC1にデータをロードする(S161)。   In the second write of the third page shown in FIG. 29, the difference from FIG. 24 is the loading of flag cell data after the internal read (S109). In the second embodiment, data is loaded into the fourth flag cell FC4 (S110). On the other hand, in the third embodiment, after internal reading (S93), data is loaded into the flag cell FC1 (S161).

前述したように、第2ページの書き込みにおいて、フラグセルFC1は、ベリファイ電位“b*’”まで書き込まれ、フラグセルFC2は、ベリファイ電位“d*’”まで書き込まれる。次いで、図29、図30に示す書き込み動作により、第3ページの書き込みにおいて、フラグセルFC3は、ベリファイ電位“a’”まで書き込まれる。第2ページの書き込みにおいて、ベリファイ電位“b*’”まで書き込まれたフラグセルFC1は、第3ページの書き込みによりベリファイ電位“b’”まで書き込まれる。第2ページの書き込みにおいて、ベリファイ電位“d*’”まで書き込まれたフラグセルFC2は、第3ページの書き込みによりベリファイ電位“d’”まで書き込まれる。   As described above, in the second page write, the flag cell FC1 is written to the verify potential “b * ′”, and the flag cell FC2 is written to the verify potential “d * ′”. Next, by the write operation shown in FIGS. 29 and 30, in the third page write, the flag cell FC3 is written to the verify potential “a ′”. The flag cell FC1 written to the verify potential “b * ′” in the second page write is written to the verify potential “b ′” by the third page write. In the second page write, the flag cell FC2 written to the verify potential “d * ′” is written to the verify potential “d ′” by the third page write.

図31(a)は、第1ページの読み出しアルゴリズムを示し、図31(b)は第2ページの読み出しアルゴリズムを示している。   FIG. 31A shows the first page read algorithm, and FIG. 31B shows the second page read algorithm.

図31(a)において、図27(a)と異なるのは、電位“d”による読み出し(S131)の後の判別である。第2の実施形態において、この判別は、フラグセルFC5から読み出したデータに基づいて行なった(S132)。これに対して、第3の実施形態において、この判別は、フラグセルFC2から読み出したデータに基づいて行なわれる(S201)。その他の動作は、図27(a)と同様である。   In FIG. 31A, the difference from FIG. 27A is the determination after reading (S131) by the potential “d”. In the second embodiment, this determination is made based on the data read from the flag cell FC5 (S132). In contrast, in the third embodiment, this determination is performed based on the data read from the flag cell FC2 (S201). Other operations are the same as those in FIG.

また、図31(b)において、図27(b)と異なるのは、電位“b”による読み出し(S141)の後の判別である。第2の実施形態において、この判別は、フラグセルFC4から読み出したデータに基づいて行なった(S142)。これに対して、第3の実施形態において、この判別は、フラグセルFC2から読み出したデータに基づいて行なわれる(S211)。その他の動作は、図27(b)と同様である。   In FIG. 31 (b), the difference from FIG. 27 (b) is the determination after reading (S141) by the potential “b”. In the second embodiment, this determination is made based on the data read from the flag cell FC4 (S142). In contrast, in the third embodiment, this determination is performed based on the data read from the flag cell FC2 (S211). Other operations are the same as those in FIG.

第3ページの読み出しアルゴリズムは、図28に示す第2の実施形態と同様である。   The algorithm for reading the third page is the same as that of the second embodiment shown in FIG.

上記第3の実施形態によれば、3つのフラグ用データ記憶回路と、3つのフラグセルにより、第2の実施形態と同様にプログラムベリファイを高速化することができる。しかも、フラグ用データ記憶回路とフラグセルの数を削減することができるため、チップの占有面積を削減できる利点を有している。   According to the third embodiment, the program verification can be speeded up by the three flag data storage circuits and the three flag cells as in the second embodiment. In addition, since the number of flag data storage circuits and flag cells can be reduced, the area occupied by the chip can be reduced.

尚、上記第1の実施形態の第2ページの書き込み、及び第2、3の実施形態の第3ページの書き込みにおいて、メモリセルにデータ“1”を書き込んだ場合、SDCが空く。このため、SDCに、次に書き込むべきデータを供給することが可能である。このように、次に書き込むべきデータを予めSDCに記憶させることにより、一層書き込み速度を高速化することができる。   In addition, when data “1” is written in the memory cell in the second page writing of the first embodiment and the third page writing of the second and third embodiments, the SDC becomes empty. Therefore, it is possible to supply data to be written next to the SDC. In this way, the data to be written next is stored in advance in the SDC, so that the writing speed can be further increased.

さらに、SDCが空いた場合、プログラム動作を一時停止し、別のページのメモリセルからデータを読み出し、この読み出し結果をSDCに記憶し、SDCから外部に出力している間に、停止していたプログラム動作を再開するように構成することも可能である。   Further, when the SDC becomes empty, the program operation is temporarily stopped, data is read from the memory cell of another page, the read result is stored in the SDC, and stopped while being output from the SDC to the outside. It is also possible to configure to resume the program operation.

尚、フラグセルの数及び配置は、上記各実施形態に限定されるものではない。   The number and arrangement of flag cells are not limited to the above embodiments.

図32は、フラグセルを複数配置した場合の例を示すものである。この例は、信頼性を向上させるため、メモリセルアレイの一端部に複数の第1、第2のフラグセルとダミーセルを配置している。すなわち、偶数ページ(BLE)用に4個の第1のフラグセルと、3個の第2のフラグセルを配置し、奇数ページ(BLO)用に4個の第1のフラグセルと、3個の第2のフラグセルを配置している。偶数、及び奇数ページ用の第2のフラグセルの両側には偶数用ダミーセル、奇数用ダミーセルが配置されている。   FIG. 32 shows an example in which a plurality of flag cells are arranged. In this example, in order to improve the reliability, a plurality of first and second flag cells and dummy cells are arranged at one end of the memory cell array. That is, four first flag cells and three second flag cells are arranged for even pages (BLE), and four first flag cells and three second flags cells are arranged for odd pages (BLO). The flag cells are arranged. Even-numbered dummy cells and odd-numbered dummy cells are arranged on both sides of the second flag cell for even-numbered and odd-numbered pages.

このような構成において、データの読み出し時に、遇数ページの4個の第1のフラグセルの多数決と、3個の第2のフラグセルの多数決を求めることにより、遇数ページにおける第2ページの書き込みの有無を判断する。また、奇数ページ用の4個の第1のフラグセルの多数決と、3個の第2のフラグセルの多数決を求めることにより、奇数ページにおける第2ページの書き込みの有無を判断する。このような構成とすれば、隣接するセルのFG−FG間容量により、後に書いた隣接セルの閾値電圧により、先に書いたセルの閾値電圧が変化した場合においても、確実に第2ページが書き込まれたかどうかを判断することができる。   In such a configuration, when data is read, the majority of the four first flag cells of the adjective page and the majority of the three second flag cells are obtained, so that the writing of the second page on the adjective page is performed. Judgment is made. Further, by determining the majority of the four first flag cells for odd pages and the majority of the three second flag cells, it is determined whether or not the second page is written in the odd pages. With such a configuration, even if the threshold voltage of the previously written cell changes due to the threshold voltage of the adjacent cell written later due to the FG-FG capacitance of the adjacent cell, the second page is surely displayed. It can be determined whether or not it has been written.

(第4の実施形態)
多値データを記憶する不揮発性半導体記憶装置の場合、記憶するデータのビット数が多い場合、1つの閾値分布を狭くしなくてはならない。このため、プログラム及びベリファイ動作において、プログラム電圧を少しずつ上昇させて書き込み動作を行ない、本来のベリファイ電位より低いベリファイ電位を超えた場合、ビット線に中間電位を入力することにより、プログラム動作中の書き込みスピードを遅くし、この状態で本来のベリファイ電位まで書き込むことが提案されている。しかし、本来より低いベリファイ電位を超えていることと、本来のベリファイ電位を超えていることの区別が必要である。このため、ページバッファの数が増大するという課題がある。
(Fourth embodiment)
In the case of a nonvolatile semiconductor memory device that stores multilevel data, if the number of bits of data to be stored is large, one threshold distribution must be narrowed. For this reason, in the program and verify operations, the program voltage is gradually increased to perform the write operation. When the verify potential lower than the original verify potential is exceeded, an intermediate potential is input to the bit line to It has been proposed to reduce the writing speed and write to the original verify potential in this state. However, it is necessary to distinguish between exceeding the original verify potential and exceeding the original verify potential. For this reason, there is a problem that the number of page buffers increases.

第4の実施形態は、第1の実施形態とほぼ同様の動作であるが、第2ページのプログラムベリファイにおけるベリファイ電位“b’”“c’”によるデータ“2”、“3”の同時ベリファイのみが異なっている。第1の実施形態において、閾値電圧“b’”“c’”に書き込むセルは、本来の閾値電圧より低いベリファイ電位まで書き込み、このベリファイ電位を超えたセルに対しては、ビット線に中間電位を供給して書き込みスピードを遅くし、閾値電圧の分布幅を狭めることはしなかった。閾値電圧“b’”に書き込むセルは、図33(a)に示すように、第1ページの書き込み時に“v’”のレベルまで書き込みが行われている。したがって、書き込みスピードが遅くなるため、このような操作は、不必要であるかもしれない。しかし、閾値電圧“c’”に書き込むセルも、第1ページの書き込み時に“v’”のレベルまで書き込まれているが、“v’”と“c’”のレベルに差がある。このため、閾値電圧“c’”のベリファイにおいて、本来の閾値電圧より低いベリファイ電位まで書き込み、このレベルを超えたセルに対しては、ビット線に中間電位を供給して書き込みスピードを遅くし閾値分布幅を狭めたほうがよい。このため、閾値電圧“c’”のベリファイでは、先ず、本来より低いベリファイ電位“c*’”と、本来のベリファイ電位“c’”とで行なう。   In the fourth embodiment, the operation is almost the same as that of the first embodiment, but the simultaneous verification of data “2” and “3” by the verify potentials “b ′” and “c ′” in the program verify of the second page is performed. Only is different. In the first embodiment, the cells written to the threshold voltages “b ′” and “c ′” are written up to the verify potential lower than the original threshold voltage, and for the cells exceeding the verify potential, the intermediate potential is applied to the bit line. The write speed was slowed down and the threshold voltage distribution width was not narrowed. As shown in FIG. 33A, the cell written to the threshold voltage “b ′” is written to the level “v ′” when the first page is written. Therefore, this operation may be unnecessary because the writing speed is slowed down. However, the cells written to the threshold voltage “c ′” are also written to the “v ′” level when the first page is written, but there is a difference between the levels of “v ′” and “c ′”. Therefore, in verifying the threshold voltage “c ′”, writing is performed up to a verify potential lower than the original threshold voltage, and for cells exceeding this level, an intermediate potential is supplied to the bit line to slow down the write speed and It is better to narrow the distribution width. For this reason, the verification of the threshold voltage “c ′” is first performed with the verification potential “c * ′” lower than the original and the original verification potential “c ′”.

図34は、第4の実施形態に係る第1ページの書き込み動作を示している。図34のS301〜S308に示す第1の書き込み動作、及び図36に示すデータキャッシュにデータは、第1の実施形態と同様であるため、説明は省略する。   FIG. 34 shows a first page write operation according to the fourth embodiment. Since the first write operation shown in S301 to S308 in FIG. 34 and the data in the data cache shown in FIG. 36 are the same as those in the first embodiment, description thereof will be omitted.

図35は、第2ページの書き込み動作を示している。第2ページの書き込みにおいて、S311〜S322までの動作は、第1の実施形態と殆ど同じである。しかし、ベリファイ電位“b”“c*’”“c’”による同時ベリファイが第1の実施形態と異なっている。   FIG. 35 shows the write operation of the second page. In writing the second page, the operations from S311 to S322 are almost the same as in the first embodiment. However, the simultaneous verification by the verification potentials “b”, “c * ′”, and “c ′” is different from the first embodiment.

(ベリファイ電位“b”“c*’”“c’”同時ベリファイ)(図37、図38)。 (Verify potential “b” “c * ′” “c ′” simultaneous verify) (FIGS. 37 and 38).

図35において、プログラム及びベリファイファイを何回か繰り返すと、メモリセルにデータ“3”を書き込みでいるセルも書き込みが終了する。このため、ベリファイ電位“b’”を用いたベリファイ(S322)に替わり、ベリファイ電位“b’”“c*’”“c’”を用いた同時ベリファイを行なう(S324)。先ず、信号BLPRE=ハイレベル(Vdd+Vth)、VPRE=ハイレベル(Vdd+Vth)、信号BLCLAMPを所定電位に設定し、ビット線をプリチャージする。   In FIG. 35, when the program and verify are repeated several times, the writing of data “3” to the memory cell is also completed. Therefore, instead of verify using the verify potential “b ′” (S322), simultaneous verify using the verify potentials “b ′”, “c * ′”, and “c ′” is performed (S324). First, the signal BLPRE = high level (Vdd + Vth), VPRE = high level (Vdd + Vth), the signal BLCLAMP is set to a predetermined potential, and the bit line is precharged.

次に、ワード線にベリファイ電位“b’”を供給しビット線を放電する。ビット線の放電中にDDCのデータをTDCに移す。この後、PDCのデータをDDCに移し、TDCのデータをPDCに移す。   Next, the verify potential “b ′” is supplied to the word line to discharge the bit line. DDC data is transferred to TDC during bit line discharge. Thereafter, the PDC data is transferred to the DDC, and the TDC data is transferred to the PDC.

この後、TDCをVddに充電した後、信号BLCLAMPを所定の電位とする。すると、TDCが“1”(ハイレベル)になるのは、閾値電圧がベリファイ電位“b’”以上の場合である。ここで、信号BLC1が中間電位、例えばVth+0.5Vであるとすると、PDCが“0”(ローレベル)の場合(メモリセルのデータ“3”に書き込んでいる場合と、メモリセルにデータ“1”を書き込んでいる場合で、ベリファイ電位“a*’”以下の場合)、TDCはVssになる。したがって、TDCがVddになるのは、メモリセルがデータ“2”に書き込まれていて、ベリファイ電位“b’”に達した時である。次に、信号VREGをハイレベル(例えばVdd)、信号REGをVsg(例えばVdd+Vth)とすると、DDCのデータがハイレベルの場合、強制的にTDCがハイレベルとなる。したがって、TDCがVddになるのは、メモリセルにデータ“2”を書き込んでいてベリファイ電位“b’”に達した時と、書き込み非選択の場合である。信号DTGをVsgとし、PDCのデータをDDCにコピーした後、信号BLC1をVsgとしてTDCの電位をPDCに取りこむ。   Thereafter, after charging TDC to Vdd, the signal BLCLAMP is set to a predetermined potential. Then, the TDC becomes “1” (high level) when the threshold voltage is equal to or higher than the verify potential “b ′”. Here, assuming that the signal BLC1 is an intermediate potential, for example, Vth + 0.5V, when the PDC is “0” (low level) (when writing to the data “3” of the memory cell, and when data “1” is stored in the memory cell). "Is written and the verify potential is lower than" a * '"), TDC becomes Vss. Therefore, TDC becomes Vdd when the memory cell is written in data “2” and reaches verify potential “b ′”. Next, when the signal VREG is set to a high level (for example, Vdd) and the signal REG is set to Vsg (for example, Vdd + Vth), when the data of the DDC is at a high level, the TDC is forcibly set to a high level. Therefore, TDC becomes Vdd when data “2” is written in the memory cell and the verify potential “b ′” is reached, and when writing is not selected. After the signal DTG is set to Vsg and the data of the PDC is copied to the DDC, the signal BLC1 is set to Vsg and the potential of the TDC is taken into the PDC.

次に、ワード線にベリファイ電位“c*’”を供給しビット線を放電する。   Next, the verify potential “c * ′” is supplied to the word line to discharge the bit line.

この後、TDCをVddに充電した後、信号BLCLAMPを所定の電位とする。TDCがVddになるのは、メモリセルのデータを“3”に書き込みを行なっていてベリファイ電位“c*’”に達した時である。次に、信号VREGをハイレベル、信号REGをVsgとすると、DDCのデータがハイレベルの場合、強制的にTDCがハイレベルとなる。したがって、TDCがVddになるのは、メモリセルにデータ“3”を書き込んでいてベリファイ電位“c*’”に達した時と、メモリセルにデータ“2”を書き込んでいる場合と、メモリセルにデータ“1”を書き込んでいる場合で、ベリファイ電位“a*’”が以上の場合である。信号DTGをVsgとし、PDCのデータをDDCにコピーした後、信号BLC1をVdd+VthとしてTDCの電位をPDCに取りこむ。   Thereafter, after charging TDC to Vdd, the signal BLCLAMP is set to a predetermined potential. TDC becomes Vdd when data in the memory cell is written to “3” and reaches verify potential “c * ′”. Next, when the signal VREG is set to the high level and the signal REG is set to Vsg, when the data of the DDC is at the high level, the TDC is forcibly set to the high level. Therefore, TDC becomes Vdd when data “3” is written in the memory cell and the verify potential “c * ′” is reached, when data “2” is written in the memory cell, This is the case where the data “1” is written in the memory and the verify potential “a * ′” is equal to or higher than the above. After the signal DTG is set to Vsg and the data of the PDC is copied to the DDC, the signal BLC1 is set to Vdd + Vth and the potential of the TDC is taken into the PDC.

次に、ワード線にベリファイ電位“c’”を供給しビット線を放電する。   Next, the verify potential “c ′” is supplied to the word line to discharge the bit line.

この後、TDCをVddに充電した後、信号BLCLAMPを所定の電位とする。TDCがVddになるのは、メモリセルのデータが“3”に書き込まれていてベリファイ電位“c’”に達した時である。次に、信号VREGをハイレベルとし、信号REGをVsgとすると、DDCのデータがハイレベルの場合、強制的にTDCがハイレベルとなる。したがって、TDCがVddになるのは、メモリセルにデータ“3”を書き込んでいてベリファイ電位“c’”に達した時と、書き込み非選択の場合である。さらに、信号DTGをVsgとし、PDCのデータをDDCにコピーした後、信号BLC1をVsgとしてTDCの電位をPDCに取りこむ。   Thereafter, after charging TDC to Vdd, the signal BLCLAMP is set to a predetermined potential. The TDC becomes Vdd when the data in the memory cell is written to “3” and reaches the verify potential “c ′”. Next, when the signal VREG is set to high level and the signal REG is set to Vsg, when the data of the DDC is high level, the TDC is forcibly set to high level. Therefore, TDC becomes Vdd when data “3” is written in the memory cell and the verify potential “c ′” is reached, and when writing is not selected. Further, after the signal DTG is set to Vsg and the data of the PDC is copied to the DDC, the signal BLC1 is set to Vsg and the potential of the TDC is taken into the PDC.

これらの動作により、メモリセルにデータ“3”を書き込んでいて、ベリファイ電位“c*’”を超え、本来のベリファイ電位での書き込みが完了とならなかった場合、DDCはハイレベル、PDCはローレベル、SDCはローレベルとなり、メモリセルにデータ“2”を書き込んでいる場合と同様になる。このため、次のプログラムにおいて、DDCはハイレベルとなっているため、ビット線が中間電位(例えば1V)となり書き込みが行われる。   By these operations, when data “3” is written in the memory cell, the verify potential “c * ′” is exceeded, and writing at the original verify potential is not completed, DDC is high level and PDC is low level. The level and SDC become low level, which is the same as when data “2” is written in the memory cell. For this reason, in the next program, since DDC is at a high level, the bit line is set to an intermediate potential (for example, 1 V) and writing is performed.

また、この後、ベリファイ電位“b’”“c*’”“c’”同時ベリファイにおいて、閾値電圧“b’”のベリファイ時に、閾値電圧は当然“c*’”以上にあるため、このベリファイはパスし、PDCがハイレベルとなる。したがって、メモリセルにデータ“3”を書き込んでいて、ベリファイ電位“c*’”を超えた場合、1回だけビット線を中間電位にして書き込みが行なわれる。   After this, in the verify potential “b ′” “c * ′” “c ′” simultaneous verification, the threshold voltage is naturally “c * ′” or higher when the threshold voltage “b ′” is verified. Pass and the PDC goes high. Therefore, when data “3” is written to the memory cell and the verify potential “c * ′” is exceeded, writing is performed with the bit line set to the intermediate potential only once.

このようにして、全てのPDCのデータが“1”になるまで、プログラムとベリファイ動作が繰り返される。しかし、書き込み動作において、DDCのデータが“1”の場合、つまり、メモリセルにデータ“2”を書き込んでいる場合と、メモリセルにデータ“3”を書き込んでいてベリファイ電位“c*’”を超えたとき(これはメモリセルにデータ“2”を書き込んでいる場合と同じになる)、とデータ“1”を書き込んでいてベリファイ電位“a*’”を超えている場合、ビット線を中間電位にして書き込み動作をする。   In this way, the program and verify operation are repeated until the data of all PDCs becomes “1”. However, in the write operation, when the DDC data is “1”, that is, when the data “2” is written in the memory cell, the data “3” is written in the memory cell and the verify potential “c * ′” Is exceeded (this is the same as when data “2” is written to the memory cell), and when data “1” is written and the verify potential “a * ′” is exceeded, the bit line is turned on. Write operation is performed at an intermediate potential.

また、プログラムとベリファイ動作を繰り返す毎に、プログラム電圧Vpgmを少しずつ上昇させる。このプログラム電圧Vpgmの増分ΔVpgmは、第1ページの書き込み動作と、第2の書き込み動作で相違されており、例えば第1ページの書き込み動作における増分ΔVpgmは、第2の書き込み動作における増分ΔVpgmより大きく設定されている。   Further, each time the program and verify operations are repeated, the program voltage Vpgm is gradually increased. The increment ΔVpgm of the program voltage Vpgm is different between the first page write operation and the second write operation. For example, the increment ΔVpgm in the first page write operation is larger than the increment ΔVpgm in the second write operation. Is set.

図35に示すフローチャートでは、プログラムとベリファイ“a*,a’”(S316,S319)を数回繰り返した後に、プログラムとベリファイ“a*’,a’”とプログラムベリファイ“b’”を数回繰り返し、プログラムとベリファイ“a*’,a’”とプログラムベリファイ“b’,c’”を数回繰り返す。この途中でメモリセルへのデータ“1”の書き込みは、早く終了する。このため、データ“1”を書き込むべきセルが無くなった場合、プログラムベリファイ“a*’,a’”をスキップし(S318〜S320)、プログラムとプログラムベリファイ“b’”(S316、S322)、又はプログラムとプログラムベリファイ“b’,c*’,c’”(S316−S326)を繰り返すようになる。プログラムとベリファイ“a*’,a’”(S316、S319)をスキップする場合、SDCは使用しなくなる。このため、次のプログラムデータを入力することができる。しかし、稀に、メモリセルにデータ“1”がなかなか書けないセルもある。したがって、プログラムベリファイ“a*,a’”の回数を制限している。   In the flowchart shown in FIG. 35, the program and verify “a *, a ′” (S316, S319) are repeated several times, and then the program, verify “a * ′, a ′” and program verify “b ′” are performed several times. The program, verify “a * ′, a ′” and program verify “b ′, c ′” are repeated several times. In the middle of this, the writing of data “1” to the memory cell is completed early. Therefore, when there is no cell to which data “1” is to be written, program verify “a * ′, a ′” is skipped (S318 to S320), and program and program verify “b ′” (S316, S322), or The program and program verify “b ′, c * ′, c ′” (S316-S326) are repeated. When the program and verify “a * ′, a ′” (S316, S319) are skipped, the SDC is not used. Therefore, the next program data can be input. However, rarely, there are some cells in which data “1” cannot be written easily. Therefore, the number of program verify “a *, a ′” is limited.

(リード動作)
リード動作は、第1の実施形態と同様である。
(Read operation)
The read operation is the same as in the first embodiment.

(イレーズ)
消去動作は、前述したように、先ず、アドレスを指定し、図3の破線で示すブロックを選択する。次に、セルが形成されたウエルの電位を高電圧(約20V)にし、選択ブロックのワード線をVss、非選択ブロックのワード線をフローティングにする。すると、選択ブロックのセルとウエル間に高電圧が加わり、セルに記憶されたデータが消去される。一方、非選択ブロックにおいて、ワード線はフローティング状態であるため、ウエルを高電圧にすると、ワード線も高電圧になる。このため、非選択ブロックのメモリセルに記憶されたデータは消去されない。
(Erase)
As described above, in the erase operation, first, an address is designated, and a block indicated by a broken line in FIG. 3 is selected. Next, the potential of the well in which the cell is formed is set to a high voltage (about 20 V), the word line of the selected block is set to Vss, and the word line of the non-selected block is floated. Then, a high voltage is applied between the cell and the well of the selected block, and the data stored in the cell is erased. On the other hand, since the word line is in a floating state in the non-selected block, when the well is set to a high voltage, the word line also becomes a high voltage. For this reason, data stored in the memory cells of the non-selected block is not erased.

消去動作を行なうと、メモリセルのデータは“0”となり、第1ページ、第2ページの何れでリードを行なってもデータ“1”が出力される。   When the erase operation is performed, the data in the memory cell becomes “0”, and data “1” is output regardless of whether reading is performed on the first page or the second page.

(消去後書き込み)
図33(e)は、消去後の閾値電圧の例を示している。上記のように、消去動作はブロック内の複数のメモリセルのデータを一括して消去するため、図33(e)に示すように、図33(a)に示す閾値電圧より低い電圧まで消去されている場合がある。このように、本来の閾値電圧より低い電圧まで消去されているメモリセルがある場合、アッパーページ(例えば2ページ)のプログラムにおいて、メモリセルのデータ“0”を“1”に書き込む際、閾値電圧が変化する範囲が大きくなる。このため、浮遊ゲートと浮遊ゲートのカップリングにより、隣接するセルの閾値電圧が変化してしまう。
(Write after erase)
FIG. 33 (e) shows an example of the threshold voltage after erasure. As described above, since the erase operation erases data in a plurality of memory cells in the block at a time, as shown in FIG. 33 (e), the data is erased to a voltage lower than the threshold voltage shown in FIG. 33 (a). There may be. In this way, when there is a memory cell that has been erased to a voltage lower than the original threshold voltage, the threshold voltage when writing the memory cell data “0” to “1” in the upper page (for example, page 2) program The range that changes is increased. For this reason, the threshold voltage of an adjacent cell changes due to coupling between the floating gate and the floating gate.

したがって、図33(f)に示すように、隣接するセルの閾値電圧の変化を防止するため、消去後、僅かな書き込みを行ない。本来の閾値電圧より低い負の電圧まで消去されているセルの閾値電圧を本来の閾値電圧までもどす。   Therefore, as shown in FIG. 33 (f), in order to prevent a change in the threshold voltage of adjacent cells, a slight write is performed after erasure. The threshold voltage of the cell erased to a negative voltage lower than the original threshold voltage is returned to the original threshold voltage.

消去後書き込みにおいて、先ず、全データ記憶回路のPDCがローレベルにセットされる。この後、データ記憶回路に接続された2本のビット線BLEとBLOに接続されたセルに対して同時に書き込み動作を行なう。書き込みベリファイは、2本のビット線のうち1本ずつ行なう。しかし、フロック内の全セルについてベリファイを行なうと時間がかかるため、全部のワード線を同一電位とし、1つのNANDセルを一括してベリファイする。一方のビット線に関して、消去後の書き込みが完了した場合、PDCがハイレベルとなるようにし、次のプログラムが行なわないようにする。同様にして他方のビット線に関してベリファイ動作を行ない、全データ記憶回路のデータがハイレベルになるまで書き込み及びベリファイ動作を繰り返す。   In writing after erasure, first, the PDCs of all data storage circuits are set to a low level. Thereafter, the write operation is simultaneously performed on the cells connected to the two bit lines BLE and BLO connected to the data storage circuit. Write verify is performed one by one of the two bit lines. However, since it takes time to verify all the cells in the floc, all the word lines are set to the same potential, and one NAND cell is verified collectively. When writing after erasure is completed for one of the bit lines, the PDC is set to high level so that the next program is not performed. Similarly, the verify operation is performed on the other bit line, and the write and verify operations are repeated until the data in all the data storage circuits become high level.

上記第4の実施形態によれば、第2ページの書き込みベリファイ動作の途中において、一度のビット線の充電に対して、ワード線の電位を閾値電圧“b’,c*’,c’”の順に変更し、閾値電圧“b’,c*’,c’”を一括してベリファイしている。このため、高速なベリファイが可能であるため、高速な書き込みが可能となる。   According to the fourth embodiment, the potential of the word line is set to the threshold voltage “b ′, c * ′, c ′” for one bit line charge during the write verify operation of the second page. The threshold voltages “b ′, c * ′, c ′” are verified in batch by changing in order. For this reason, since high-speed verification is possible, high-speed writing is possible.

また、メモリセルにデータ“3”を書き込んでいる際において、本来のベリファイ電位より僅かに低いベリファイ電位を超えた場合、ビット線に中間電位を供給して書き込みを行なっている。このため、メモリセルに書き込まれる閾値電圧の分布を狭くすることができる。したがって、書き込み時の電圧のステップアップ幅を大きくすることが可能であるため、全体的な書き込み時間を短縮でき、高速な書き込みが可能となる。   In addition, when data “3” is written in the memory cell, if the verify potential is slightly lower than the original verify potential, the intermediate potential is supplied to the bit line for writing. For this reason, the distribution of the threshold voltage written in the memory cell can be narrowed. Accordingly, since the voltage step-up width at the time of writing can be increased, the overall writing time can be shortened and high-speed writing can be performed.

つまり、書き込み動作により、メモリセルが、データ“3”の閾値電圧に達したかどうかをベリファイする場合、本来のベリファイ電位“c’”より低いベリファイ電位“c*’”でベリファイし、この低いベリファイ電位“c*’”を超えていて、本来のベリファイ電位“c’”で書き込みが完了とならなかった場合、データ記憶回路内のDDC,PDC,SDCはデータ“2”を書き込む時のデータとなるため、次の書き込みではビット線に中間電位を供給し、書き込みスピードを遅くしている。この後、データ“2”のベリファイ時、このメモリセルはベリファイをパスするため、このセルの書き込みは終了する。このため、メモリセルに書き込まれる閾値電圧の分布を狭くすることができる。   That is, when verifying whether or not the memory cell has reached the threshold voltage of data “3” by the write operation, verify is performed at a verify potential “c * ′” lower than the original verify potential “c ′”, and this low If the verify potential “c * ′” is exceeded and writing is not completed at the original verify potential “c ′”, the DDC, PDC, and SDC in the data storage circuit are the data when the data “2” is written. Therefore, in the next writing, an intermediate potential is supplied to the bit line to slow down the writing speed. Thereafter, at the time of verifying the data “2”, the memory cell passes the verify, and the writing of this cell is completed. For this reason, the distribution of the threshold voltage written in the memory cell can be narrowed.

しかも、本来のベリファ電位より低いベリファイ電位を超えているメモリセルと、本来のベリファイ電位を超えているメモリセルとを区別のためのデータ記憶回路を必要としないため、回路構成の増加を防止できる。   In addition, since a data storage circuit is not required to distinguish between a memory cell exceeding a verify potential lower than the original verify potential and a memory cell exceeding the original verify potential, an increase in circuit configuration can be prevented. .

(第5の実施形態)
上記第4の実施形態において、第2ページの書き込みは、次のように行っていた。すなわち、データ“3”を書き込むセルにおいて、本来のベリファイ電位“c’”より低いベリファイ電位“c*’”を超えるセルに対し、中間電位を供給して、1回のみ書き込みを行ない、この後、書き込み完了としていた。しかし、データ“1”を書き込むセルについては、本来のベリファイ電位“a’”より低いベリファイ電位“a*’”を超えるセルに対して、中間電位を供給し、本来のベリファイ電位“a’”まで書き込みを繰り返し行っていた。したがって、書き込むデータに応じて動作が若干異なっている。
(Fifth embodiment)
In the fourth embodiment, the second page is written as follows. That is, in the cell to which data “3” is written, the intermediate potential is supplied to the cell exceeding the verify potential “c * ′” lower than the original verify potential “c ′”, and writing is performed only once. And the writing was complete. However, for a cell to which data “1” is written, an intermediate potential is supplied to a cell exceeding the verify potential “a * ′” lower than the original verify potential “a ′”, and the original verify potential “a ′” is supplied. The writing was repeated until. Therefore, the operation is slightly different depending on the data to be written.

これに対して、第5の実施形態は、データ“1”を書き込むセルに対して、データ”3”を書き込むセルと同じように書き込みを行なう。すなわち、本来のベリファイ電位“a’”より低いベリファイ電位“a*’”を超えるセルに対して、中間電位を供給して1回のみ書き込みを行ない、書き込みを完了する。また、第1ページのデータの書き込みに関しても、本来のベリファイ電位“v’”より低いベリファイ電位“v*’”を超えるセルに対して、中間電位を供給して1回のみ書き込みを行ない。この後、書き込み完了する。   On the other hand, in the fifth embodiment, writing is performed on a cell to which data “1” is written in the same manner as a cell to which data “3” is written. In other words, the intermediate potential is supplied to the cell exceeding the verify potential “a * ′” lower than the original verify potential “a ′”, and writing is performed only once to complete the writing. As for the data writing of the first page, the intermediate potential is supplied to the cells exceeding the verify potential “v * ′” lower than the original verify potential “v ′”, and writing is performed only once. Thereafter, the writing is completed.

以下、図39乃至図43を参照して具体的に説明する。   Hereinafter, a specific description will be given with reference to FIGS. 39 to 43.

(第1ページ書き込み)
先ず、第1ページの書き込みについて説明する。第1ページのプログラム、プログラムベリファイ動作は、図8に示す第1の実施形態の変形例と同様である。しかし、図39(a)に示すように、プログラムベリファイにおいて、本来のベリファイ電位“v’”より低いベリファイ電位“v*’”を超えるセルに対して、DDCに“1”を設定し、次のプログラムの時にPDCが“0”、DDCが“1”の場合、ビット線に中間電位(例えば1V)を供給して書き込みを行なう。
(1st page write)
First, the writing of the first page will be described. The program of the first page and the program verify operation are the same as in the modification of the first embodiment shown in FIG. However, as shown in FIG. 39A, in the program verify, for a cell exceeding the verify potential “v * ′” lower than the original verify potential “v ′”, “1” is set to DDC, When the PDC is “0” and the DDC is “1” at the time of programming, an intermediate potential (for example, 1 V) is supplied to the bit line for writing.

TDCはキャパシタにより構成されているため、この書き込みリカバリー中において、図39(b)(データリフレッシュ1後)に示すように、DDCのデータをTDCに移し、PDCのデータをDDCに移し、TDCのデータをPDC移す。   Since the TDC is composed of capacitors, during this write recovery, as shown in FIG. 39B (after data refresh 1), the DDC data is transferred to the TDC, the PDC data is transferred to the DDC, and the TDC Transfer data to PDC.

さらに、再び、図39(c)(データリフレッシュ2後)に示すように、DDCのデータをTDCに移し、PDCのデータをDDCに移し、TDCのデータをPDCに移し、DDCのデータをリフレッシュする。しかし、図39(c)に示す操作において、DDCのデータをTDCのデータに移すとき、図39(b)に示すTDCの値(ベリファイ電位“a*’”を超える→1)をリセットせずに、DDCのデータ(1:書き込み非選択、0:書き込み)を移すと、TDCの値がベリファイ電位“a*’”を超える場合も“1”になるため、PDCには書き込み非選択となる。したがって、ベリファイ電位“a*’”を超える場合、ビット線に1回のみ中間電位が供給されてプログラムされる。   Furthermore, as shown in FIG. 39C (after data refresh 2), the DDC data is transferred to the TDC, the PDC data is transferred to the DDC, the TDC data is transferred to the PDC, and the DDC data is refreshed. . However, in the operation shown in FIG. 39C, when the DDC data is moved to the TDC data, the TDC value shown in FIG. 39B (beyond the verify potential “a * ′” → 1) is not reset. If the DDC data (1: write non-selection, 0: write) is moved, the TDC value becomes “1” even when the verify potential exceeds “a * ′”. . Therefore, when the verify potential exceeds “a * ′”, the intermediate potential is supplied to the bit line only once and programmed.

(第2ページ書き込み)
第2ページの書き込みは、本来のベリファイ電位“a’”より低いベリファイ電位“a*’”を超えるセルに対して、ビット線に中間電位を供給し、1回のみ書き込みを行ない、書き込みを完了する。
(2nd page write)
For the second page write, an intermediate potential is supplied to the bit line to the cell exceeding the verify potential “a * ′” lower than the original verify potential “a ′”, and the write is performed only once to complete the write. To do.

プログラムベリファイ動作は、図35と同様である。プログラムベリファイにおいて、本来のベリファイ電位“a’”より低いベリファイ電位“a*’”を超えるセルに対しては、図40に示すように、DDCを“1”にし、次のプログラム時にPDCが“0”でDDCが“1”の場合、ビット線に中間電位を供給して書き込みを行なう。したがって、この中間電位をビット線に供給して1回書き込みを行なった後、PDCを“1”にして書き込み完了とする。   The program verify operation is the same as in FIG. In the program verify, for a cell exceeding the verify potential “a * ′” lower than the original verify potential “a ′”, the DDC is set to “1” as shown in FIG. When DDC is “1” at “0”, an intermediate potential is supplied to the bit line to perform writing. Therefore, after the intermediate potential is supplied to the bit line and writing is performed once, PDC is set to “1” to complete the writing.

以下、動作について具体的に説明する。   Hereinafter, the operation will be specifically described.

プログラム中に、信号BLCLAMPをローレベルとし、PDC及びDDCをビット線から切り離す。ビット線は容量が大きいため、切り離されても、書き込みは継続して行なわれる。   During programming, the signal BLCLAMP is set to low level, and the PDC and DDC are disconnected from the bit line. Since the bit line has a large capacity, writing is continued even if it is disconnected.

この後、信号BLPREをハイレベル、信号VPREをハイレベルとしてTDCをハイレベルとする。さらに、信号REGをハイレベル、信号VREGをローレベルとして、DDCが“1”の場合、TDCをローレベルとし、DDCが“0”の場合、TDCをハイレベルのままとする。この状態において、TDCのデータをPDCに移すと同時に、DTGをハイレベルとし、図41(a)に示すように、DDCにもPDCと同じデータを保持させる。   Thereafter, the signal BLPRE is set to the high level, the signal VPRE is set to the high level, and the TDC is set to the high level. Further, when the signal REG is high level, the signal VREG is low level, and DDC is “1”, TDC is low level, and when DDC is “0”, TDC is kept high level. In this state, the TDC data is transferred to the PDC, and at the same time, the DTG is set to the high level, and the DDC holds the same data as the PDC as shown in FIG.

次に、信号BLC2をハイレベルとしてSDCのデータをTDCに移し、信号REGをハイレベル、信号VREGをVssとする。この状態において、DDCが“1”の場合、強制的に、TDCをローレベルにした後、TDCのデータをPDCに移す(図41(b))。   Next, the signal BLC2 is set to the high level, the SDC data is transferred to the TDC, the signal REG is set to the high level, and the signal VREG is set to Vss. In this state, when the DDC is “1”, the TDC is forcibly set to the low level, and then the TDC data is transferred to the PDC (FIG. 41B).

この後、信号BLPREをハイレベルとし、信号VPREをハイレベルとしてTDCをハイレベルとする。さらに、信号REGをハイレベル、信号VREGをローレベルとして、DDCが“1”の場合、TDCをローレベルとする。DDCが“0”の場合、TDCをハイレベルのままとし、信号DTGを“1”としてPDCのデータをDDCに移した後、TDCのデータをPDCに移す(図42(a))。   Thereafter, the signal BLPRE is set to the high level, the signal VPRE is set to the high level, and the TDC is set to the high level. Further, when the signal REG is at a high level, the signal VREG is at a low level, and the DDC is “1”, the TDC is set at a low level. When the DDC is “0”, the TDC is kept at the high level, the signal DTG is set to “1”, the PDC data is transferred to the DDC, and then the TDC data is transferred to the PDC (FIG. 42A).

次に、信号BLPREをハイレベルとし、信号VPREをハイレベルとしてTDCをハイレベHとした後、信号BLCLAMPを所定の電圧とする。すると、ビット線がローレベル(“0”)又は中間電位の場合、TDCはローレベル、ビット線がハイレベルの場合、TDCはハイレベルとなる。この後、信号VREGをVddとし、信号REGをハイレベルとして、DDCがハイレベルの場合、TDCを強制的にハイレベルにする。この後、PDCのデータをDDCに移し、TDCのデータをPDCに移す。DDCのデータは元々保持されたデータとなる。しかし、PDCは元々のデータにDDCがハイレベルであり、SDCがハイレベルであった場合、つまり、本来のベリファイ電位“a’”より低いベリファイ電位“a*’”を超える場合、PDCがハイレベル、つまり書込み非選択となる。したがって、ベリファイ電位“a*’”を超える場合、1回のみビット線が中間電位になりプログラムが行なわれる(図42(b))。   Next, the signal BLPRE is set to high level, the signal VPRE is set to high level, the TDC is set to high level H, and then the signal BLCLAMP is set to a predetermined voltage. Then, when the bit line is at a low level (“0”) or an intermediate potential, TDC is at a low level, and when the bit line is at a high level, TDC is at a high level. Thereafter, the signal VREG is set to Vdd, the signal REG is set to high level, and when the DDC is at high level, the TDC is forcibly set to high level. Thereafter, the PDC data is transferred to the DDC, and the TDC data is transferred to the PDC. The DDC data is originally retained data. However, when the DDC is high level and the SDC is high level in the original data, that is, when the verify potential “a * ′” lower than the original verify potential “a ′” is exceeded, the PDC is high. Level, that is, write deselection. Therefore, when the verify potential “a * ′” is exceeded, the bit line is set to the intermediate potential only once and programming is performed (FIG. 42B).

上記第5の実施形態によれば、第2ページの書き込みにおいて、データ“1”を書き込むメモリセルと、データ“3”を書き込むメモリセルに対して、同一の書き込み方式によりデータを書き込むことができる。つまり、本来のベリファイ電位“a’”より低いバリファイ電位“a*’”を超えるセルに対して中間電位を供給して1回のみ書き込みを行ない。この後、書き込み完了としている。このため、高速な書き込み動作を実現できる。   According to the fifth embodiment, in writing the second page, data can be written to the memory cell to which data “1” is written and the memory cell to which data “3” is written by the same writing method. . That is, the intermediate potential is supplied to the cell exceeding the verify potential “a * ′” lower than the original verify potential “a ′”, and writing is performed only once. Thereafter, the writing is completed. For this reason, a high-speed write operation can be realized.

しかも、第1ページのデータの書き込みにつても、本来のベリファイ電位“v’”より低いベリファイ電位“v*’”を超えるセルに対して、中間電位を供給して1回のみ書き込みを行ない、書き込み完了としている。このため、一層高速な書き込み動作を実現できる。   In addition, when writing the data of the first page, the intermediate potential is supplied to the cell exceeding the verify potential “v * ′” lower than the original verify potential “v ′”, and writing is performed only once. Writing is complete. For this reason, a higher-speed write operation can be realized.

(第6の実施形態)
次に、図43乃至図52を参照して、本発明の第6の実施形態について説明する。
(Sixth embodiment)
Next, with reference to FIGS. 43 to 52, a sixth embodiment of the present invention will be described.

第6の実施形態において、メモリセルアレイの構成及びデータ記憶回路の配置は、第2及び第3の実施形態と同じである。すなわち、第6の実施形態は、1つのメモリセルに8値(3ビット)のデータを記憶する。   In the sixth embodiment, the configuration of the memory cell array and the arrangement of the data storage circuits are the same as those in the second and third embodiments. That is, in the sixth embodiment, 8-level (3-bit) data is stored in one memory cell.

図43(a)(b)(c)、図44(a)(b)に示す第6の実施形態の書き込みデータとメモリセルの閾値電圧の関係は、図20(a)(b)(c)、図21(a)(b)と同様である。また、第1ページ、第2ページのプログラム動作は、第4の実施形態とほぼ同様の動作である。すなわち、第1ページ、第2ページのプログラム動作において、メモリセルのデータが本来の閾値電圧に達したかどうかをベリファイする際、通常より低いベリファイ電位を用いてベリファイされている。第6の実施形態は、第3ページのプログラムが第4の実施形態と相違する。   43 (a) (b) (c) and FIG. 44 (a) (b), the relationship between the write data and the threshold voltage of the memory cell in the sixth embodiment is shown in FIGS. ), Which is the same as FIGS. The program operations for the first page and the second page are almost the same as those in the fourth embodiment. That is, in the first page and second page program operations, when verifying whether the data in the memory cell has reached the original threshold voltage, the verify is performed using a verify potential lower than normal. The sixth embodiment is different from the fourth embodiment in the program of the third page.

(第3ページプログラム)
図45、図46は、第3ページプログラムのブロックダイアグラムを示している。第3ページのプログラム動作も、先ずアドレスを指定し、図19に示す3ページを選択する。
(3rd page program)
45 and 46 show block diagrams of the third page program. In the program operation of the third page, first, an address is designated, and the third page shown in FIG. 19 is selected.

次に、データ記憶回路10をリセットし(S351)、書き込みデータを外部より入力して全てのデータ記憶回路10のSDCに記憶する(S352)。外部よりデータ“1”(書き込みを行なわない)が入力されると、図6に示すデータ記憶回路10のSDCは、ローレベルになり、データ“0”(書き込みを行なう)が入力されるとハイレベルとなる。   Next, the data storage circuit 10 is reset (S351), and write data is input from the outside and stored in the SDCs of all the data storage circuits 10 (S352). When data “1” (not written) is input from the outside, the SDC of the data storage circuit 10 shown in FIG. 6 becomes low level, and when data “0” (written) is input, the SDC is high. Become a level.

第3ページのプログラムは、図44(b)に示すように、メモリセルのデータが“0”の場合で、外部から入力されるデータが“1”の場合、メモリセルのデータを“0”のままとし、外部から入力されるデータが“0”の場合、メモリセルのデータを“1”にする。   As shown in FIG. 44 (b), the program on the third page sets the memory cell data to “0” when the memory cell data is “0” and the externally input data is “1”. If the data input from the outside is “0”, the data in the memory cell is set to “1”.

メモリセルのデータが“2”の場合で、外部から入力されるデータが“1”の場合、メモリセルのデータは“2”のままである。しかし、第2ページの書き込み時において、メモリセルのデータが“2”に達したかどうかをベリファイする際、通常より低いベリファイ電位“b*’”を用いた。このため、データ“2”を記憶するメモリセルは、本来のベリファイ電位である“b’”の電位まで書き込む。メモリセルのデータが“2”の場合で、外部から入力されるデータが“0”の場合、メモリセルのデータを“3”にする。   When the data in the memory cell is “2” and the data input from the outside is “1”, the data in the memory cell remains “2”. However, when verifying whether or not the data in the memory cell has reached “2” at the time of writing the second page, a verify potential “b * ′” lower than usual is used. Therefore, the memory cell storing the data “2” writes up to the potential “b ′” which is the original verify potential. When the data in the memory cell is “2” and the data input from the outside is “0”, the data in the memory cell is set to “3”.

メモリセルのデータが“4”の場合で、外部から入力されるデータが“1”の場合、メモリセルのデータは“4”のままである。しかし、第2ページの書き込み時において、メモリセルのデータが“4”に達したかどうかをベリファイする際、通常より低いベリファイ電位“d*’”を用いた。このため、データ“4”を記憶するメモリセルは、本来のベリファイ電位である“d’”の電位まで書き込む。メモリセルのデータが“4”の場合で、外部から入力されるデータが“0”の場合、メモリセルのデータを“5”にする。   When the data in the memory cell is “4” and the data input from the outside is “1”, the data in the memory cell remains “4”. However, when verifying whether or not the data in the memory cell has reached “4” at the time of writing the second page, a verify potential “d * ′” lower than usual is used. For this reason, the memory cell storing the data “4” writes up to the potential “d ′” which is the original verify potential. When the data in the memory cell is “4” and the data input from the outside is “0”, the data in the memory cell is set to “5”.

メモリセルのデータが“6”の場合で、外部から入力されるデータが“1”の場合、メモリセルのデータを“6”のままである。しかし、第2ページの書き込み時において、メモリセルのデータが“6”に達したかどうかをベリファイする際、通常より低いベリファイ電位“f*’”を用いた。このため、データ“6”を記憶するメモリセルは、本来のベリファイ電位である“f’”の電位まで書き込む。メモリセルのデータが“6”の場合で、外部から入力されるデータが“0”の場合、メモリセルのデータを“7”にする。   When the data in the memory cell is “6” and the data input from the outside is “1”, the data in the memory cell remains “6”. However, when verifying whether or not the data in the memory cell has reached “6” at the time of writing the second page, a verify potential “f * ′” lower than usual is used. For this reason, the memory cell storing the data “6” writes up to the potential of “f ′” which is the original verify potential. When the data in the memory cell is “6” and the data input from the outside is “0”, the data in the memory cell is set to “7”.

第6の実施形態では、このようにして書き込みを行なうが、書き込み及び読み出されるデータとメモリセルのデータを、第2及び第3の実施形態と同じようにすることも可能である。   In the sixth embodiment, writing is performed in this way, but it is also possible to make the data to be written and read and the data in the memory cell the same as in the second and third embodiments.

また、メモリセルデータ“3”、“5”、“7”への書き込みセルに関しては、本来のベリファイ電位より低い閾値でベリファイ動作を行ない。このレベルを超えていた場合で、本来のベリファイ電位で書き込み完了とならなかった場合、次の書き込み時は、ビット線に中間電位を供給して書き込みスピードを遅くし、1回のみ書き込みを行ない書き込み完了とする。本来のベリファイ電位を超えているセルは、その時点で書き込みが終了となる。   For the write cells to the memory cell data “3”, “5”, “7”, the verify operation is performed with a threshold lower than the original verify potential. If this level has been exceeded and writing has not been completed at the original verify potential, the next writing will be performed by supplying an intermediate potential to the bit line to slow down the writing speed and writing only once. Completed. For cells exceeding the original verify potential, the writing is completed at that time.

また、メモリセルにデータ“1”を書き込むセルに関しては、本来のベリファイ電位より低いベリファイ電圧でベリファイ動作を行なう。そして、この本来より低いベリファイ電位を超えていた場合、次の書き込み以降、ビット線に中間電位を供給して書き込みスピードを遅くし、本来のベリファイ電位を超えるまで書き込む。   Further, a verify operation is performed with a verify voltage lower than the original verify potential for a cell in which data “1” is written in the memory cell. If the verify potential lower than the original is exceeded, an intermediate potential is supplied to the bit line after the next write to reduce the write speed and write until the verify potential exceeds the original verify potential.

(第3ページ第1回目プログラム)
第3ページのプログラムは、メモリセルにデータ“1”〜“7”を書き込む。これらのデータを同時にプログラムすることも可能であるが、第6の実施形態では、先ず、メモリセルにデータ“4”〜“7”の4つのデータを書き込む。この後、メモリセルにデータ“1”〜“3”を書き込む。以下、具体的に説明する。
(3rd page 1st program)
The program on the third page writes data “1” to “7” to the memory cells. Although it is possible to program these data simultaneously, in the sixth embodiment, first, four data “4” to “7” are written in the memory cell. Thereafter, data “1” to “3” are written in the memory cells. This will be specifically described below.

先ず、データ記憶回路がリセットされ、外部よりデータ記憶回路のSDCにデータがロードされる(図45、S351、S352)。   First, the data storage circuit is reset, and data is loaded from the outside into the SDC of the data storage circuit (FIG. 45, S351, S352).

(内部データリード1及びデータキャッシュ設定1)(S353、S354)
メモリセルへデータを書き込む前に、第2ページのメモリセルのデータが“4”、“6”か、“0”、“2”であるかの判断と、メモリセルのデータが“6”か、データが“0”、“2”、“4”のいずれであるかを判断する。このため、ワード線の電位を“d*”、“f*”に順次設定し、メモリセルに書き込まれているデータが読み出され、データキャッシュに設定される。
(Internal data read 1 and data cache setting 1) (S353, S354)
Before writing data to the memory cell, it is determined whether the memory cell data on the second page is “4”, “6”, “0”, “2”, and whether the memory cell data is “6”. Whether the data is “0”, “2”, or “4” is determined. For this reason, the potential of the word line is sequentially set to “d *” and “f *”, the data written in the memory cell is read and set in the data cache.

図47(a)は、内部リード後のデータキャッシュの状態を示している。この後、データキャッシュを操作することにより、図47(b)に示すように、データキャッシュを設定する。さらに、例えばカウンタ(PC)をゼロに初期設定し、第5のフラグセルのデータをロードする。   FIG. 47A shows the state of the data cache after the internal read. Thereafter, by operating the data cache, the data cache is set as shown in FIG. Further, for example, the counter (PC) is initialized to zero and the data of the fifth flag cell is loaded.

図47(b)において、メモリセルのデータを“0”〜“3”にする場合、PDCはハイレベル(“1”)。メモリセルのデータを“4”とする場合、PDCはローレベル(“0”)、DDCはハイレベル、SDCはハイレベルに設定する。メモリセルのデータを“5”とする場合、PDCはローレベル、DDCはローレベル、SDCはハイレベルに設定する。メモリセルのデータを“6”とする場合、PDCはローレベル、DDCはハイレベル、SDCはローレベルに設定する。メモリセルのデータを“7”とする場合、PDC、DDC、SDCをいずれもローレベルに設定する。   In FIG. 47B, when the data in the memory cell is set to “0” to “3”, the PDC is at the high level (“1”). When the data in the memory cell is “4”, the PDC is set to a low level (“0”), the DDC is set to a high level, and the SDC is set to a high level. When the data in the memory cell is “5”, the PDC is set to the low level, the DDC is set to the low level, and the SDC is set to the high level. When the data in the memory cell is “6”, the PDC is set to the low level, the DDC is set to the high level, and the SDC is set to the low level. When the data in the memory cell is “7”, all of PDC, DDC, and SDC are set to a low level.

(プログラム:第1回目)(S355)
次いで、カウンタ(PC)をカウントアップした後、メモリセルにデータが書き込まれる。第6の実施形態においても、第2の実施形態と同様、カウンタの値と予め定められたベリファイ開始回数を用いて、不要なベリファイがスキップされる。
(Program: 1st time) (S355)
Next, after counting up the counter (PC), data is written into the memory cell. Also in the sixth embodiment, unnecessary verification is skipped using the counter value and a predetermined number of verification starts, as in the second embodiment.

先ず、信号BLC1をVsgとすると、PDCがデータ“0”の場合、ビット線がVssとなり、データ“1”の場合、ビット線はVddになる。次に、信号BLC1をVssに設定した後、信号VREGをVdd、信号REGを中間電位(例えば1V+Vth)に設定する。DDCがデータ“1”の場合、ビット線が中間電位となり、DDCがデータ“0”の場合、ビット線はプリチャージされない。この結果、メモリセルにデータ“5”,“7”を書き込んでいるときのみビット線はVss、メモリセルにデータ“4”,“6”を書き込んでいる場合、ビット線は中間電位(例えば1V)、メモリセルのデータが“0”〜“3”の場合(書き込みしない場合)、ビット線はVddになる。ここで、選択ワード線をVpgm、非選択ワード線をVpassとすると、ビット線がVddの場合、書き込みが行なわれない。また、ビット線がVssの場合、書き込みが起こり、ビット線が中間電位(例えば1V)の場合、少しだけ書き込まれる。したがって、メモリセルにデータ“4”,“6”を書き込んでいるセルは、あまり書き込まれない可能性がある。しかし、メモリセルのデータ“4”とデータ“5”のベリファイとメモリセルのデータ“6”とデータ“7”のベリファイはそれぞれ一括して行なうため、出来るだけ同時に書き込まれたほうが書き込み時間が早く終わる。このため、ビット線に中間電位を供給する。   First, when the signal BLC1 is Vsg, when the PDC is data “0”, the bit line is Vss, and when the data is “1”, the bit line is Vdd. Next, after setting the signal BLC1 to Vss, the signal VREG is set to Vdd, and the signal REG is set to an intermediate potential (for example, 1V + Vth). When the DDC is data “1”, the bit line is at an intermediate potential, and when the DDC is data “0”, the bit line is not precharged. As a result, only when data “5” and “7” are written in the memory cell, the bit line is Vss, and when data “4” and “6” are written in the memory cell, the bit line is at an intermediate potential (for example, 1 V). ) When the data in the memory cell is “0” to “3” (when writing is not performed), the bit line becomes Vdd. Here, if the selected word line is Vpgm and the non-selected word line is Vpass, writing is not performed when the bit line is Vdd. Further, when the bit line is Vss, writing occurs, and when the bit line is at an intermediate potential (for example, 1 V), writing is performed only slightly. Therefore, there is a possibility that the cells in which data “4” and “6” are written in the memory cell are not so much written. However, since verify of the data “4” and data “5” of the memory cell and verify of the data “6” and data “7” of the memory cell are performed all at once, the write time is faster if they are written simultaneously. End. For this reason, an intermediate potential is supplied to the bit line.

(“d’”のみのベリファイ)(S356−S358、図48(a))
この後、ベリファイ電圧“d’”を設定して書き込みベリファイが行なわれる。先ず、信号BLC2をハイレベルとし(Vdd+Vth)、信号BLCLAMPを所定の電位に設定すると、ビット線がプリチャージされる。このとき、プリチャージされるのは、SDCがハイレベル、つまり、データ“5”、“4”を書き込んでいるメモリセルのみである。
(Verify only “d ′”) (S356-S358, FIG. 48 (a))
Thereafter, the verify voltage “d ′” is set and the write verify is performed. First, when the signal BLC2 is set to a high level (Vdd + Vth) and the signal BLCLAMP is set to a predetermined potential, the bit line is precharged. At this time, only the memory cells in which the SDC is at a high level, that is, data “5” and “4” are written, are precharged.

次に、ワード線にベリファイ電位“d’”を供給し、ビット線を放電する。ビット線の放電中にDDCのデータをTDCに移す。この後、PDCのデータをDDCに移し、TDCのデータをPDCに移す。次いで、TDCをVddに充電する。この後、信号BLCLAMPを所定の電位に設定する。すると、TDCがハイレベルになるのは、メモリセルにデータ“4”及び“5”を書き込んでいて、ベリファイ電位“d’”以上になったときである。この後、信号BLC1を中間電位(Vth+0.5V)にすると、PDCがローレベルの場合、メモリセルにデータ“5”を書き込んでいる場合、TDCがローレベルになる。したがって、TDCがハイレベルになるのは、メモリセルにデータ“4”を書き込んでいて、ベリファイ電位“d’”以上になったときである。   Next, the verify potential “d ′” is supplied to the word line, and the bit line is discharged. DDC data is transferred to TDC during bit line discharge. Thereafter, the PDC data is transferred to the DDC, and the TDC data is transferred to the PDC. The TDC is then charged to Vdd. Thereafter, the signal BLCLAMP is set to a predetermined potential. Then, the TDC becomes high level when data “4” and “5” are written in the memory cell and become equal to or higher than the verify potential “d ′”. After that, when the signal BLC1 is set to the intermediate potential (Vth + 0.5V), when the data “5” is written in the memory cell when the PDC is at the low level, the TDC becomes the low level. Therefore, TDC becomes high level when data “4” is written in the memory cell and becomes equal to or higher than the verify potential “d ′”.

次に、信号VREGをハイレベルとし、信号REGをVsgとすると、DDCのデータがハイレベルの場合、強制的にTDCがハイレベルとなる。したがって、TDCがVddになるのは、メモリセルにデータ“4”を書き込んでいてベリファイ電位“d’”に達した時と、書き込み非選択の場合である。信号DTGをVsgとし、PDCのデータをDDCにコピーした後、信号BLC1をVsgとしてTDCの電位をPDCに取りこむ。   Next, when the signal VREG is set to high level and the signal REG is set to Vsg, when the data of the DDC is high level, the TDC is forcibly set to high level. Therefore, TDC becomes Vdd when data “4” is written in the memory cell and the verify potential “d ′” is reached, and when writing is not selected. After the signal DTG is set to Vsg and the data of the PDC is copied to the DDC, the signal BLC1 is set to Vsg and the potential of the TDC is taken into the PDC.

(“d’”“e*’”“e’”同時ベリファイ)(S359−S361、図48(b))
プログラムを数回繰り繰り返すと、メモリセルに対するデータ“5”への書き込みも完了してくる。したがって、ベリファイ“e’”のベリファイも行なうが、このベリファイは、“d’”“e*’”“e’”レベルのベリファイを同時に行なう。
("D '""e*'""e'" simultaneous verify) (S359-S361, FIG. 48 (b))
When the program is repeated several times, writing to the data “5” to the memory cell is also completed. Therefore, the verify “e ′” is also verified. In this verify, “d ′”, “e * ′”, and “e ′” level verify are simultaneously performed.

先ず、信号BLC2をハイレベルとし、信号BLCLAMPを所定の電位に設定すると、ビット線がプリチャージされる。このとき、プリチャージされるのは、SDCがハイレベル、つまり、データ“5”、“4”を書き込んでいるメモリセルのみである。   First, when the signal BLC2 is set to a high level and the signal BLCLAMP is set to a predetermined potential, the bit line is precharged. At this time, only the memory cells in which the SDC is at a high level, that is, data “5” and “4” are written, are precharged.

次に、ワード線にベリファイ電位“d’”を供給し、ビット線を放電する。ビット線の放電中にDDCのデータをTDCに移す。この後、PDCのデータをDDCに移し、TDCのデータをPDCに移す。次いで、TDCをVddに充電する。この後、信号BLCLAMPを所定の電位に設定する。すると、TDCがハイレベルになるのは、メモリセルにデータ“4”及び“5”を書き込んでいて、ベリファイ電位“d’”以上になったときである。この後、信号BLC1を中間電位(Vth+0.5V)にすると、PDCがローレベルの場合、メモリセルにデータ“5”を書き込んでいるとき、TDCがローレベルになる。したがって、TDCがハイレベルになるのは、メモリセルにデータ“4”を書き込んでいて、ベリファイ電位“d’”以上になったときである。   Next, the verify potential “d ′” is supplied to the word line, and the bit line is discharged. DDC data is transferred to TDC during bit line discharge. Thereafter, the PDC data is transferred to the DDC, and the TDC data is transferred to the PDC. The TDC is then charged to Vdd. Thereafter, the signal BLCLAMP is set to a predetermined potential. Then, the TDC becomes high level when data “4” and “5” are written in the memory cell and become equal to or higher than the verify potential “d ′”. Thereafter, when the signal BLC1 is set to the intermediate potential (Vth + 0.5V), when the data “5” is written in the memory cell when the PDC is at the low level, the TDC is at the low level. Therefore, TDC becomes high level when data “4” is written in the memory cell and becomes equal to or higher than the verify potential “d ′”.

次に、信号VREGをハイレベルとし、信号REGをVsgとすると、DDCのデータがハイレベルの場合、強制的にTDCがハイレベルとなる。したがって、TDCがVddになるのは、メモリセルにデータ“4”を書き込んでいてベリファイ電位“d’”に達した時と、書き込み非選択の場合である。さらに、信号DTGをVsgとし、PDCのデータをDDCにコピーした後、信号BLC1をVsgとしてTDCの電位をPDCに取りこむ。   Next, when the signal VREG is set to high level and the signal REG is set to Vsg, when the data of the DDC is high level, the TDC is forcibly set to high level. Therefore, TDC becomes Vdd when data “4” is written in the memory cell and the verify potential “d ′” is reached, and when writing is not selected. Further, after the signal DTG is set to Vsg and the data of the PDC is copied to the DDC, the signal BLC1 is set to Vsg and the potential of the TDC is taken into the PDC.

この後、ワード線にベリファイ電位“e*’”を供給し、ビット線を放電する。次いで、TDCをVddに充電する。この後、信号BLCLAMPを所定の電位に設定すると、TDCがハイレベルになるのは、セルの閾値電圧がベリファイ電位“e*’”以上の場合である。つまり、メモリセルのデータが“5”に書き込まれていてベリファイ電位“e*’”に達した時である。   Thereafter, a verify potential “e * ′” is supplied to the word line, and the bit line is discharged. The TDC is then charged to Vdd. Thereafter, when the signal BLCLAMP is set to a predetermined potential, the TDC becomes high level when the threshold voltage of the cell is equal to or higher than the verify potential “e * ′”. That is, when the data in the memory cell is written to “5” and reaches the verify potential “e * ′”.

次に、信号VREGをハイレベルとし、信号REGをVsgとすると、DDCのデータがハイレベルの場合、強制的にTDCがハイレベルとなる。したがって、TDCがVddになるのは、メモリセルにデータ“5”を書き込んでいてベリファイ電位“e*’”に達した時と、メモリセルにデータ“0”“2”“4”“6”を書き込んでいる場合である。次いで、信号DTGをVsgとし、PDCのデータをDDCにコピーした後、信号BLC1をVsgとしてTDCの電位をPDCに取りこむ。   Next, when the signal VREG is set to high level and the signal REG is set to Vsg, when the data of the DDC is high level, the TDC is forcibly set to high level. Therefore, TDC becomes Vdd when data “5” is written in the memory cell and the verify potential “e * ′” is reached, and when data “0” “2” “4” “6” is stored in the memory cell. Is written. Next, after the signal DTG is set to Vsg and the data of the PDC is copied to the DDC, the signal BLC1 is set to Vsg and the potential of the TDC is taken into the PDC.

この後、ワード線にベリファイ電位“e’”を供給し、ビット線を放電する。次いで、TDCをVddに充電する。この後、信号BLCLAMPを所定の電位に設定する。TDCがハイレベルになるのは、セルの閾値電圧がベリファイ電位“e’”以上の場合である。つまり、メモリセルのデータが“5”に書き込まれていてベリファイ電位“e’”に達した時である。   Thereafter, a verify potential “e ′” is supplied to the word line to discharge the bit line. The TDC is then charged to Vdd. Thereafter, the signal BLCLAMP is set to a predetermined potential. The TDC becomes high level when the threshold voltage of the cell is equal to or higher than the verify potential “e ′”. That is, when the data in the memory cell is written to “5” and reaches the verify potential “e ′”.

次に、信号VREGをハイレベルとし、信号REGをVsgとすると、DDCのデータがハイレベルの場合、強制的にTDCがハイレベルとなる。したがって、TDCがVddになるのは、メモリセルにデータ“5”を書き込んでいてベリファイ電位“e’”に達した時と、書き込み非選択の場合である。信号DTGをVsgとし、PDCのデータをDDCにコピーした後、信号BLC1をVsgとしてTDCの電位をPDCに取りこむ。   Next, when the signal VREG is set to high level and the signal REG is set to Vsg, when the data of the DDC is high level, the TDC is forcibly set to high level. Therefore, TDC becomes Vdd when data “5” is written in the memory cell and the verify potential “e ′” is reached, and when writing is not selected. After the signal DTG is set to Vsg and the data of the PDC is copied to the DDC, the signal BLC1 is set to Vsg and the potential of the TDC is taken into the PDC.

メモリセルにデータ“5”を書き込んでいてベリファイ電位“e*’”に達し、ベリファイ電位“e’”のベリファイで書き込み完了にならなかった場合のデータ記憶回路データは、SDC=“1”、DDC=“1”、PDC=“0”となり、メモリセルにデータ“4”を書き込んでいる場合のデータ記憶回路のデータと同様になる。つまり、メモリセルにデータ“5”を書き込んでいてベリファイ電位“e*’”に達した場合、メモリセルにデータ“4”が書き込み状態となる。メモリセルにデータ“4”を書き込む場合、ビット線に中間電位を供給されている。このため、次の書き込みではメモリセルに少しだけ書き込みが行われる。また、このセルは、次の“d’”“e*’”“e’”同時ベリファイにおいて、“d’”のベリファイで、セルの閾値電圧が“e*’”以上に存在するため、必ずベルファイをパスすることとなり、2回目以降の書き込みは行なわれなくなる。   The data storage circuit data when the data “5” is written in the memory cell and the verify potential “e * ′” is reached and the write at the verify potential “e ′” is not completed is SDC = “1”, DDC = "1", PDC = "0", which is the same as the data in the data storage circuit when data "4" is written in the memory cell. That is, when data “5” is written in the memory cell and the verify potential “e * ′” is reached, data “4” is written in the memory cell. When data “4” is written to the memory cell, an intermediate potential is supplied to the bit line. For this reason, in the next writing, a little writing is performed on the memory cell. In addition, since the cell has a threshold voltage of "e * '" or higher in the verification of "d'" in the next "d '", "e *'", and "e '" simultaneous verification, Belphi is passed, and the second and subsequent writings are not performed.

(ベリファイ電位“f’”のみを用いたベリファイ)(S362−S364、図49(a))
ベリファイ電位“f’”のみを用いたベリファイは、先ず、信号VPREをハイレベルとし、信号BLPREをVdd+Vthとし、信号BLCLAMPを所定の電位に設定すると、ビット線がプリチャージされる。
(Verify using only verify potential “f ′”) (S362-S364, FIG. 49A)
In the verification using only the verify potential “f ′”, first, when the signal VPRE is set to the high level, the signal BLPRE is set to Vdd + Vth, and the signal BLCLAMP is set to a predetermined potential, the bit line is precharged.

次に、ワード線にベリファイ電位“f’”を供給し、ビット線を放電する。ビット線の放電中にDDCのデータをTDCに移す。この後、PDCのデータをDDCに移し、TDCのデータをPDCに移す。次いで、TDCをVddに充電する。この後、信号BLCLAMPを所定の電位に設定する。すると、TDCがハイレベルになるのは、メモリセルにデータ“6”及び“7”を書き込んでいて、ベリファイ電位“f’”以上になったときである。この後、信号BLC1を中間電位(Vth+0.5V)にすると、PDCがローレベルの場合、メモリセルにデータ“7”を書き込んでいる場合、TDCがローレベルになる。したがって、TDCがハイレベルになるのは、メモリセルにデータ“6”を書き込んでいて、ベリファイ電位“f’”以上になったときである。   Next, the verify potential “f ′” is supplied to the word line, and the bit line is discharged. DDC data is transferred to TDC during bit line discharge. Thereafter, the PDC data is transferred to the DDC, and the TDC data is transferred to the PDC. The TDC is then charged to Vdd. Thereafter, the signal BLCLAMP is set to a predetermined potential. Then, the TDC goes high when data “6” and “7” are written in the memory cell and become the verify potential “f ′” or higher. Thereafter, when the signal BLC1 is set to the intermediate potential (Vth + 0.5V), when the PDC is at a low level, when data “7” is written in the memory cell, the TDC is at a low level. Therefore, TDC becomes high level when data “6” is written in the memory cell and becomes equal to or higher than the verify potential “f ′”.

次に、信号VREGをハイレベルとし、信号REGをVsgとすると、DDCのデータがハイレベルの場合、強制的にTDCがハイレベルとなる。したがって、TDCがVddになるのは、メモリセルにデータ“6”を書き込んでいてベリファイ電位“f’”に達した時と、書き込み非選択の場合である。次いで、信号DTGをVsgとし、PDCのデータをDDCにコピーした後、信号BLC1をVsgとしてTDCの電位をPDCに取りこむ。   Next, when the signal VREG is set to high level and the signal REG is set to Vsg, when the data of the DDC is high level, the TDC is forcibly set to high level. Therefore, TDC becomes Vdd when data “6” is written in the memory cell and the verify potential “f ′” is reached, and when writing is not selected. Next, after the signal DTG is set to Vsg and the data of the PDC is copied to the DDC, the signal BLC1 is set to Vsg and the potential of the TDC is taken into the PDC.

(“f’”“g*’”“g’”同時ベリファイ)(S365,S366、図49(b))
プログラムを数回繰り繰り返すと、メモリセルのデータ“7”への書き込みが完了してくる。したがって、ベリファイ“g’”のベリファイも行なう。このベリファイは、“f’”“g*’”“g’”のベリファイを同時に行なう。
("F '""g*'""g'" simultaneous verification) (S365, S366, FIG. 49 (b))
When the program is repeated several times, writing to the data “7” in the memory cell is completed. Therefore, verify “g ′” is also performed. In this verification, “f ′”, “g * ′”, and “g ′” are simultaneously verified.

先ず、信号VPREをハイレベルとし、信号BLPREをVdd+Vthとし、信号BLCLAMPを所定の電位に設定する。すると、ビット線がプリチャージされる。   First, the signal VPRE is set to high level, the signal BLPRE is set to Vdd + Vth, and the signal BLCLAMP is set to a predetermined potential. Then, the bit line is precharged.

次に、ワード線にベリファイ電位“f’”を供給し、ビット線を放電する。ビット線の放電中にDDCのデータをTDCに移す。この後、PDCのデータをDDCに移し、TDCのデータをPDCに移す。次いで、TDCをVddに充電する。この後、信号BLCLAMPを所定の電位に設定する。すると、TDCがハイレベルになるのは、メモリセルにデータ“6”及び“7”を書き込んでいて、ベリファイ電位“f’”以上になったときである。この後、信号BLC1を中間電位(Vth+0.5V)にすると、PDCがローレベルの場合、メモリセルにデータ“7”を書き込んでいる場合TDCがローレベルになる。したがって、TDCがハイレベルになるのは、メモリセルにデータ“6”を書き込んでいて、ベリファイ電位“f’”以上になったときである。   Next, the verify potential “f ′” is supplied to the word line, and the bit line is discharged. DDC data is transferred to TDC during bit line discharge. Thereafter, the PDC data is transferred to the DDC, and the TDC data is transferred to the PDC. The TDC is then charged to Vdd. Thereafter, the signal BLCLAMP is set to a predetermined potential. Then, the TDC goes high when data “6” and “7” are written in the memory cell and become the verify potential “f ′” or higher. After that, when the signal BLC1 is set to the intermediate potential (Vth + 0.5V), when the data “7” is written in the memory cell when the PDC is at the low level, the TDC is at the low level. Therefore, TDC becomes high level when data “6” is written in the memory cell and becomes equal to or higher than the verify potential “f ′”.

次に、信号VREGをハイレベルとし、信号REGをVsgとすると、DDCのデータがハイレベルの場合、強制的にTDCがハイレベルとなる。したがって、TDCがVddになるのは、メモリセルにデータ“6”を書き込んでいてベリファイ電位“f’”に達した時と、書き込み非選択の場合である。次いで、信号DTGをVsgとし、PDCのデータをDDCにコピーした後、信号BLC1をVsgとしてTDCの電位をPDCに取りこむ。   Next, when the signal VREG is set to high level and the signal REG is set to Vsg, when the data of the DDC is high level, the TDC is forcibly set to high level. Therefore, TDC becomes Vdd when data “6” is written in the memory cell and the verify potential “f ′” is reached, and when writing is not selected. Next, after the signal DTG is set to Vsg and the data of the PDC is copied to the DDC, the signal BLC1 is set to Vsg and the potential of the TDC is taken into the PDC.

この後、ワード線にベリファイ電位“g*’”を供給し、ビット線を放電する。次いで、TDCをVddに充電する。この後、信号BLCLAMPを所定の電位に設定する。すると、TDCがハイレベルになるのは、セルの閾値電圧がベリファイ電位“g*’”以上の場合である。つまり、メモリセルのデータが“7”に書き込まれていてベリファイ電位“g*’”に達した時である。   Thereafter, the verify potential “g * ′” is supplied to the word line, and the bit line is discharged. The TDC is then charged to Vdd. Thereafter, the signal BLCLAMP is set to a predetermined potential. Then, the TDC becomes high level when the threshold voltage of the cell is equal to or higher than the verify potential “g * ′”. That is, when the memory cell data is written to “7” and reaches the verify potential “g * ′”.

次に、信号VREGをハイレベルとし、信号REGをVsgとすると、DDCのデータがハイレベルの場合、強制的にTDCがハイレベルとなる。したがって、TDCがVddになるのは、メモリセルにデータ“7”を書き込んでいてベリファイ電位“g*’”に達した時と、メモリセルにデータ“0”“2”“4”“6”を書き込んでいる場合である。信号DTGをVsgとし、PDCのデータをDDCにコピーした後、信号BLC1をVsgとしてTDCの電位をPDCに取りこむ。   Next, when the signal VREG is set to high level and the signal REG is set to Vsg, when the data of the DDC is high level, the TDC is forcibly set to high level. Therefore, TDC becomes Vdd when data “7” is written to the memory cell and the verify potential “g * ′” is reached, and when data “0” “2” “4” “6” is stored in the memory cell. Is written. After the signal DTG is set to Vsg and the data of the PDC is copied to the DDC, the signal BLC1 is set to Vsg and the potential of the TDC is taken into the PDC.

この後、ワード線にベリファイ電位“g’”を供給し、ビット線を放電する。次いで、TDCをVddに充電する。この後、信号BLCLAMPを所定の電位に設定する。すると、TDCがハイレベルになるのは、セルの閾値電圧がベリファイ電位“g’”以上の場合である。つまり、メモリセルのデータが“7”に書き込まれていてベリファイ電位“g’”に達した時である。   Thereafter, the verify potential “g ′” is supplied to the word line, and the bit line is discharged. The TDC is then charged to Vdd. Thereafter, the signal BLCLAMP is set to a predetermined potential. Then, the TDC becomes high level when the threshold voltage of the cell is equal to or higher than the verify potential “g ′”. That is, the memory cell data is written to “7” and reaches the verify potential “g ′”.

次に、信号VREGをハイレベルとし、信号REGをVsgとすると、DDCのデータがハイレベルの場合、強制的にTDCがハイレベルとなる。したがって、TDCがVddになるのは、メモリセルにデータ“7”を書き込んでいてベリファイ電位“g’”に達した時と、書き込み非選択の場合である。信号DTGをVsgとし、PDCのデータをDDCにコピーした後、信号BLC1をVsgとしてTDCの電位をPDCに取りこむ。   Next, when the signal VREG is set to high level and the signal REG is set to Vsg, when the data of the DDC is high level, the TDC is forcibly set to high level. Therefore, TDC becomes Vdd when data “7” is written in the memory cell and the verify potential “g ′” is reached, and when writing is not selected. After the signal DTG is set to Vsg and the data of the PDC is copied to the DDC, the signal BLC1 is set to Vsg and the potential of the TDC is taken into the PDC.

メモリセルにデータ“7”を書き込んでいてベリファイ電位“g*’”に達し、ベリファイ電位“g’”のベリファイで書き込み完了にならなかった場合、データ記憶回路のデータは、SDC=“0”、DDC=“1”、PDC=“0”となり、メモリセルにデータ“6”を書き込んでいる場合のデータ記憶回路のデータと同様になる。つまり、メモリセルにデータ“7”を書き込んでいてベリファイ電位“g*’”に達した場合、メモリセルにデータ“6”を書き込む状態となる。メモリセルに対するデータ“6”への書き込みは、ビット線に中間電位を供給している。このため、次の書き込みでは少しだけ書き込みが行われる。また、このセルは、次の“f’”“f*’”“g’”同時ベリファイにおいて、“f’”のベリファイの際、セルの閾値電圧が“g*’”以上に存在する。このため、ベリファイは必ずパスとなり、2回目以降の書き込みは行なわれなくなる。   When the data “7” is written in the memory cell, the verify potential “g * ′” is reached, and the verify of the verify potential “g ′” does not complete the write, the data in the data storage circuit is SDC = “0”. DDC = “1” and PDC = “0”, which is the same as the data in the data storage circuit when data “6” is written in the memory cell. That is, when data “7” is written in the memory cell and the verify potential “g * ′” is reached, data “6” is written in the memory cell. In writing data “6” to the memory cell, an intermediate potential is supplied to the bit line. For this reason, in the next writing, writing is performed a little. Further, in the next “f ′”, “f * ′”, and “g ′” simultaneous verification, the cell has a threshold voltage of “g * ′” or more when “f ′” is verified. For this reason, the verification is always a pass, and the second and subsequent writings are not performed.

このようにして、全てのPDCのデータが“1”になるまで、プログラムとベリファイ動作を繰り返す(S367、S368)。しかし、書き込み動作において、DDCのデータが“1”の場合、つまり、メモリセルにデータ“4”を書き込んでいる場合と、メモリセルにデータ“6”を書き込んでいる場合と、メモリセルにデータ“5”を書き込んでいて、ベリファイ電位“e*’”を超えた場合と、メモリセルにデータ“7”を書き込んでいて、ベリファイ電位“g*’”を超えた場合、ビット線を中間電位にして書き込み動作をする。また、プログラムとベリファイ動作を繰り返す毎に、プログラム電圧Vpgmを少しずつ上昇させる。このようにして、第1回目プログラムにより、メモリセルにデータ“4”〜“7”の4つが書き込まれる。   In this way, the program and verify operation are repeated until the data of all PDCs becomes “1” (S367, S368). However, in the write operation, when the DDC data is “1”, that is, when data “4” is written in the memory cell, when data “6” is written in the memory cell, and when data is written in the memory cell. When “5” is written and the verify potential “e * ′” is exceeded, and when data “7” is written to the memory cell and the verify potential “g * ′” is exceeded, the bit line is set to the intermediate potential. And write operation. Further, each time the program and verify operations are repeated, the program voltage Vpgm is gradually increased. In this manner, four pieces of data “4” to “7” are written in the memory cell by the first program.

上記説明では、1回のプログラムの後、4つのベリファイを行なっていた。しかし、プログラムの初期のループでは、閾値電圧が上がらない。このため、初めは、ベリファイ電位“d’”を用いたベリファイのみ行なう。次に、ベリファイ電位“d’”“e*’”“e’”を用いた同時ベリファイを行なう。次に、ベリファイ電位“d’”“e*’”“e’”を用いた同時ベリファイと、“f’”のみを用いたベリファイを行なう。次に、ベリファイ電位“d’”“e*’”“e’”を用いた同時ベリファイと、“f’”“g*’”“g’”を用いた同時ベリファイを行なうことも可能である。   In the above description, four verifications are performed after one program. However, the threshold voltage does not increase in the initial loop of the program. Therefore, at first, only the verification using the verification potential “d ′” is performed. Next, simultaneous verification using verify potentials “d ′”, “e * ′”, and “e ′” is performed. Next, simultaneous verification using verify potentials “d ′”, “e * ′”, “e ′” and verification using only “f ′” are performed. Next, simultaneous verification using verify potentials “d ′”, “e * ′”, and “e ′” and simultaneous verification using “f ′”, “g * ′”, and “g ′” can be performed. .

また、プログラムの終了近くのループでは、メモリセルのデータ“4”、“5”への書き込みは終了している。このため、ベリファイ電位“d’”“e*’”“e’”を用いた同時ベリファイ動作を省略し、最後に、“f’”“g*’”“g’”を用いた同時ベリファイのみを行なうことも可能である。   In the loop near the end of the program, writing to the data “4” and “5” of the memory cell is completed. Therefore, the simultaneous verify operation using the verify potentials “d ′”, “e * ′”, and “e ′” is omitted, and finally, only the simultaneous verify using “f ′”, “g * ′”, and “g ′” is performed. It is also possible to perform.

(第2回目プログラム)
第2回目プログラムにより、メモリセルにデータ“1”〜“3”の3つが書き込まれるが、データ“1”を書き込むメモリセルには、全く書き込みが行なわれていない。このため、第1の実施形態と同様に、本来のベリファイ電位より低いベリファイ電位“a*’”を設け、このベリファイ電位を超えたセルに対して、ビット線に中間電位を供給する。これにより、書き込みスピードを遅くし、閾値分布を狭くする。また、メモリセルのデータ“2”とデータ“3”のベリファイは一括して行なうため、出来るだけ同時に書き込まれたほうが書き込み時間が早く終わる。したがって、メモリセルにデータ“2”を書き込んでいる場合にも、ビット線に中間電位を供給することにより、書き込みスピードを遅くする。
(2nd program)
By the second program, three data “1” to “3” are written in the memory cell, but no data is written in the memory cell in which the data “1” is written. Therefore, as in the first embodiment, a verify potential “a * ′” lower than the original verify potential is provided, and an intermediate potential is supplied to the bit line for cells exceeding this verify potential. This slows down the writing speed and narrows the threshold distribution. In addition, since the data “2” and data “3” of the memory cell are verified in a lump, the writing time ends earlier if they are written simultaneously as much as possible. Therefore, even when data “2” is written in the memory cell, the write speed is reduced by supplying the intermediate potential to the bit line.

(内部データリード2及びデータキャッシュ設定2)(S369,S370、図50(a))
セルへの書き込みの前に、ワード線の電位を“b*(=a)”、“d*”の順に設定し、内部リード動作を行なう。
(Internal data read 2 and data cache setting 2) (S369, S370, FIG. 50A)
Before writing to the cell, the potential of the word line is set in the order of “b * (= a)” and “d *”, and an internal read operation is performed.

この後、データキャッシュを操作することにより、図50(a)に示すように、データキャッシュを設定する。すなわち、メモリセルにデータ“0”を書き込む場合、PDCは“1”、DDCは“1”、SDCは“1”に設定する。メモリセルにデータ“1”を書き込む場合、PDCは“0”、DDCは“0”/“1”、SDCは“1”に設定する。メモリセルにデータ“2”を書き込む場合、PDCは“0”、DDCは“1”、SDCは“0”に設定する。メモリセルにデータ“3”を書き込む場合、PDCは“0”、DDCは“0”、SDCは“0”に設定する。メモリセルにデータ“4”〜“7”を書き込む場合、PDCは全て“1”に設定する。   Thereafter, by operating the data cache, the data cache is set as shown in FIG. That is, when data “0” is written in the memory cell, PDC is set to “1”, DDC is set to “1”, and SDC is set to “1”. When data “1” is written to the memory cell, PDC is set to “0”, DDC is set to “0” / “1”, and SDC is set to “1”. When data “2” is written to the memory cell, PDC is set to “0”, DDC is set to “1”, and SDC is set to “0”. When data “3” is written in the memory cell, PDC is set to “0”, DDC is set to “0”, and SDC is set to “0”. When data “4” to “7” are written in the memory cell, all PDCs are set to “1”.

(プログラム:第2回目)(S371)
ここで、例えばカウンタ(PC)をゼロに初期設定する。
(Program: 2nd) (S371)
Here, for example, a counter (PC) is initialized to zero.

次いで、例えばカウンタ(PC)をカウントアップした後、メモリセルにデータが書き込まれる。先ず、信号BLC1を中間電位(Vdd+Vth)とすると、PDCがデータ“0”の場合、ビット線がVssとなり、データ“1”の場合、ビット線はVddになる。次に、信号BLC1=Vssとした後、信号VREG=Vdd、信号REG=中間電位(例えば1V+Vth)とする。すると、DDCがデータ“1”の場合、ビット線が中間電位(例えば1V)となり、DDCがデータ“0”の場合、ビット線はプリチャージされない。この結果、メモリセルにデータ“3”を書き込んでいる時と、メモリセルにデータ“1”を書き込んでいて本来のベリファイ電位より低いベリファイ電位“a*’”以下の場合、ビット線は、Vssである。メモリセルにデータ“2”を書き込んでいる時と、メモリセルにデータ“1”を書き込んでいて本来のベリファイ電位より低いベリファイ電位“a*’”を越えている場合、ビット線は中間電位(1V)、メモリセルのデータが“0”、“4”〜“7”の場合(書き込みしない場合)、ビット線はVddになる。ここで、選択ワード線をVpgm、非選択ワード線をVpassとすると、ビット線がVddの場合、書き込みが行なわれない。また、ビット線がVssの場合、書き込みが起こり、ビット線が中間電位(1V)の場合、少しだけ書き込まれる。しかし、メモリセルにデータ“2”とデータ“3”を書き込む場合のベリファイは一括して行なうため、出来るだけ同時に書き込まれたほうが書き込み時間が早く終わる。したがって、ビット線に中間電位を供給する。   Next, for example, after counting up a counter (PC), data is written in the memory cell. First, when the signal BLC1 is set to an intermediate potential (Vdd + Vth), when the PDC is data “0”, the bit line is Vss, and when the data is “1”, the bit line is Vdd. Next, after setting the signal BLC1 = Vss, the signal VREG = Vdd and the signal REG = intermediate potential (for example, 1V + Vth). Then, when the DDC is data “1”, the bit line becomes an intermediate potential (for example, 1 V), and when the DDC is data “0”, the bit line is not precharged. As a result, when data “3” is written to the memory cell and when data “1” is written to the memory cell and the verify potential is “a * ′” lower than the original verify potential, the bit line is Vss. It is. When data “2” is written to the memory cell and when data “1” is written to the memory cell and the verify potential “a * ′” lower than the original verify potential is exceeded, the bit line has an intermediate potential ( 1V), when the data of the memory cell is “0”, “4” to “7” (when writing is not performed), the bit line becomes Vdd. Here, if the selected word line is Vpgm and the non-selected word line is Vpass, writing is not performed when the bit line is Vdd. In addition, when the bit line is Vss, writing occurs, and when the bit line is at the intermediate potential (1 V), writing is slightly performed. However, since the verify operation when data “2” and data “3” are written to the memory cell is performed in a lump, the write time ends earlier when data is simultaneously written as much as possible. Therefore, an intermediate potential is supplied to the bit line.

(ベリファイ“a’、a*’”)(S372−S374、図50(b))
ベリファイ電位“a’、a*’”を用いたベリファイは、先ず、信号VPREをハイレベルとし、信号BLPREをVdd+Vthとし、信号BLCLAMPを所定の電位に設定する。すると、ビット線がプリチャージされる。次に、ワード線にベリファイ電位“a*’”を供給し、ビット線を放電する。
(Verify “a ′, a * ′”) (S372-S374, FIG. 50B)
In the verification using the verify potentials “a ′, a * ′”, first, the signal VPRE is set to a high level, the signal BLPRE is set to Vdd + Vth, and the signal BLCLAMP is set to a predetermined potential. Then, the bit line is precharged. Next, the verify potential “a * ′” is supplied to the word line, and the bit line is discharged.

次いで、TDCをVddに充電する。この後、信号BLCLAMPを所定の電位に設定する。すると、TDCがハイレベルになるのは、セルの閾値電圧がベリファイ電位“a*’”以上の場合である。次に、信号BLC2を中間電位(Vth+0.5V)にするとSDCがLの場合、TDCがLとなる。つまり、TDCがハイレベルになるのは、メモリセルのデータが“1”に書き込まれていてベリファイ電位“a*’”に達した時である。次に、信号VREGをハイレベルとし、信号REGをVsgとすると、DDCのデータがハイレベルの場合、強制的にTDCがハイレベルとなる。したがって、TDCがVddになるのは、メモリセルにデータ“1”を書き込んでいてベリファイ電位“a*’”に達した時と、メモリセルにデータ“0”“2”“4”“6”を書き込んでいる場合である。信号DTGをVsgとし、PDCのデータをDDCにコピーした後、信号BLC1をVsgとしてTDCの電位をPDCに取りこむ。   The TDC is then charged to Vdd. Thereafter, the signal BLCLAMP is set to a predetermined potential. Then, the TDC becomes high level when the threshold voltage of the cell is equal to or higher than the verify potential “a * ′”. Next, when the signal BLC2 is set to an intermediate potential (Vth + 0.5V), when SDC is L, TDC becomes L. That is, the TDC goes high when the data in the memory cell is written to “1” and reaches the verify potential “a * ′”. Next, when the signal VREG is set to high level and the signal REG is set to Vsg, when the data of the DDC is high level, the TDC is forcibly set to high level. Therefore, TDC becomes Vdd when data “1” is written in the memory cell and the verify potential “a * ′” is reached, and when data “0” “2” “4” “6” is stored in the memory cell. Is written. After the signal DTG is set to Vsg and the data of the PDC is copied to the DDC, the signal BLC1 is set to Vsg and the potential of the TDC is taken into the PDC.

この後、ワード線にベリファイ電位“a’”を供給し、ビット線を放電する。次いで、TDCをVddに充電する。この後、信号BLCLAMPを所定の電位に設定する。すると、TDCがハイレベルになるのは、セルの閾値電圧がベリファイ電位“a’”以上の場合である。次に、信号BLC2を中間電位(Vth+0.5V)にするとSDCがローレベル(“0”)の場合、TDCがハイレベル(“1”)となる。つまり、TDCがハイレベルになるのは、メモリセルのデータが“1”に書き込まれていてベリファイ電位“a’”に達した時である。次に、信号VREGをハイレベルとし、信号REGをVsgとすると、DDCのデータがハイレベルの場合、強制的にTDCがハイレベルとなる。したがって、TDCがVddになるのは、メモリセルにデータ“1”を書き込んでいてベリファイ電位“a’”に達した時と、書き込み非選択の場合である。信号DTGをVsgとし、PDCのデータをDDCにコピーした後、信号BLC1をVsgとしてTDCの電位をPDCに取りこむ。(図51(a))。   Thereafter, the verify potential “a ′” is supplied to the word line, and the bit line is discharged. The TDC is then charged to Vdd. Thereafter, the signal BLCLAMP is set to a predetermined potential. Then, the TDC becomes high level when the threshold voltage of the cell is equal to or higher than the verify potential “a ′”. Next, when the signal BLC2 is set to the intermediate potential (Vth + 0.5V), when the SDC is at the low level (“0”), the TDC is at the high level (“1”). That is, the TDC goes high when the data in the memory cell is written to “1” and reaches the verify potential “a ′”. Next, when the signal VREG is set to high level and the signal REG is set to Vsg, when the data of the DDC is high level, the TDC is forcibly set to high level. Therefore, TDC becomes Vdd when data “1” is written in the memory cell and the verify potential “a ′” is reached, and when writing is not selected. After the signal DTG is set to Vsg and the data of the PDC is copied to the DDC, the signal BLC1 is set to Vsg and the potential of the TDC is taken into the PDC. (FIG. 51 (a)).

(ベリファイ電位“b’”)(S375−377、図51(b))
ベリファイ電位“b’”のみを用いたベリファイは、先ず、信号VPREをハイレベルとし、信号BLPREをVdd+Vthとし、信号BLCLAMPを所定の電位に設定する。すると、ビット線がプリチャージされる。
(Verify potential “b ′”) (S375-377, FIG. 51 (b))
In the verification using only the verify potential “b ′”, first, the signal VPRE is set to the high level, the signal BLPRE is set to Vdd + Vth, and the signal BLCLAMP is set to a predetermined potential. Then, the bit line is precharged.

次に、ワード線にベリファイ電位“b’”を供給し、ビット線を放電する。前記ビット線放電中に、DDCのデータをTDCに移し、PDCのデータをDDCに移し、TDCのデータをPDCに移す。さらに、ビット線の放電中に、信号VREGをVssとし、信号REGをVddとし、信号BLCLAMPに所定の電圧を設定すると、DDCがハイレベル(“1”)の場合、つまり書込み非選択の場合、ビット線が強制的にローレベルになる。この後、TDCをVddに充電する。この後、信号BLCLAMPを所定の電位に設定する。すると、TDCがハイレベルになるのは、メモリセルにデータが、ベリファイ電位“b’”以上になったときである。この後、信号BLC1を中間電位(Vth+0.5V)にするとPDCがローレベルの場合、つまりメモリセルにデータ“3”を書き込んでいる場合TDCがローレベルになる。したがって、TDCがハイレベルになるのは、メモリセルにデータ“2”を書き込んでいて、ベリファイ電位“b’”以上になったときである。   Next, the verify potential “b ′” is supplied to the word line, and the bit line is discharged. During the bit line discharge, DDC data is transferred to TDC, PDC data is transferred to DDC, and TDC data is transferred to PDC. Furthermore, when the signal VREG is set to Vss, the signal REG is set to Vdd, and a predetermined voltage is set to the signal BLCLAMP during the discharge of the bit line, when the DDC is at a high level (“1”), that is, when writing is not selected, The bit line is forced low. Thereafter, TDC is charged to Vdd. Thereafter, the signal BLCLAMP is set to a predetermined potential. Then, the TDC becomes high level when the data in the memory cell becomes equal to or higher than the verify potential “b ′”. Thereafter, when the signal BLC1 is set to the intermediate potential (Vth + 0.5V), when the PDC is at the low level, that is, when the data “3” is written in the memory cell, the TDC becomes the low level. Therefore, the TDC becomes high level when data “2” is written in the memory cell and becomes equal to or higher than the verify potential “b ′”.

次に、信号VREGをハイレベルとし、信号REGをVsgとすると、DDCのデータがハイレベルの場合、強制的にTDCがハイレベルとなる。したがって、TDCがVddになるのは、メモリセルにデータ“2”を書き込んでいてベリファイ電位“b’”に達した時と、書き込み非選択の場合である。信号DTGをVsgとし、PDCのデータをDDCにコピーした後、信号BLC1をVsgとしてTDCの電位をPDCに取りこむ。   Next, when the signal VREG is set to high level and the signal REG is set to Vsg, when the data of the DDC is high level, the TDC is forcibly set to high level. Therefore, TDC becomes Vdd when data “2” is written in the memory cell and the verify potential “b ′” is reached, and when writing is not selected. After the signal DTG is set to Vsg and the data of the PDC is copied to the DDC, the signal BLC1 is set to Vsg and the potential of the TDC is taken into the PDC.

(“b’”“c*’”“c’”同時ベリファイ)(S378,S379、図52)
プログラムを数回繰り繰り返すと、メモリセルデータ“2”への書き込みも完了してくる。したがって、ベリファイ“c’”のベリファイも行なうが、このベリファイは、“b’”“c*’”“c’”レベルのベリファイを同時に行なう。
(“B ′” “c * ′” “c ′” simultaneous verification) (S378, S379, FIG. 52)
When the program is repeated several times, writing to the memory cell data “2” is completed. Therefore, the verify “c ′” is also verified. In this verification, “b ′”, “c * ′”, and “c ′” level verify are simultaneously performed.

先ず、信号VPREをハイレベルとし、信号BLPREをVdd+Vthとし、信号BLCLAMPを所定の電位に設定すると、ビット線がプリチャージされる。次に、ワード線にベリファイ電位“b’”を供給し、ビット線を放電する。前記ビット線放電中に、DDCのデータをTDCに移し、PDCのデータをDDCに移し、TDCのデータをPDCに移す。さらに、ビット線の放電中に、信号VREGをVssとし、信号REGをVddとし、信号BLCLAMPに所定の電圧を設定すると、DDCが“1”の場合、つまり書込み非選択の場合、ビット線が強制的にローレベルになる。この後、TDCをVddに充電する。この後、信号BLCLAMPを所定の電位に設定する。すると、TDCがハイレベルになるのは、メモリセルにデータ“2”を書き込んでいて、ベリファイ電位“b’”以上になったときである。この後、信号BLC1を中間電位(Vth+0.5V)にするとPDCがローレベルの場合、つまりメモリセルにデータ“3”書き込んでいる場合TDCがローレベルになる。したがって、TDCがハイレベルになるのは、メモリセルにデータ“2”を書き込んでいて、ベリファイ電位“b’”以上になったときである。   First, when the signal VPRE is set to high level, the signal BLPRE is set to Vdd + Vth, and the signal BLCLAMP is set to a predetermined potential, the bit line is precharged. Next, the verify potential “b ′” is supplied to the word line, and the bit line is discharged. During the bit line discharge, DDC data is transferred to TDC, PDC data is transferred to DDC, and TDC data is transferred to PDC. Further, when the signal VREG is set to Vss, the signal REG is set to Vdd, and a predetermined voltage is set to the signal BLCLAMP during the discharge of the bit line, the bit line is forced when DDC is “1”, that is, when writing is not selected. Low level. Thereafter, TDC is charged to Vdd. Thereafter, the signal BLCLAMP is set to a predetermined potential. Then, the TDC goes high when data “2” is written in the memory cell and becomes equal to or higher than the verify potential “b ′”. Thereafter, when the signal BLC1 is set to the intermediate potential (Vth + 0.5V), when the PDC is at a low level, that is, when data “3” is written in the memory cell, the TDC becomes a low level. Therefore, the TDC becomes high level when data “2” is written in the memory cell and becomes equal to or higher than the verify potential “b ′”.

この後、ワード線にベリファイ電位“c*’”を供給し、ビット線を放電する。次いで、TDCをVddに充電する。この後、信号BLCLAMPを所定の電位に設定する。すると、TDCがハイレベルになるのは、セルの閾値電圧がベリファイ電位“c*’”以上の場合である。つまり、メモリセルのデータが“3”に書き込まれていてベリファイ電位“c*’”に達した時である。   Thereafter, the verify potential “c * ′” is supplied to the word line, and the bit line is discharged. The TDC is then charged to Vdd. Thereafter, the signal BLCLAMP is set to a predetermined potential. Then, the TDC becomes high level when the threshold voltage of the cell is equal to or higher than the verify potential “c * ′”. That is, when the data of the memory cell is written to “3” and reaches the verify potential “c * ′”.

次に、信号VREGをハイレベルとし、信号REGをVsgとすると、DDCのデータがハイレベルの場合、強制的にTDCがハイレベルとなる。したがって、TDCがVddになるのは、メモリセルにデータ“3”を書き込んでいてベリファイ電位“c*’”に達した時と、メモリセルにデータ“0”“2”“4”“6”を書き込んでいる場合である。信号DTGをVsgとし、PDCのデータをDDCにコピーした後、信号BLC1をVsgとしてTDCの電位をPDCに取りこむ。   Next, when the signal VREG is set to high level and the signal REG is set to Vsg, when the data of the DDC is high level, the TDC is forcibly set to high level. Therefore, TDC becomes Vdd when data “3” is written in the memory cell and the verify potential “c * ′” is reached, and when data “0” “2” “4” “6” is stored in the memory cell. Is written. After the signal DTG is set to Vsg and the data of the PDC is copied to the DDC, the signal BLC1 is set to Vsg and the potential of the TDC is taken into the PDC.

この後、ワード線にベリファイ電位“c’”を供給し、ビット線を放電する。次いで、TDCをVddに充電する。この後、信号BLCLAMPを所定の電位に設定する。TDCがハイレベルになるのは、セルの閾値電圧がベリファイ電位“c’”以上の場合である。つまり、メモリセルのデータが“3”に書き込まれていてベリファイ電位“c’”に達した時である。   Thereafter, the verify potential “c ′” is supplied to the word line, and the bit line is discharged. The TDC is then charged to Vdd. Thereafter, the signal BLCLAMP is set to a predetermined potential. The TDC becomes high level when the threshold voltage of the cell is equal to or higher than the verify potential “c ′”. That is, when the data of the memory cell is written to “3” and reaches the verify potential “c ′”.

次に、信号VREGをハイレベルとし、信号REGをVsgとすると、DDCのデータがハイレベルの場合、強制的にTDCがハイレベルとなる。したがって、TDCがVddになるのは、メモリセルにデータ“3”を書き込んでいてベリファイ電位“c’”に達した時と、書き込み非選択の場合である。信号DTGをVsgとし、PDCのデータをDDCにコピーした後、信号BLC1をVsgとしてTDCの電位をPDCに取りこむ。   Next, when the signal VREG is set to high level and the signal REG is set to Vsg, when the data of the DDC is high level, the TDC is forcibly set to high level. Therefore, TDC becomes Vdd when data “3” is written in the memory cell and the verify potential “c ′” is reached, and when writing is not selected. After the signal DTG is set to Vsg and the data of the PDC is copied to the DDC, the signal BLC1 is set to Vsg and the potential of the TDC is taken into the PDC.

メモリセルにデータ“3”を書き込んでいてベリファイ電位“c*’”に達し、ベリファイ電位“g’”のベリファイで書き込み完了にならなかった場合のデータ記憶回路データは、SDC=“0”、DDC=“1”、PDC=“0”となり、メモリセルにデータ“2”を書き込んでいる場合のデータ記憶回路のデータと同様になる。つまり、メモリセルにデータ“3”を書き込んでいてベリファイ電位“c*’”に達した場合、メモリセルにデータ“2”を書き込んでいる状態となる。メモリセルにデータ“2”を書き込んでいる場合、ビット線に中間電位を供給していた。このため、次の書き込みでは少しだけ書き込みが行われる。また、このメモリセルは、次の“b’”“c*’”“c’”同時ベリファイにおいて、“b’”のベリファイで、セルの閾値電圧が“c*’”以上に存在するため必ず、ベリファイはパスとなり、2回目以降の書き込みは行なわれなくなる。   The data storage circuit data when the data “3” is written to the memory cell and the verify potential “c * ′” is reached and the write is not completed by the verify potential “g ′” is SDC = “0”, DDC = “1”, PDC = “0”, which is the same as the data in the data storage circuit when data “2” is written in the memory cell. That is, when data “3” is written in the memory cell and the verify potential “c * ′” is reached, data “2” is written in the memory cell. When data “2” is written in the memory cell, an intermediate potential is supplied to the bit line. For this reason, in the next writing, writing is performed a little. In addition, in this memory cell, in the next “b ′”, “c * ′”, and “c ′” simultaneous verification, the threshold voltage of the cell is always higher than “c * ′” in the verification of “b ′”. The verification is a pass, and the second and subsequent writings are not performed.

このようにして、全てのPDCのデータが“1”になるまで、プログラムとベリファイ動作を繰り返す(S380,S381)。しかし、書き込み動作において、DDCのデータが“1”の場合、つまり、メモリセルにデータ“1”を書き込んでいる場合と、メモリセルにデータ“3”を書き込んでいて、ベリファイ電位“a*’”を超えた場合と、メモリセルにデータ“2”を書き込んでいる場合と、メモリセルにデータ“3”を書き込んでいて、ベリファイ電位“c*’”を超えた場合、ビット線を中間電位にして書き込み動作をする。また、プログラムとベリファイ動作を繰り返す毎に、プログラム電圧Vpgmを少しずつ上昇させる。第2回目プログラムにより、メモリセルにデータ“1”〜“3”の3つが書き込まれる。   In this way, the program and verify operation are repeated until the data of all PDCs becomes “1” (S380, S381). However, in the write operation, when the DDC data is “1”, that is, when the data “1” is written in the memory cell, the data “3” is written in the memory cell, and the verify potential “a * ′” ”, When data“ 2 ”is written to the memory cell, and when data“ 3 ”is written to the memory cell and the verify potential“ c * ′ ”is exceeded, the bit line is set to the intermediate potential. And write operation. Further, each time the program and verify operations are repeated, the program voltage Vpgm is gradually increased. By the second program, three data “1” to “3” are written in the memory cell.

PDCがローレベルの場合、再び書き込み動作を行ない全てのデータ記憶回路のPDCのデータがハイレベルになるまでこのプログラム動作とベリファイ動作が繰り返される。   When the PDC is at the low level, the write operation is performed again, and the program operation and the verify operation are repeated until the data in the PDC of all the data storage circuits becomes the high level.

上記説明では、1回のプログラムの後、2つのベリファイを行なっていた。しかし、プログラムの初期のループでは、閾値電圧が上がらないため、初めは、ベリファイ電位“a’、a*’”を用いたベリファイのみ行ない、次に、ベリファイ電位“a’、a*’”を用いたベリファイとベリファイ電位“b’”を行ない、最後に、ベリファイ電位“a’、a*’”を用いたベリファイとベリファイ電位”b’”“c’”同時ベリファイを行なうことも可能である。   In the above description, two verifications are performed after one program. However, since the threshold voltage does not increase in the initial loop of the program, first, only the verify using the verify potential “a ′, a * ′” is performed, and then the verify potential “a ′, a * ′” is applied. It is also possible to perform the verification and the verification potential “b ′” used, and finally perform the verification using the verification potentials “a ′ and a * ′” and the verification potential “b ′” and “c ′” simultaneously. .

また、プログラムの終了近くのループにおいて、メモリセルに対するデータ“1”への書き込みは終了しているため、これらのベリファイ動作は省略することもできる。メモリセルに対するデータ“1”のベリファイが不用になると、SDCでデータを保持する必要がなくなる。このため、次の書き込みのためのデータを外部より読み込み、SDCに記憶しておくことも可能である。このような構成とした場合、さらなる高速動作が可能である。   In addition, since the writing of data “1” to the memory cell is completed in the loop near the end of the program, these verify operations can be omitted. If the verification of the data “1” for the memory cell becomes unnecessary, it is not necessary to hold the data in the SDC. Therefore, it is possible to read data for the next writing from the outside and store it in the SDC. With such a configuration, further high-speed operation is possible.

(リード)
リード動作は、第2、第3の実施形態とほぼ同じであるため、説明は省略する。
(Lead)
Since the read operation is almost the same as that of the second and third embodiments, the description thereof is omitted.

(イレーズ)
消去動作は、第1、第4の実施形態と同様であるため、説明は省略する。
(Erase)
Since the erasing operation is the same as in the first and fourth embodiments, description thereof is omitted.

上記第6の実施形態によれば、第3ページプログラムにおいて、メモリセルにデータ“3”“5”“7”を書き込む際、本来のベリファイ電位より低い閾値電圧でベリファイ動作を行なう。そして、この本来より低いベリファイ電位を超えた場合で、本来のベリファイ電位で書き込み完了とならなかった場合、次の書き込み時は、ビット線に中間電位を供給して書き込みスピードを遅くし、1回のみ書き込みを行ない書き込み完了とする。本来のベリファイ電位を超えているセルは、その時点で書き込みが終了となる。また、メモリセルにデータ“1”を書き込む場合、本来のベリファイ電位より低いベリファイ電圧でベリファイ動作を行ない、この本来より低いベリファイ電位を超えていた場合、次の書き込み以降、ビット線に中間電位を供給して書き込みスピードを遅くし、本来のベリファイ電位を超えるまで書き込んでいる。このため、8値(3ビット)のデータを確実且つ高速に書き込み、読み出すことができる。   According to the sixth embodiment, when data “3”, “5”, and “7” are written in the memory cell in the third page program, the verify operation is performed with a threshold voltage lower than the original verify potential. When the verify potential lower than the original is exceeded and writing is not completed at the original verify potential, an intermediate potential is supplied to the bit line at the next writing to slow down the writing speed and Only writing is performed and writing is completed. For cells exceeding the original verify potential, the writing is completed at that time. When data “1” is written to the memory cell, a verify operation is performed with a verify voltage lower than the original verify potential. If the verify voltage is lower than the original verify potential, an intermediate potential is applied to the bit line after the next write. The write speed is reduced by supplying the data, and writing is performed until the original verify potential is exceeded. For this reason, 8-value (3-bit) data can be written and read reliably and at high speed.

しかも、第6の実施形態によれば、“1”“3”“5”“7”の奇数データを書き込むメモリセルの閾値電圧の分布を狭めることが可能である。   In addition, according to the sixth embodiment, it is possible to narrow the distribution of threshold voltages of memory cells into which odd data “1”, “3”, “5”, and “7” is written.

(第7の実施形態)
上記第6の実施形態は、第3ページの書き込み時、第1回目の書き込みで、メモリセルにデータ“4”〜“7”を書き込み、第2回目の書き込みでメモリセルにデータ“1”〜“3”を書き込んだ。
(Seventh embodiment)
In the sixth embodiment, at the time of writing the third page, data “4” to “7” are written to the memory cell by the first write, and data “1” to “7” are written to the memory cell by the second write. I wrote “3”.

これに対して、第7の実施形態は、第3ページの書き込みにおいて、メモリセルにデータ“1”〜“7”を同時に書き込むことを可能とする。このため、データ記憶回路10の構成を若干変更している。   On the other hand, the seventh embodiment makes it possible to simultaneously write data “1” to “7” to the memory cells in the third page write. For this reason, the configuration of the data storage circuit 10 is slightly changed.

図53は、第7の実施形態に適用されるデータ記憶回路を示している。図53において、図6と同一部分には同一符号を付している。図53に示すように、データ記憶回路10には、SDCのデータを一時的に記憶し、SDC、PDC、DDC、TDCと共に、ベリファイ用のデータを記憶するSDDC(セコンダリダイナミックデータキャッシュ)が追加されている。このSDDCの構成は、DDCとほぼ同様であり、トランジスタ63a、63bにより構成されている。トランジスタ63aの電流通路の一端はノードN2bに接続されている。このトランジスタ63aのゲートには信号DTG2が供給され、電流通路の他端はトランジスタ63bのゲートに接続されている。このトランジスタ63bの電流通路の一端部には信号VREG2が供給され、電流通路の他端はトランジスタ63cの電流通路の一端部に接続されている。このトランジスタ63cの電流通路の他端はノードN3に接続され、ゲートには信号REG2が供給されている。   FIG. 53 shows a data storage circuit applied to the seventh embodiment. 53, the same symbols are added to the same portions as FIG. As shown in FIG. 53, in the data storage circuit 10, SDDC (secondary dynamic data cache) for temporarily storing SDC data and storing verification data along with SDC, PDC, DDC, and TDC is added. Has been. The configuration of the SDDC is almost the same as that of the DDC, and includes transistors 63a and 63b. One end of the current path of the transistor 63a is connected to the node N2b. A signal DTG2 is supplied to the gate of the transistor 63a, and the other end of the current path is connected to the gate of the transistor 63b. A signal VREG2 is supplied to one end of the current path of the transistor 63b, and the other end of the current path is connected to one end of the current path of the transistor 63c. The other end of the current path of the transistor 63c is connected to the node N3, and a signal REG2 is supplied to the gate.

上記構成において、図54、図55、図56(a)(b)を参照して、上記データ記憶回路10を用いた第3ページの書き込み動作について説明する。   With the above configuration, the third page write operation using the data storage circuit 10 will be described with reference to FIGS. 54, 55, 56A and 56B.

先ず、データ記憶回路10がリセットされた後、外部より書き込みデータがデータ記憶回路10のSDCにロードされる(S401,S402)。この後、閾値電圧“a”“d*”“f*”を用いて内部リードが行われ、メモリセルからデータが読み出される(S403)。   First, after the data storage circuit 10 is reset, write data is loaded from the outside into the SDC of the data storage circuit 10 (S401, S402). Thereafter, internal read is performed using the threshold voltages “a”, “d *”, and “f *”, and data is read from the memory cell (S403).

図56(a)は、第3ページのデータロード及び内部リード後のデータキャッシュの設定を示している。ここで、SDC、DDC、PDCのデータは、図47(a)と同様である。また、SDDCのデータは、メモリセルにデータ“0”“1”が書き込まれている場合、“0”が設定され、メモリセルにデータ“2”〜“7”が書き込まれている場合、“1”が設定される。   FIG. 56A shows the setting of the data cache after the third page data load and internal read. Here, SDC, DDC, and PDC data are the same as those in FIG. The data of the SDDC is set to “0” when data “0” “1” is written in the memory cell, and “2” to “7” is written to the memory cell. 1 "is set.

次いで、各データキャッシュが操作され、図56(b)に示すように、各データキャッシュのデータが設定される(S404)。ここで、SDDCのデータは、データ“5”“4”“1”“0”のベリファイに使用され、SDCのデータは“3”“2”“1”“0”のベリファイに使用され、DDCのデータは、“7”“5”“3”“1”のベリファイに使用される。第7の実施形態も第5の実施形態と同様に、書き込み時は、PDCが“0”である場合、ビット線の電位をVssに設定し、PDCが“1”である場合、ビット線の電位をVddに設定する。この後、DDCが“1”の場合、ビット線の電位を中間電位(例えばVth+0.5V)として書き込み動作が行なわれる(S405)。   Next, each data cache is operated, and data of each data cache is set as shown in FIG. 56B (S404). Here, the SDDC data is used for verifying data “5”, “4”, “1”, and “0”, and the SDC data is used for verifying “3”, “2”, “1”, and “0”. This data is used for verifying “7” “5” “3” “1”. Similarly to the fifth embodiment, in the seventh embodiment, when the PDC is “0”, the potential of the bit line is set to Vss and when the PDC is “1”, Set the potential to Vdd. Thereafter, when DDC is “1”, the write operation is performed with the bit line potential set to an intermediate potential (for example, Vth + 0.5 V) (S405).

ベリファイ動作は、閾値電圧の小さい側から順次実行する。すなわち、先ず、ベリファイ電位“a*’”“a’”を用いてデータ“1”のベリファイが行われる(S406−S408)。この後、ベリファイ電位“b’”を用いて、データ“2”のベリファイが行われる(S409−S412)。次に、ベリファイ電位“b’”“c*’”“c’”を用いて、データ“2”“3”のベリファイが行われる(S412−S415)。さらに、ベリファイ電位“d’”を用いて、データ“4”のベリファイが行われる(S416−S419)。この後、ベリファイ電位“d’”“e*’”“e’”を用いて、データ“4”“5”のベリファイが行われる(S420−S422)。次に、ベリファイ電位“f’”を用いて、データ“6”のベリファイが行われる(S423−S426)。次いで、ベリファイ電位“f’”“g*’”“g’”を用いて、データ“6”“7”のベリファイが行われる(S427−S429)。この動作が、各データのベリファイが完了するまで繰り返される(S430、S431)。   The verify operation is sequentially executed from the side with the smaller threshold voltage. That is, first, data “1” is verified using the verify potentials “a * ′” and “a ′” (S406 to S408). Thereafter, the data “2” is verified using the verify potential “b ′” (S409-S412). Next, using the verify potentials “b ′”, “c * ′”, and “c ′”, the data “2” and “3” are verified (S412-S415). Further, the data “4” is verified using the verify potential “d ′” (S416-S419). Thereafter, data “4” and “5” are verified using the verify potentials “d ′”, “e * ′”, and “e ′” (S420 to S422). Next, the data “6” is verified using the verify potential “f ′” (S423-S426). Next, data “6” and “7” are verified using the verify potentials “f ′”, “g * ′”, and “g ′” (S427 to S429). This operation is repeated until the verification of each data is completed (S430, S431).

上記ベリファイ動作において、メモリセルのデータ“3”、“5”、“7”のベリファイにおいて、本来より低い閾値電圧に達した場合で、本来の閾値電圧より低い場合、データキャッシュ内のデータをそれぞれメモリセルのデータ“2”、“4”、“6”と同じに設定する。この状態において、次のプログラム時にビット線に中間電位を供給して書き込み動作を行い。次のベリファイで書き込み完了とする。また、メモリセルに対するデータ“1”の書き込みは、本来より低い閾値電圧に達した場合、以降のプログラムにおいて、ビット線に中間電位を供給して書き込み、本来の閾値電圧まで書き込み動作を行なう。   In the verify operation, when verifying the memory cell data “3”, “5”, and “7”, when the threshold voltage is lower than the original and lower than the original threshold voltage, the data in the data cache is It is set to be the same as the data “2”, “4”, “6” of the memory cell. In this state, an intermediate potential is supplied to the bit line at the next program time to perform a write operation. Writing is completed at the next verify. In addition, when data “1” is written to the memory cell, when a threshold voltage lower than the original is reached, an intermediate potential is supplied to the bit line in the subsequent program, and the write operation is performed up to the original threshold voltage.

上記第7の実施形態によれば、データ記憶回路10にメモリセルのデータ“5”“4”“1”“0”のベリファイに使用するデータを保持するSDDCを設けている。このため、第3ページのデータを一度に書き込み、ベリファイすることが可能である。このため、書き込み速度を一層高速化することが可能である。   According to the seventh embodiment, the data storage circuit 10 is provided with the SDDC that holds data used for verifying data “5”, “4”, “1”, and “0” of the memory cell. Therefore, it is possible to write and verify the third page data at a time. For this reason, it is possible to further increase the writing speed.

尚、上記第7の実施形態において、SDDCは、SDCとTDCの間に配置した。しかし、これに限らず、例えばPDCとTDCの間で、DDCと並列に配置することも可能である。   In the seventh embodiment, the SDDC is disposed between the SDC and the TDC. However, the present invention is not limited to this. For example, it may be arranged between the PDC and the TDC in parallel with the DDC.

その他、本発明の要旨を変えない範囲において種々変形実施可能なことは勿論である。   Of course, various modifications can be made without departing from the scope of the present invention.

図1(a)(b)(c)(d)は、メモリセルのデータとメモリセルの閾値電圧の関係を示す図。FIGS. 1A, 1B, 1C, and 1D are diagrams showing a relationship between data of a memory cell and a threshold voltage of the memory cell. 不揮発性半導体記憶装置の概略構成を示す図。1 is a diagram showing a schematic configuration of a nonvolatile semiconductor memory device. 第1の実施形態に係り、図2に示すメモリセルアレイ及びビット線制御回路の構成を示す回路図。FIG. 3 is a circuit diagram showing a configuration of a memory cell array and a bit line control circuit shown in FIG. 2 according to the first embodiment. 図4(a)(b)はメモリセル及び選択トランジスタを示す断面図。4A and 4B are cross-sectional views showing a memory cell and a select transistor. メモリセルアレイの1つのNANDセルを示す断面図。2 is a cross-sectional view showing one NAND cell of a memory cell array. FIG. 図3に示すデータ記憶回路の一例を示す回路図。FIG. 4 is a circuit diagram showing an example of a data storage circuit shown in FIG. 3. NANDセルに対する書き込み順序を示す図。The figure which shows the write-in order with respect to a NAND cell. 第1ページのプログラム動作を示すブロックダイアグラム。The block diagram which shows the program operation | movement of the 1st page. 第2ページのプログラム動作を示すブロックダイアグラム。The block diagram which shows the program operation | movement of a 2nd page. 図10(a)(b)は、各データキャッシュとメモリセルのデータの関係を示す図。10A and 10B are diagrams showing the relationship between data caches and data in memory cells. 図11(a)(b)(c)は、データキャッシュの設定手順を示す図。11A, 11B, and 11C are diagrams showing a data cache setting procedure. 図12(a)(b)(c)は、データキャッシュの設定手順を示す図。12A, 12B, and 12C are diagrams showing a data cache setting procedure. 図13(a)(b)は、ベリファイ動作時におけるデータキャッシュを示す図。FIGS. 13A and 13B are views showing a data cache during a verify operation. ベリファイ動作時におけるデータキャッシュを示す図。The figure which shows the data cache at the time of verify operation | movement. ベリファイ動作時におけるデータキャッシュを示す図。The figure which shows the data cache at the time of a verify operation | movement. ベリファイ動作時におけるデータキャッシュを示す図。The figure which shows the data cache at the time of verify operation | movement. 第1の実施形態の変形例を示すものであり、第2ページのプログラム動作を示すブロックダイアグラム。The block diagram which shows the modification of 1st Embodiment and shows the program operation | movement of a 2nd page. 図18(a)(b)は、読み出し動作を示すブロックダイアグラム。18A and 18B are block diagrams showing a read operation. 第2の実施形態を示すものであり、図3を変形した回路図。The circuit diagram which shows 2nd Embodiment and which deform | transformed FIG. 図20(a)(b)(c)は、メモリセルのデータとメモリセルの閾値電圧の関係を示す図。FIGS. 20A, 20B, and 20C are diagrams showing the relationship between memory cell data and memory cell threshold voltage. 図21(a)(b)は、メモリセルのデータとメモリセルの閾値電圧の関係を示す図。FIGS. 21A and 21B are diagrams showing a relationship between data of a memory cell and a threshold voltage of the memory cell. 図22(a)(b)は、第2の実施形態における書き込み順序の例を示す図。FIGS. 22A and 22B are diagrams showing examples of the writing order in the second embodiment. 第2の実施形態に係る第3ページプログラムを示すブロックダイアグラム。The block diagram which shows the 3rd page program which concerns on 2nd Embodiment. 図23に続く第3ページプログラムを示すブロックダイアグラム。The block diagram which shows the 3rd page program following FIG. 図25(a)(b)は、第3ページプログラムにおけるデータキャッシュの状態を示す図。FIGS. 25A and 25B are views showing the state of the data cache in the third page program. 第3ページプログラムにおけるデータキャッシュの状態を示す図。The figure which shows the state of the data cache in a 3rd page program. 図27(a)(b)は、それぞれ第1ページ、第2ページの読み出し動作を示すブロックダイアグラム。FIGS. 27A and 27B are block diagrams showing the first page and second page read operations, respectively. 第3ページの読み出し動作を示すブロックダイアグラム。The block diagram which shows the read-out operation | movement of the 3rd page. 第3の実施形態に係り、第3ページの書き込み動作を示すブロックダイアグラム。FIG. 10 is a block diagram showing a third page write operation according to the third embodiment. 図29に続く第3ページの書き込み動作を示すブロックダイアグラム。FIG. 30 is a block diagram showing a third page write operation following FIG. 29. FIG. 図31(a)(b)は、それぞれ第1ページ、第2ページの読み出し動作を示すブロックダイアグラム。FIGS. 31A and 31B are block diagrams showing read operations of the first page and the second page, respectively. フラグセルを複数配置した場合の例を示す図。The figure which shows the example at the time of arrange | positioning multiple flag cells. 図1(a)乃至(f)は、第4の実施形態に係るメモリセルのデータとメモリセルの閾値電圧の関係を示す図。FIGS. 1A to 1F are views showing a relationship between data of a memory cell and a threshold voltage of the memory cell according to the fourth embodiment. 第4の実施形態に係る第1ページの書き込み動作を示すブロックダイアグラム。FIG. 10 is a block diagram showing a first page write operation according to a fourth embodiment. 第4の実施形態に係る第2ページの書き込み動作を示すブロックダイアグラム。FIG. 10 is a block diagram showing a second page write operation according to the fourth embodiment. 図36(a)(b)は、第4の実施形態に係る各データキャッシュとメモリセルのデータの関係を示す図。FIGS. 36A and 36B are views showing the relationship between data caches and data in memory cells according to the fourth embodiment. 図37(a)(b)は、第4の実施形態に係る各データキャッシュとメモリセルのデータの関係を示す図。FIGS. 37A and 37B are views showing the relationship between data caches and data in memory cells according to the fourth embodiment. 第4の実施形態に係る各データキャッシュとメモリセルのデータの関係を示す図。The figure which shows the relationship between each data cache and data of a memory cell which concerns on 4th Embodiment. 図39(a)(b)(c)は、第5の実施形態に係る各データキャッシュとメモリセルのデータの関係を示す図。39A, 39B, and 39C are views showing the relationship between data caches and data in memory cells according to the fifth embodiment. 図40は、第5の実施形態に係る各データキャッシュとメモリセルのデータの関係を示す図。FIG. 40 is a view showing the relationship between data caches and data in memory cells according to the fifth embodiment. 図41(a)(b)は、第5の実施形態に係る各データキャッシュとメモリセルのデータの関係を示す図。41A and 41B are views showing the relationship between each data cache and memory cell data according to the fifth embodiment. 図42(a)(b)は、第5の実施形態に係る各データキャッシュとメモリセルのデータの関係を示す図。42A and 42B are views showing the relationship between data caches and data in memory cells according to the fifth embodiment. 図43(a)(b)(c)は、第6の実施形態に係るメモリセルのデータとメモリセルの閾値電圧の関係を示す図。FIGS. 43A, 43B, and 43C are views showing the relationship between the memory cell data and the threshold voltage of the memory cell according to the sixth embodiment. 図44(a)(b)は、第6の実施形態に係るメモリセルのデータとメモリセルの閾値電圧の関係を示す図。44A and 44B are views showing the relationship between the data of the memory cell and the threshold voltage of the memory cell according to the sixth embodiment. 第6の実施形態に係る第3ページの書き込み動作を示すブロックダイアグラム。The block diagram which shows the write-in operation | movement of the 3rd page which concerns on 6th Embodiment. 第6の実施形態に係る第3ページの書き込み動作を示すブロックダイアグラム。The block diagram which shows the write-in operation | movement of the 3rd page which concerns on 6th Embodiment. 図47(a)(b)は、第6の実施形態に係る各データキャッシュとメモリセルのデータの関係を示す図。47A and 47B are views showing the relationship between each data cache and memory cell data according to the sixth embodiment. 図48(a)(b)は、第6の実施形態に係る各データキャッシュとメモリセルのデータの関係を示す図。48A and 48B are views showing the relationship between data caches and data in memory cells according to the sixth embodiment. 図49(a)(b)は、第6の実施形態に係る各データキャッシュとメモリセルのデータの関係を示す図。49A and 49B are views showing the relationship between data caches and data in memory cells according to the sixth embodiment. 図50(a)(b)は、第6の実施形態に係る各データキャッシュとメモリセルのデータの関係を示す図。FIGS. 50A and 50B are views showing the relationship between data caches and data in memory cells according to the sixth embodiment. 図51(a)(b)は、第6の実施形態に係る各データキャッシュとメモリセルのデータの関係を示す図。51A and 51B are views showing the relationship between data caches and data in memory cells according to the sixth embodiment. 第6の実施形態に係る各データキャッシュとメモリセルのデータの関係を示す図。The figure which shows the relationship between each data cache and data of a memory cell concerning 6th Embodiment. 第7の実施形態に係るデータ記憶回路の構成を示す回路図。FIG. 10 is a circuit diagram showing a configuration of a data storage circuit according to a seventh embodiment. 第7の実施形態に係る第3ページの書き込み動作を示すブロックダイアグラム。FIG. 16 is a block diagram showing a third page write operation according to the seventh embodiment. 第7の実施形態に係る第3ページの書き込み動作を示すブロックダイアグラム。FIG. 16 is a block diagram showing a third page write operation according to the seventh embodiment. 図56(a)(b)は、第7の実施形態に係る各データキャッシュとメモリセルのデータの関係を示す図。FIGS. 56A and 56B are views showing the relationship between data caches and data in memory cells according to the seventh embodiment.

符号の説明Explanation of symbols

1…メモリセルアレイ、2…ビット線制御回路、3…カラムデコーダ、4…データ入出力バッファ、5…データ入出力端子、6…ワード線制御回路、7…制御信号及び制御電圧発生回路、8…制御信号入力端子、10…データ記憶回路、10a、10b〜10e…フラグ用データ記憶回路、PDC…プライマリデータキャッシュ、SDC…セコンダリデータキャッシュ、DDC…ダイナミックデータキャッシュ、TDC…テンポラリデータキャッシュ、SDDC…セコンダリダイナミックデータキャッシュ、FC1、FC2〜FC5…フラグセル。     DESCRIPTION OF SYMBOLS 1 ... Memory cell array, 2 ... Bit line control circuit, 3 ... Column decoder, 4 ... Data input / output buffer, 5 ... Data input / output terminal, 6 ... Word line control circuit, 7 ... Control signal and control voltage generation circuit, 8 ... Control signal input terminal, 10 ... data storage circuit, 10a, 10b to 10e ... flag data storage circuit, PDC ... primary data cache, SDC ... secondary data cache, DDC ... dynamic data cache, TDC ... temporary data cache, SDDC ... Secondary dynamic data cache, FC1, FC2 to FC5 ... flag cells.

Claims (34)

ワード線、及びビット線に接続され、n値(nは3以上の自然数)を記憶する複数のメモリセルがマトリックス状に配置されて構成されたメモリセルアレイと、
入力データに応じて前記ワード線、ビット線の電位を制御し、前記メモリセルにデータを書き込む制御回路とを具備し、
前記制御回路は、書き込み動作により、k値(k<=n)の閾値電圧に書き込み、
前記ビット線を一度プリチャージした後、前記ワード線の電位をi回変化させて前記メモリセルが、i値(i<=k)の閾値電圧に達したかのベリファイを行なうことを特徴とする半導体記憶装置。
A memory cell array connected to a word line and a bit line and configured by arranging a plurality of memory cells storing n values (n is a natural number of 3 or more) in a matrix;
A control circuit for controlling the potential of the word line and the bit line in accordance with input data and writing data to the memory cell;
The control circuit writes a threshold voltage of k value (k <= n) by a write operation,
After precharging the bit line once, the potential of the word line is changed i times to verify whether the memory cell has reached a threshold voltage of i value (i <= k). apparatus.
前記制御回路は、
第1の書き込み動作により、前記メモリセルの閾値電圧を前記第1の閾値電圧から第1の閾値電圧又は第2の閾値電圧(第1の閾値電圧<第2の閾値電圧)とし、
第2の書き込み動作により、前記メモリセルの閾値電圧が前記第1の閾値電圧である場合、第1の閾値電圧又は第3の閾値電圧(第1の閾値電圧<第3の閾値電圧)とし、第2の閾値電圧である場合、第4の閾値電圧(第2の閾値電圧<=第4の閾値電圧)又は第5の閾値電圧(第4の閾値電圧<第5の閾値電圧)とし、
前記第2の書き込み動作において、前記制御回路は、前記ビット線を一度プリチャージした後、前記ワード線の電位を変化させて前記メモリセルが前記第4の閾値電圧に達したかどうかのベリファイと、前記第5の閾値電圧に達したかどうかのベリファイを行なうことを特徴とする請求項1記載の半導体記憶装置。
The control circuit includes:
By the first write operation, the threshold voltage of the memory cell is changed from the first threshold voltage to the first threshold voltage or the second threshold voltage (first threshold voltage <second threshold voltage),
When the threshold voltage of the memory cell is the first threshold voltage by the second write operation, the first threshold voltage or the third threshold voltage (first threshold voltage <third threshold voltage) is set. When it is the second threshold voltage, the fourth threshold voltage (second threshold voltage <= fourth threshold voltage) or the fifth threshold voltage (fourth threshold voltage <fifth threshold voltage),
In the second write operation, the control circuit, after precharging the bit line once, changes the potential of the word line to verify whether the memory cell has reached the fourth threshold voltage. 2. The semiconductor memory device according to claim 1, wherein verification is made as to whether or not the fifth threshold voltage has been reached.
ワード線、及びビット線に接続され、4値を記憶する複数のメモリセルがマトリックス状に配置されて構成されたメモリセルアレイと、
入力データに応じて前記ワード線、ビット線の電位を制御し、前記メモリセルにデータを書き込む制御回路とを具備し、
前記制御回路は、
第1の書き込み動作により、前記メモリセルの閾値電圧を前記第1の閾値電圧から第1の閾値電圧又は第2の閾値電圧(第1の閾値電圧<第2の閾値電圧)とし、
第2の書き込み動作により、前記メモリセルの閾値電圧が前記第1の閾値電圧である場合、第1の閾値電圧又は第3の閾値電圧(第1の閾値電圧<第3の閾値電圧)とし、第2の閾値電圧である場合、第4の閾値電圧(第2の閾値電圧<=第4の閾値電圧)又は第5の閾値電圧(第4の閾値電圧<第5の閾値電圧)とし、
前記制御回路は、前記第1、第2の書き込み動作において、プログラム電圧をΔVpgmづつ上げて、プログラム及びベリファイ動作を繰り返して書き込み動作を行ない、前記第1の書き込み動作時のΔVpgmは、前記第2の書き込み動作時のΔVpgmよりも大きい値であることを特徴とする半導体記憶装置。
A memory cell array connected to a word line and a bit line and configured by arranging a plurality of memory cells storing four values in a matrix;
A control circuit for controlling the potential of the word line and the bit line in accordance with input data and writing data to the memory cell;
The control circuit includes:
By the first write operation, the threshold voltage of the memory cell is changed from the first threshold voltage to the first threshold voltage or the second threshold voltage (first threshold voltage <second threshold voltage),
When the threshold voltage of the memory cell is the first threshold voltage by the second write operation, the first threshold voltage or the third threshold voltage (first threshold voltage <third threshold voltage) is set. When it is the second threshold voltage, the fourth threshold voltage (second threshold voltage <= fourth threshold voltage) or the fifth threshold voltage (fourth threshold voltage <fifth threshold voltage),
In the first and second write operations, the control circuit increases the program voltage by ΔVpgm and repeats the program and verify operations to perform the write operation. The ΔVpgm in the first write operation is the second write operation. A semiconductor memory device having a value larger than ΔVpgm at the time of the write operation.
前記制御回路は、第3の書き込み動作により、前記メモリセルの閾値電圧が前記第1の閾値電圧である場合、前記第1の閾値電圧又は第6の閾値電圧(第1の閾値電圧<第6の閾値電圧)とし、
前記第3の閾値電圧である場合、第7の閾値電圧(第3の閾値電圧<=第7の閾値電圧)又は第8の閾値電圧(第7の閾値電圧<第8の閾値電圧)とし、
前記第4の閾値電圧である場合、第9の閾値電圧(第4の閾値電圧<=第9の閾値電圧)又は第10の閾値電圧(第9の閾値電圧<第10の閾値電圧)とし、
第5の閾値電圧である場合、第11の閾値電圧(第5の閾値電圧<=第11の閾値電圧)又は第12の閾値電圧(第11の閾値電圧<=第12の閾値電圧)とすることを特徴とする請求項3記載の半導体記憶装置。
When the threshold voltage of the memory cell is the first threshold voltage by the third write operation, the control circuit performs the first threshold voltage or the sixth threshold voltage (first threshold voltage <6th Threshold voltage)
When the third threshold voltage, the seventh threshold voltage (third threshold voltage <= seventh threshold voltage) or the eighth threshold voltage (seventh threshold voltage <eighth threshold voltage),
If the fourth threshold voltage, the ninth threshold voltage (fourth threshold voltage <= ninth threshold voltage) or tenth threshold voltage (9th threshold voltage <tenth threshold voltage),
In the case of the fifth threshold voltage, the eleventh threshold voltage (fifth threshold voltage <= eleventh threshold voltage) or the twelfth threshold voltage (eleventh threshold voltage <= twelfth threshold voltage) is set. The semiconductor memory device according to claim 3.
前記制御回路は、前記第3の書き込み動作において、プログラム電圧をΔVpgmづつ上げて、プログラム及びベリファイ動作を繰り返して書き込み動作を行ない、前記第2の書き込み動作時のΔVpgmは、前記第3の書き込み動作時のΔVpgmよりも大きい値であることを特徴とする請求項4記載の半導体記憶装置。   In the third write operation, the control circuit increases the program voltage by ΔVpgm and repeats the program and verify operations to perform the write operation. The ΔVpgm in the second write operation is the third write operation. 5. The semiconductor memory device according to claim 4, wherein the value is larger than the hourly ΔVpgm. 前記制御回路は、前記第2の書き込み動作において、前記第4の閾値電圧に書き込んでいるメモリセルが接続されたビット線に中間電位を供給することを特徴とする請求項2又は3記載の半導体記憶装置。   4. The semiconductor according to claim 2, wherein the control circuit supplies an intermediate potential to a bit line connected to a memory cell written to the fourth threshold voltage in the second write operation. 5. Storage device. 前記制御回路は、前記第2の書き込み動作において、前記第3の閾値電圧に書き込んでいるメモリセルのうち、前記第3の閾値電圧より低い閾値電圧を有するメモリセルの書き込みスピードを遅くすることを特徴とする請求項2又は3記載の半導体記憶装置。   In the second write operation, the control circuit slows down the write speed of a memory cell having a threshold voltage lower than the third threshold voltage among the memory cells written to the third threshold voltage. 4. The semiconductor memory device according to claim 2, wherein: 前記制御回路は、前記ビット線を一度プリチャージした後、ワード線の電位を変化させて前記メモリセルから前記第4の閾値電圧のデータ、前記第5の閾値電圧のデータを読み出すことを特徴とする請求項2又は3記載の半導体記憶装置。   The control circuit reads the fourth threshold voltage data and the fifth threshold voltage data from the memory cell by changing the potential of the word line after precharging the bit line once. The semiconductor memory device according to claim 2 or 3. ワード線、及びビット線に接続され、4値を記憶する複数のメモリセルがマトリックス状に配置されて構成されたメモリセルアレイと、
入力データに応じて前記ワード線、ビット線の電位を制御し、前記メモリセルにデータを書き込む制御回路とを具備し、
前記制御回路は、
第1の書き込み動作により、前記メモリセルの閾値電圧を前記第1の閾値電圧から第1の閾値電圧又は第2の閾値電圧(第1の閾値電圧<第2の閾値電圧)とし、
第2の書き込み動作により、前記メモリセルの閾値電圧が前記第1の閾値電圧である場合、第1の閾値電圧又は第3の閾値電圧(第1の閾値電圧<第3の閾値電圧)とし、第2の閾値電圧である場合、第4の閾値電圧(第2の閾値電圧<=第4の閾値電圧)又は第5の閾値電圧(第4の閾値電圧<第5の閾値電圧)とし、
前記制御回路は、前記第2の書き込み動作において、プログラム及びベリファイ動作を繰り返し行ない、前記第3の閾値電圧に達したかどうかをベリファイするベリファイ動作の回数に最大値を設定し、前記ベリファイ動作の回数が前記最大値に達した場合、前記第3の閾値電圧に達したかどうかをベリファイするベリファイ動作をスキップすることを特徴とする半導体記憶装置。
A memory cell array connected to a word line and a bit line and configured by arranging a plurality of memory cells storing four values in a matrix;
A control circuit for controlling the potential of the word line and the bit line in accordance with input data and writing data to the memory cell;
The control circuit includes:
By the first write operation, the threshold voltage of the memory cell is changed from the first threshold voltage to the first threshold voltage or the second threshold voltage (first threshold voltage <second threshold voltage),
When the threshold voltage of the memory cell is the first threshold voltage by the second write operation, the first threshold voltage or the third threshold voltage (first threshold voltage <third threshold voltage) is set. When it is the second threshold voltage, the fourth threshold voltage (second threshold voltage <= fourth threshold voltage) or the fifth threshold voltage (fourth threshold voltage <fifth threshold voltage),
The control circuit repeatedly performs a program and verify operation in the second write operation, sets a maximum value to the number of verify operations for verifying whether the third threshold voltage has been reached, and performs the verify operation. When the number of times reaches the maximum value, a verify operation for verifying whether or not the third threshold voltage has been reached is skipped.
前記メモリセルと同時に選択される第1のフラグセルをさらに具備し、前記制御回路は、前記第2の書き込み動作時に、前記第1のフラグセルの閾値電圧を前記第1の閾値電圧から前記第3の閾値電圧に変化させることを特徴とする請求項2、3、9の何れかに記載の半導体記憶装置。   The control circuit further includes a first flag cell that is selected simultaneously with the memory cell, and the control circuit is configured to change the threshold voltage of the first flag cell from the first threshold voltage to the third threshold voltage during the second write operation. The semiconductor memory device according to claim 2, wherein the semiconductor memory device is changed to a threshold voltage. 前記メモリセルと同時に選択される第2のフラグセルをさらに具備し、前記制御回路は、前記第2の書き込み動作時に、前記第2のフラグセルの閾値電圧を前記第1の閾値電圧から前記第4の閾値電圧に変化させることを特徴とする請求項2、3、9の何れかに記載の半導体記憶装置。   The control circuit further includes a second flag cell that is selected simultaneously with the memory cell, and the control circuit changes the threshold voltage of the second flag cell from the first threshold voltage to the fourth threshold voltage during the second write operation. 10. The semiconductor memory device according to claim 2, wherein the semiconductor memory device is changed to a threshold voltage. 前記制御回路は、第1の読み出し動作において、前記第4の閾値電圧で前記メモリセルからデータを読み出し、前記第2のフラグセルにデータが書き込まれている場合、前記読み出したデータを出力し、前記第2のフラグセルにデータが書きこまれていない場合、前記第2の閾値電圧で前記メモリセルから読み出したデータを出力することを特徴とする請求項11記載の半導体記憶装置。   In the first read operation, the control circuit reads data from the memory cell with the fourth threshold voltage, and outputs data when the data is written to the second flag cell, 12. The semiconductor memory device according to claim 11, wherein when data is not written in the second flag cell, data read from the memory cell is output at the second threshold voltage. 前記制御回路は、第2の読み出し動作において、前記第3の閾値電圧で前記メモリセルからデータを読み出し、前記第1のフラグセルにデータが書き込まれている場合、前記読み出したデータを出力し、前記第1のフラグセルにデータが書き込まれていない場合、固定値を出力することを特徴とする請求項10記載の半導体記憶装置。   In the second read operation, the control circuit reads data from the memory cell at the third threshold voltage, and outputs the read data when data is written to the first flag cell, 11. The semiconductor memory device according to claim 10, wherein a fixed value is output when data is not written in the first flag cell. 前記制御回路は、第3の書き込み動作により、前記メモリセルの閾値電圧が前記第1の閾値電圧である場合、前記第1の閾値電圧又は第6の閾値電圧(第1の閾値電圧<第6の閾値電圧)とし、
前記第3の閾値電圧である場合、第7の閾値電圧(第3の閾値電圧<=第7の閾値電圧)又は第8の閾値電圧(第7の閾値電圧<第8の閾値電圧)とし、
前記第4の閾値電圧である場合、第9の閾値電圧(第4の閾値電圧<=第9の閾値電圧)又は第10の閾値電圧(第9の閾値電圧<第10の閾値電圧)とし、第5の閾値電圧である場合、第11の閾値電圧(第5の閾値電圧<=第11の閾値電圧)又は第12の閾値電圧(第11の閾値電圧<=第12の閾値電圧)とすることを特徴とする請求項2記載の半導体記憶装置。
When the threshold voltage of the memory cell is the first threshold voltage by the third write operation, the control circuit performs the first threshold voltage or the sixth threshold voltage (first threshold voltage <6th Threshold voltage)
When the third threshold voltage, the seventh threshold voltage (third threshold voltage <= seventh threshold voltage) or the eighth threshold voltage (seventh threshold voltage <eighth threshold voltage),
If the fourth threshold voltage, the ninth threshold voltage (fourth threshold voltage <= ninth threshold voltage) or tenth threshold voltage (9th threshold voltage <tenth threshold voltage), In the case of the fifth threshold voltage, the eleventh threshold voltage (fifth threshold voltage <= eleventh threshold voltage) or the twelfth threshold voltage (eleventh threshold voltage <= twelfth threshold voltage) is set. The semiconductor memory device according to claim 2.
前記制御回路は、前記第3の書き込み動作において、プログラム電圧をΔVpgmづつ上げて、プログラム及びベリファイ動作を繰り返して書き込み動作を行ない、前記第2の書き込み動作時のΔVpgmは、前記第3の書き込み動作時のΔVpgmよりも大きい値であることを特徴とする請求項14記載の半導体記憶装置。   In the third write operation, the control circuit increases the program voltage by ΔVpgm and repeats the program and verify operations to perform the write operation. The ΔVpgm in the second write operation is the third write operation. 15. The semiconductor memory device according to claim 14, wherein the value is larger than ΔVpgm at the time. 前記制御回路は、前記第3の書き込み動作の第1回目の書き込み動作により、前記第9の閾値電圧、第10の閾値電圧、第11の閾値電圧、及び第12の閾値電圧への書き込みを行ない、前記第3の書き込み動作の第2回目の書き込み動作により、前記第6の閾値電圧、第7の閾値電圧、及び第8の閾値電圧への書き込みを行なうことを特徴とする請求項14記載の半導体記憶装置。   The control circuit performs writing to the ninth threshold voltage, the tenth threshold voltage, the eleventh threshold voltage, and the twelfth threshold voltage by the first writing operation of the third writing operation. 15. The writing to the sixth threshold voltage, the seventh threshold voltage, and the eighth threshold voltage is performed by the second writing operation of the third writing operation. Semiconductor memory device. 前記第3の書き込み動作の第1回目の書き込み動作において、前記制御回路は、前記ビット線を一度プリチャージした後、前記ワード線の電位を変化させて前記メモリセルが前記第11の閾値電圧に達したかどうかのベリファイと、前記第12の閾値電圧に達したかどうかのベリファイを行なうことを特徴とする請求項14記載の半導体記憶装置。   In the first write operation of the third write operation, the control circuit precharges the bit line once and then changes the potential of the word line so that the memory cell becomes the eleventh threshold voltage. 15. The semiconductor memory device according to claim 14, wherein verifying whether or not the threshold voltage has been reached and verifying whether or not the twelfth threshold voltage has been reached are performed. 前記第3の書き込み動作の第2回目の書き込み動作において、前記制御回路は、前記ビット線を一度プリチャージした後、前記ワード線の電位を変化させて前記メモリセルが前記第7の閾値電圧に達したかどうかのベリファイと、前記第8の閾値電圧に達したかどうかのベリファイを行なうことを特徴とする請求項14記載の半導体記憶装置。   In the second write operation of the third write operation, the control circuit precharges the bit line once and then changes the potential of the word line so that the memory cell becomes the seventh threshold voltage. 15. The semiconductor memory device according to claim 14, wherein verification is performed as to whether or not said eighth threshold voltage has been reached. 前記第3の書き込み動作の第1回目の書き込み動作において、前記制御回路は、前記第11の閾値電圧に書き込んでいるメモリセルの書き込みスピードを遅くすることを特徴とする請求項14記載の半導体記憶装置。   15. The semiconductor memory according to claim 14, wherein, in the first write operation of the third write operation, the control circuit slows down the write speed of the memory cell that writes to the eleventh threshold voltage. apparatus. 前記第3の書き込み動作の第2回目の書き込み動作において、前記制御回路は、前記第7の閾値電圧に書き込んでいるセルの書き込みスピードを遅くすることを特徴とする請求項14記載の半導体記憶装置。   15. The semiconductor memory device according to claim 14, wherein, in the second write operation of the third write operation, the control circuit slows down a write speed of a cell written to the seventh threshold voltage. . 前記第3の書き込み動作の第2回目の書き込み動作において、前記制御回路は、第6の閾値電圧に書き込んでいるセルのうち、第6の閾値電圧より低い閾値電圧を超えたセルの書き込みスピードを遅くすることを特徴とする請求項14記載の半導体記憶装置。   In the second write operation of the third write operation, the control circuit increases the write speed of a cell that exceeds the threshold voltage lower than the sixth threshold voltage among the cells that are written to the sixth threshold voltage. 15. The semiconductor memory device according to claim 14, wherein the semiconductor memory device is delayed. 第1閾値電圧乃至第n閾値電圧(nは2以上の自然数)により、データを記憶するメモリセルと、
入力データに応じて前記メモリセルに前記第1乃至第n閾値電圧のいずれかを書き込む制御回路とを具備し、
前記制御回路は、第1回目の書き込み動作により、前記メモリセルに第n閾値電圧、第(n−1)閾値電圧…第(n−k+1)閾値電圧のk値の閾値電圧に書き込み、第2回目の書き込み動作により、前記メモリセルに第(n−k)閾値電圧、第(n−k−1)閾値電圧…第(n−2k+1)閾値電圧のk値の閾値電圧に書き込み、第n/k回目の書き込み動作により、前記メモリセルに第k閾値電圧、第(k−1)閾値電圧…第2閾値電圧の(k−1)値の閾値電圧を書き込むことを特徴とする半導体記憶装置。
Memory cells for storing data according to a first threshold voltage to an nth threshold voltage (n is a natural number of 2 or more);
A control circuit for writing one of the first to nth threshold voltages in the memory cell according to input data,
The control circuit writes to the threshold voltage of the k value of the nth threshold voltage, the (n−1) th threshold voltage,... (N−k + 1) th threshold voltage in the first write operation. By the write operation of the second time, the memory cell is written to the threshold voltage of the (n−k) th threshold voltage, the (n−k−1) th threshold voltage, the (n−2k + 1) th threshold voltage, and the nth / A semiconductor memory device, wherein a kth threshold voltage, a (k−1) th threshold voltage, and a (k−1) th threshold voltage of a second threshold voltage are written into the memory cell by a kth write operation.
前記各閾値電圧は、第1閾値電圧乃至第n閾値電圧(nは2以上の自然数)の順で閾値電圧が高く定義され、書き込み動作により閾値電圧が高くなることを特徴とする請求項22記載の半導体記憶装置。   23. The threshold voltage is defined such that a threshold voltage is higher in order of a first threshold voltage to an nth threshold voltage (n is a natural number of 2 or more), and the threshold voltage is increased by a write operation. Semiconductor memory device. 少なくとも1つ以上のデータを記憶するメモリと、
前記メモリセルに接続され、外部より入力された第1論理レベル又は第2論理レベルのデータを記憶する少なくとも1つ以上のデータ記憶回路と、
前記データ記憶回路の動作を制御する制御回路とを有し、
前記制御回路は、前記データ記憶回路に記憶されたデータの論理レベルが、第1論理レベルの場合、第2論理レベルに反転させ、第2論理レベルの場合、第1論理レベルに反転させ、
前記データ記憶回路に記憶されたデータの論理レベルが第1論理レベルの場合、前記メモリセルに閾値電圧を上げる書き込み動作を行ない、第2論理レベルの場合、前記メモリセルに閾値電圧は変化させず維持させることを特徴とする半導体記憶装置。
A memory for storing at least one or more data;
At least one data storage circuit connected to the memory cell and storing data of a first logic level or a second logic level input from the outside;
A control circuit for controlling the operation of the data storage circuit,
The control circuit inverts to the second logic level when the logic level of the data stored in the data storage circuit is the first logic level, and inverts to the first logic level if the logic level is the second logic level;
When the logic level of the data stored in the data storage circuit is the first logic level, a write operation for increasing the threshold voltage is performed on the memory cell. When the logic level is the second logic level, the threshold voltage is not changed in the memory cell. A semiconductor memory device characterized by being maintained.
ワード線、及びビット線に接続され、n値(nは3以上の自然数)を記憶する複数のメモリセルがマトリックス状に配置されて構成されたメモリセルアレイと、
入力データに応じて前記ワード線、ビット線の電位を制御し、前記メモリセルにデータを書き込む制御回路とを具備し、
前記制御回路は、
第1の書き込み動作により、a1値(a1<=n)の閾値電圧に書き込み、第2の書き込み動作により、a2値(a2<=n)の閾値電圧に書き込み、第k(kは2以上の自然数:k<=n)の書き込み動作により、ak値(ak<=n)の閾値電圧を書き込み、
前記第1、第2乃至第kの書き込み動作において、プログラム電圧をΔVpgmづつ上げて、プログラム及びベリファイ動作を繰り返して書き込み動作を行ない、
前記第1、第2乃至第kの書き込み動作時のΔVpgmは、第1のΔVpgm>第2のΔVpgm…>第kのΔVpgmであることを特徴とする半導体記憶装置。
A memory cell array connected to a word line and a bit line and configured by arranging a plurality of memory cells storing n values (n is a natural number of 3 or more) in a matrix;
A control circuit for controlling the potential of the word line and the bit line in accordance with input data and writing data to the memory cell;
The control circuit includes:
The first write operation writes to the threshold voltage of the a1 value (a1 <= n), the second write operation writes to the threshold voltage of the a2 value (a2 <= n), and the kth (k is 2 or more). By writing operation of natural number: k <= n), a threshold voltage of ak value (ak <= n) is written,
In the first, second to kth write operations, the program voltage is increased by ΔVpgm and the program and verify operations are repeated to perform the write operation.
ΔVpgm during the first, second to kth write operations is first ΔVpgm> second ΔVpgm...> Kth ΔVpgm.
第1閾値電圧乃至第n閾値電圧(nは2以上の自然数)の順で閾値電圧が高く定義され、書き込み動作により閾値電圧が高くなり、前記第1閾値電圧乃至第n閾値電圧により、データを記憶するメモリセルと、
入力データに応じて前記メモリセルに前記第1乃至第n閾値電圧のいずれかを書き込む制御回路とを具備し、
前記制御回路は、第1回目の書き込み動作により、前記メモリセルに第n閾値電圧、第(n−1)閾値電圧…第(n−k1+1)閾値電圧のk1値の閾値電圧に書き込み、第2回目の書き込み動作により、前記メモリセルに第(n−k1)閾値電圧、第(n−k1−1)閾値電圧…第(n−k1−k2+1)閾値電圧のk2値の閾値電圧に書き込み、第i回目の書き込み動作により、前記メモリセルに第ki閾値電圧、第(ki−1)閾値電圧…第2閾値電圧の(ki−1)値の閾値電圧を書き込むことを特徴とする半導体記憶装置。
The threshold voltage is defined to be higher in the order of the first threshold voltage to the nth threshold voltage (n is a natural number of 2 or more), and the threshold voltage is increased by the write operation. A memory cell to store;
A control circuit for writing one of the first to nth threshold voltages in the memory cell according to input data,
The control circuit writes to the threshold voltage of the k1 value of the nth threshold voltage, the (n−1) th threshold voltage,... The (n−k1 + 1) th threshold voltage in the first write operation, and the second By the second write operation, the memory cell is written to the threshold voltage of the (n−k1) th threshold voltage, the (n−k1-1) th threshold voltage, the (n−k1−k2 + 1) th threshold voltage, and the k2th threshold voltage. A semiconductor memory device, wherein a threshold voltage having a (ki-1) value of a kith threshold voltage, a (ki-1) th threshold voltage, ... a second threshold voltage is written into the memory cell by an i-th write operation.
前記メモリセルは、NAND型フラッシュメモリを構成することを特徴とする請求項1、3、9、22、24、25、26の何れかに記載の半導体記憶装置。   27. The semiconductor memory device according to claim 1, wherein the memory cell constitutes a NAND flash memory. ワード線、及びビット線に接続され、n値(nは3以上の自然数)を記憶する複数のメモリセルがマトリックス状に配置されて構成されたメモリセルアレイと、
入力データに応じて前記ワード線、ビット線の電位を制御し、前記メモリセルにデータを書き込む制御回路と、
前記ビット線に接続され、少なくとも1ビット以上のデータを記憶するデータ記憶回路を具備し、
前記制御回路は、書き込み動作により、メモリセルの閾値電圧が第k値の閾値電圧に達したかのベリファイ時、前記第k値の閾値電圧より低い閾値電圧でベリファイ動作を行ない、前記メモリセルの閾値電圧が前記第k値の閾値電圧より低い閾値電圧を越えている場合、前記データ記憶回路内のデータを第k値より低い第i値の閾値電圧(i<k)への書き込みと同じデータに設定することを特徴とする半導体記憶装置。
A memory cell array connected to a word line and a bit line and configured by arranging a plurality of memory cells storing n values (n is a natural number of 3 or more) in a matrix;
A control circuit for controlling the potential of the word line and the bit line according to input data and writing data to the memory cell;
A data storage circuit connected to the bit line and storing at least one bit of data;
The control circuit performs a verify operation with a threshold voltage lower than the threshold voltage of the kth value when verifying whether the threshold voltage of the memory cell has reached the threshold voltage of the kth value by a write operation, and the threshold voltage of the memory cell Is over the threshold voltage lower than the threshold voltage of the k-th value, the data in the data storage circuit is set to the same data as the writing to the threshold voltage of the i-th value lower than the k-th value (i <k) A semiconductor memory device.
前記制御回路は、前記第k値の閾値電圧に達したかのベリファイ動作前に、前記第i値の閾値電圧に達したかのベリファイ動作を行なうことを特徴とする請求項28記載の半導体記憶装置。   29. The semiconductor memory device according to claim 28, wherein the control circuit performs a verify operation on whether the threshold voltage of the i-th value has been reached before the verify operation on whether the threshold voltage of the k-th value has been reached. 前記制御回路は、前記第i値の閾値電圧への書き込み時、書き込み速度を遅くすることことを特徴とする請求項28記載の半導体記憶装置。   29. The semiconductor memory device according to claim 28, wherein the control circuit slows down a writing speed when writing to the threshold voltage of the i-th value. 前記制御回路は、前記第i値の閾値電圧への書き込み時、前記メモリセルのビット線に中間電位を供給することを特徴とする請求項30記載の半導体記憶装置。   31. The semiconductor memory device according to claim 30, wherein the control circuit supplies an intermediate potential to the bit line of the memory cell when writing to the threshold voltage of the i-th value. 前記k値のデータを書き込む際、第1の書き込み動作において上位k/2個のデータを書き込み、第2の書き込み動作において下位k/2個のデータを書き込むことを特徴とする請求項28記載の半導体記憶装置。   29. The writing of the k-value data, wherein upper k / 2 data is written in a first write operation, and lower k / 2 data is written in a second write operation. Semiconductor memory device. k(kは2以上の自然数)ビットを記憶するメモリセルと、
外部から入力されるデータ、及びメモリセルから読み出されたデータを記憶する第1の記憶回路と、
前記第1の記憶回路に記憶されたデータを記憶する第2の記憶回路と、
前記メモリセルから読み出されたデータを記憶するた第3の記憶回路と、
前記第3の記憶回路に記憶されたデータを記憶する第4の記憶回路とを具備し、
書き込み動作時、前記メモリセルが記憶しているデータに応じて、前記第1乃至第4の記憶回路のデータを保持又は変更し、第3ページの書き込み動作において、8値のデータを同じに書き込む制御回路と
を具備すること特徴とする半導体記憶装置。
a memory cell storing k (k is a natural number of 2 or more) bits;
A first memory circuit for storing data input from the outside and data read from the memory cell;
A second memory circuit for storing data stored in the first memory circuit;
A third memory circuit for storing data read from the memory cell;
A fourth memory circuit for storing data stored in the third memory circuit,
During the write operation, the data in the first to fourth storage circuits is held or changed according to the data stored in the memory cell, and the eight-value data is written in the same manner in the third page write operation. A semiconductor memory device comprising: a control circuit.
ワード線、及びビット線に接続され、n値(nは3以上の自然数)を記憶する複数のメモリセルがマトリックス状に配置されて構成されたメモリセルアレイと、
入力データに応じて前記ワード線、ビット線の電位を制御し、前記メモリセルからデータを読み出す制御回路とを具備し、
前記制御回路は、前記ビット線を一度プリチャージした後、前記ワード線の電位をi回変化させて前記メモリセルのデータを読み出すことを特徴とする半導体記憶装置。
A memory cell array connected to a word line and a bit line and configured by arranging a plurality of memory cells storing n values (n is a natural number of 3 or more) in a matrix;
A control circuit for controlling the potential of the word line and the bit line according to input data and reading data from the memory cell;
The control circuit reads the data of the memory cell by precharging the bit line once and then changing the potential of the word line i times.
JP2004160165A 2004-01-30 2004-05-28 Semiconductor memory device Active JP4170952B2 (en)

Priority Applications (17)

Application Number Priority Date Filing Date Title
JP2004160165A JP4170952B2 (en) 2004-01-30 2004-05-28 Semiconductor memory device
US10/988,592 US7245528B2 (en) 2004-01-30 2004-11-16 Semiconductor memory device which stores plural data in a cell
KR20040107347A KR100688369B1 (en) 2004-01-30 2004-12-16 Semiconductor memory device which stores plural data in a cell
US11/759,627 US7376009B2 (en) 2004-01-30 2007-06-07 Semiconductor memory device which stores plural data in a cell
US12/117,767 US7738302B2 (en) 2004-01-30 2008-05-09 Semiconductor memory device with stores plural data in a cell
US12/775,571 US8154930B2 (en) 2004-01-30 2010-05-07 Semiconductor memory device which stores plural data in a cell
US13/413,779 US8385130B2 (en) 2004-01-30 2012-03-07 Semiconductor memory device which stores plural data in a cell
US13/754,057 US8542538B2 (en) 2004-01-30 2013-01-30 Semiconductor memory device which stores plural data in a cell
US14/017,611 US9142299B2 (en) 2004-01-30 2013-09-04 Semiconductor memory device which stores plural data in a cell
US14/825,858 US9390802B2 (en) 2004-01-30 2015-08-13 Semiconductor memory device which stores plural data in a cell
US15/175,806 US9627048B2 (en) 2004-01-30 2016-06-07 Semiconductor memory device which stores plural data in a cell
US15/453,302 US9858992B2 (en) 2004-01-30 2017-03-08 Semiconductor memory device which stores plural data in a cell
US15/832,557 US10096358B2 (en) 2004-01-30 2017-12-05 Semiconductor memory device which stores plural data in a cell
US16/125,601 US10431297B2 (en) 2004-01-30 2018-09-07 Semiconductor memory device which stores plural data in a cell
US16/539,205 US10699781B2 (en) 2004-01-30 2019-08-13 Semiconductor memory device which stores plural data in a cell
US16/857,611 US10878895B2 (en) 2004-01-30 2020-04-24 Semiconductor memory device which stores plural data in a cell
US17/101,431 US11309019B2 (en) 2004-01-30 2020-11-23 Semiconductor memory device which stores plural data in a cell

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
JP2004024475 2004-01-30
JP2004160165A JP4170952B2 (en) 2004-01-30 2004-05-28 Semiconductor memory device

Related Child Applications (2)

Application Number Title Priority Date Filing Date
JP2008099646A Division JP2008176924A (en) 2004-01-30 2008-04-07 Semiconductor storage
JP2008177382A Division JP2008282526A (en) 2004-01-30 2008-07-07 Semiconductor storage

Publications (2)

Publication Number Publication Date
JP2005243205A true JP2005243205A (en) 2005-09-08
JP4170952B2 JP4170952B2 (en) 2008-10-22

Family

ID=34810177

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2004160165A Active JP4170952B2 (en) 2004-01-30 2004-05-28 Semiconductor memory device

Country Status (3)

Country Link
US (15) US7245528B2 (en)
JP (1) JP4170952B2 (en)
KR (1) KR100688369B1 (en)

Cited By (22)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2007193911A (en) * 2006-01-20 2007-08-02 Toshiba Corp Semiconductor memory device
US7292474B2 (en) 2006-01-31 2007-11-06 Kabushiki Kaisha Toshiba Semiconductor integrated circuit device
JP2007335069A (en) * 2006-06-12 2007-12-27 Samsung Electronics Co Ltd Nonvolatile memory device and its operating method
JP2008065977A (en) * 2006-09-06 2008-03-21 Samsung Electronics Co Ltd Program method for multi-level non-volatile memory device
JP2008090993A (en) * 2006-09-29 2008-04-17 Hynix Semiconductor Inc Method for programming nand flash memory element
JP2008165967A (en) * 2006-12-28 2008-07-17 Samsung Electronics Co Ltd Memory cell programming method for reducing coupling effect
JP2008198337A (en) * 2007-01-17 2008-08-28 Toshiba Corp Semiconductor storage device
JP2008269773A (en) * 2007-04-24 2008-11-06 Hynix Semiconductor Inc Method of operating flash memory device, and control circuit therefor
JP2009004077A (en) * 2007-06-22 2009-01-08 Samsung Electronics Co Ltd Non-volatile memory device and method of operating the same
US7505312B2 (en) 2006-01-31 2009-03-17 Kabushiki Kaisha Toshiba Nonvolatile semiconductor memory device capable of controlling proximity effect due to coupling between adjacent charge storage layers
JP2009059453A (en) * 2007-09-03 2009-03-19 Toshiba Corp Nonvolatile semiconductor memory device and memory system
JP2009129479A (en) * 2007-11-20 2009-06-11 Toshiba Corp Method of controlling threshold in nonvolatile semiconductor memory device
JP2010040109A (en) * 2008-08-05 2010-02-18 Toshiba Corp Nonvolatile semiconductor memory device
US7916547B2 (en) 2007-09-14 2011-03-29 Kabushiki Kaisha Toshiba Method for controlling a non-volatile semiconductor memory device
JP2011150788A (en) * 2011-05-13 2011-08-04 Toshiba Corp Semiconductor memory
US8054682B2 (en) 2008-09-23 2011-11-08 Samsung Electronics Co., Ltd. Non-volatile memory device and page buffer circuit thereof
JP2011253608A (en) * 2010-05-31 2011-12-15 Samsung Electronics Co Ltd Nonvolatile memory device having dynamic verification mode selection and operating method, driving method, and programming method thereof, memory system, memory card, and solid-state driver
JP2012014827A (en) * 2011-09-12 2012-01-19 Toshiba Corp Semiconductor memory device
US8456920B2 (en) 2010-04-09 2013-06-04 Kabushiki Kaisha Toshiba Semiconductor memory device capable of executing high-speed page copy
JP2013232259A (en) * 2012-04-27 2013-11-14 Toshiba Corp Semiconductor memory device
JP2013254542A (en) * 2012-06-07 2013-12-19 Toshiba Corp Semiconductor memory
US9349442B2 (en) 2014-04-16 2016-05-24 Kabushiki Kaisha Toshiba Semiconductor memory device

Families Citing this family (128)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP3935139B2 (en) * 2002-11-29 2007-06-20 株式会社東芝 Semiconductor memory device
JP4041057B2 (en) * 2003-11-13 2008-01-30 株式会社東芝 Nonvolatile semiconductor memory device
JP4170952B2 (en) * 2004-01-30 2008-10-22 株式会社東芝 Semiconductor memory device
JP4786171B2 (en) 2004-12-10 2011-10-05 株式会社東芝 Semiconductor memory device
US7158421B2 (en) * 2005-04-01 2007-01-02 Sandisk Corporation Use of data latches in multi-phase programming of non-volatile memories
US7420847B2 (en) * 2004-12-14 2008-09-02 Sandisk Corporation Multi-state memory having data recovery after program fail
JP4832767B2 (en) * 2005-02-03 2011-12-07 株式会社東芝 Semiconductor integrated circuit device and data program method thereof
US7463521B2 (en) * 2005-04-01 2008-12-09 Sandisk Corporation Method for non-volatile memory with managed execution of cached data
US7447078B2 (en) 2005-04-01 2008-11-04 Sandisk Corporation Method for non-volatile memory with background data latch caching during read operations
US7206230B2 (en) * 2005-04-01 2007-04-17 Sandisk Corporation Use of data latches in cache operations of non-volatile memories
JP4991131B2 (en) * 2005-08-12 2012-08-01 株式会社東芝 Semiconductor memory device
JP4836548B2 (en) * 2005-11-11 2011-12-14 株式会社東芝 Semiconductor integrated circuit device
US7813170B2 (en) * 2005-11-11 2010-10-12 Kabushiki Kaisha Toshiba Semiconductor memory device capable of memorizing multivalued data
JP4734110B2 (en) * 2005-12-14 2011-07-27 株式会社東芝 Nonvolatile semiconductor memory device
US7567472B2 (en) * 2006-04-12 2009-07-28 Micron Technology, Inc. Memory block testing
US7583545B2 (en) * 2006-05-21 2009-09-01 Sandisk Il Ltd Method of storing data in a multi-bit-cell flash memory
US7894269B2 (en) * 2006-07-20 2011-02-22 Sandisk Corporation Nonvolatile memory and method for compensating during programming for perturbing charges of neighboring cells
US7885119B2 (en) 2006-07-20 2011-02-08 Sandisk Corporation Compensating for coupling during programming
KR100771883B1 (en) * 2006-09-06 2007-11-01 삼성전자주식회사 Multi-level non-volatile memory device and program method thereof
KR100909961B1 (en) * 2006-10-10 2009-07-29 삼성전자주식회사 Programmable voltage generation circuit and method, and nonvolatile memory device using same
US8059456B2 (en) * 2006-11-07 2011-11-15 Sandisk Il Ltd. Programming a NAND flash memory with reduced program disturb
ITTO20060931A1 (en) * 2006-12-29 2008-06-30 Intel Corp SYSTEMS AND METHODS TO REDUCE THE INTERFERENCE BETWEEN MEMORY CELLS
US7679965B2 (en) * 2007-01-31 2010-03-16 Sandisk Il Ltd Flash memory with improved programming precision
US7738295B2 (en) * 2007-01-31 2010-06-15 Micron Technology, Inc. Programming a non-volatile memory device
US7652929B2 (en) * 2007-09-17 2010-01-26 Sandisk Corporation Non-volatile memory and method for biasing adjacent word line for verify during programming
WO2009095902A2 (en) * 2008-01-31 2009-08-06 Densbits Technologies Ltd. Systems and methods for handling immediate data errors in flash memory
US8650352B2 (en) 2007-09-20 2014-02-11 Densbits Technologies Ltd. Systems and methods for determining logical values of coupled flash memory cells
US8694715B2 (en) 2007-10-22 2014-04-08 Densbits Technologies Ltd. Methods for adaptively programming flash memory devices and flash memory systems incorporating same
US8443242B2 (en) 2007-10-25 2013-05-14 Densbits Technologies Ltd. Systems and methods for multiple coding rates in flash devices
US8565019B2 (en) * 2007-11-20 2013-10-22 Kabushiki Kaisha Toshiba Method for controlling threshold value in nonvolatile semiconductor memory device
US8321625B2 (en) 2007-12-05 2012-11-27 Densbits Technologies Ltd. Flash memory device with physical cell value deterioration accommodation and methods useful in conjunction therewith
WO2009072103A2 (en) 2007-12-05 2009-06-11 Densbits Technologies Ltd. Flash memory apparatus and methods using a plurality of decoding stages including optional use of concatenated bch codes and/or designation of 'first below' cells
WO2009072105A2 (en) 2007-12-05 2009-06-11 Densbits Technologies Ltd. A low power chien-search based bch/rs decoding system for flash memory, mobile communications devices and other applications
US7688638B2 (en) * 2007-12-07 2010-03-30 Sandisk Corporation Faster programming of multi-level non-volatile storage through reduced verify operations
US8359516B2 (en) 2007-12-12 2013-01-22 Densbits Technologies Ltd. Systems and methods for error correction and decoding on multi-level physical media
US8276051B2 (en) * 2007-12-12 2012-09-25 Densbits Technologies Ltd. Chien-search system employing a clock-gating scheme to save power for error correction decoder and other applications
US8327246B2 (en) 2007-12-18 2012-12-04 Densbits Technologies Ltd. Apparatus for coding at a plurality of rates in multi-level flash memory systems, and methods useful in conjunction therewith
KR100938092B1 (en) * 2008-03-10 2010-01-21 주식회사 하이닉스반도체 Method of operating flash memory device
WO2009118720A2 (en) 2008-03-25 2009-10-01 Densbits Technologies Ltd. Apparatus and methods for hardware-efficient unbiased rounding
KR100967003B1 (en) * 2008-05-29 2010-07-02 주식회사 하이닉스반도체 Non volatile memory device and method of operating the same
TWI473117B (en) * 2008-06-04 2015-02-11 A Data Technology Co Ltd Flash storage device with data correction function
US8332725B2 (en) 2008-08-20 2012-12-11 Densbits Technologies Ltd. Reprogramming non volatile memory portions
KR101005145B1 (en) * 2009-03-06 2011-01-04 주식회사 하이닉스반도체 Method of programming a non volatile memory device
US8819385B2 (en) 2009-04-06 2014-08-26 Densbits Technologies Ltd. Device and method for managing a flash memory
US8458574B2 (en) 2009-04-06 2013-06-04 Densbits Technologies Ltd. Compact chien-search based decoding apparatus and method
US8566510B2 (en) 2009-05-12 2013-10-22 Densbits Technologies Ltd. Systems and method for flash memory management
EP2267724A1 (en) * 2009-06-26 2010-12-29 STMicroelectronics Rousset SAS EEPROM memory architecture optimised for embedded memories
US20100332922A1 (en) * 2009-06-30 2010-12-30 Mediatek Inc. Method for managing device and solid state disk drive utilizing the same
US9330767B1 (en) 2009-08-26 2016-05-03 Avago Technologies General Ip (Singapore) Pte. Ltd. Flash memory module and method for programming a page of flash memory cells
US8305812B2 (en) 2009-08-26 2012-11-06 Densbits Technologies Ltd. Flash memory module and method for programming a page of flash memory cells
US8868821B2 (en) 2009-08-26 2014-10-21 Densbits Technologies Ltd. Systems and methods for pre-equalization and code design for a flash memory
US8995197B1 (en) 2009-08-26 2015-03-31 Densbits Technologies Ltd. System and methods for dynamic erase and program control for flash memory device memories
US8730729B2 (en) 2009-10-15 2014-05-20 Densbits Technologies Ltd. Systems and methods for averaging error rates in non-volatile devices and storage systems
US8724387B2 (en) 2009-10-22 2014-05-13 Densbits Technologies Ltd. Method, system, and computer readable medium for reading and programming flash memory cells using multiple bias voltages
US8626988B2 (en) 2009-11-19 2014-01-07 Densbits Technologies Ltd. System and method for uncoded bit error rate equalization via interleaving
US9037777B2 (en) 2009-12-22 2015-05-19 Densbits Technologies Ltd. Device, system, and method for reducing program/read disturb in flash arrays
US8607124B2 (en) 2009-12-24 2013-12-10 Densbits Technologies Ltd. System and method for setting a flash memory cell read threshold
US8341502B2 (en) 2010-02-28 2012-12-25 Densbits Technologies Ltd. System and method for multi-dimensional decoding
US8527840B2 (en) 2010-04-06 2013-09-03 Densbits Technologies Ltd. System and method for restoring damaged data programmed on a flash device
US9104610B2 (en) 2010-04-06 2015-08-11 Densbits Technologies Ltd. Method, system and medium for analog encryption in a flash memory
US8745317B2 (en) 2010-04-07 2014-06-03 Densbits Technologies Ltd. System and method for storing information in a multi-level cell memory
US9021177B2 (en) 2010-04-29 2015-04-28 Densbits Technologies Ltd. System and method for allocating and using spare blocks in a flash memory
US8539311B2 (en) 2010-07-01 2013-09-17 Densbits Technologies Ltd. System and method for data recovery in multi-level cell memories
US8510639B2 (en) 2010-07-01 2013-08-13 Densbits Technologies Ltd. System and method for multi-dimensional encoding and decoding
US8467249B2 (en) 2010-07-06 2013-06-18 Densbits Technologies Ltd. Systems and methods for storing, retrieving, and adjusting read thresholds in flash memory storage system
US8964464B2 (en) 2010-08-24 2015-02-24 Densbits Technologies Ltd. System and method for accelerated sampling
US8508995B2 (en) 2010-09-15 2013-08-13 Densbits Technologies Ltd. System and method for adjusting read voltage thresholds in memories
JP5198529B2 (en) * 2010-09-22 2013-05-15 株式会社東芝 Nonvolatile semiconductor memory device
US9063878B2 (en) 2010-11-03 2015-06-23 Densbits Technologies Ltd. Method, system and computer readable medium for copy back
US8850100B2 (en) 2010-12-07 2014-09-30 Densbits Technologies Ltd. Interleaving codeword portions between multiple planes and/or dies of a flash memory device
US8472280B2 (en) 2010-12-21 2013-06-25 Sandisk Technologies Inc. Alternate page by page programming scheme
US10079068B2 (en) 2011-02-23 2018-09-18 Avago Technologies General Ip (Singapore) Pte. Ltd. Devices and method for wear estimation based memory management
US8693258B2 (en) 2011-03-17 2014-04-08 Densbits Technologies Ltd. Obtaining soft information using a hard interface
US8990665B1 (en) 2011-04-06 2015-03-24 Densbits Technologies Ltd. System, method and computer program product for joint search of a read threshold and soft decoding
US9396106B2 (en) 2011-05-12 2016-07-19 Avago Technologies General Ip (Singapore) Pte. Ltd. Advanced management of a non-volatile memory
US8996790B1 (en) 2011-05-12 2015-03-31 Densbits Technologies Ltd. System and method for flash memory management
US9501392B1 (en) 2011-05-12 2016-11-22 Avago Technologies General Ip (Singapore) Pte. Ltd. Management of a non-volatile memory module
US9110785B1 (en) 2011-05-12 2015-08-18 Densbits Technologies Ltd. Ordered merge of data sectors that belong to memory space portions
US9372792B1 (en) 2011-05-12 2016-06-21 Avago Technologies General Ip (Singapore) Pte. Ltd. Advanced management of a non-volatile memory
US9195592B1 (en) 2011-05-12 2015-11-24 Densbits Technologies Ltd. Advanced management of a non-volatile memory
US8667211B2 (en) 2011-06-01 2014-03-04 Densbits Technologies Ltd. System and method for managing a non-volatile memory
US8588003B1 (en) 2011-08-01 2013-11-19 Densbits Technologies Ltd. System, method and computer program product for programming and for recovering from a power failure
US8553468B2 (en) 2011-09-21 2013-10-08 Densbits Technologies Ltd. System and method for managing erase operations in a non-volatile memory
KR101799765B1 (en) * 2011-11-21 2017-11-22 삼성전자주식회사 Method for programing non-volatile memory device
US8947941B2 (en) 2012-02-09 2015-02-03 Densbits Technologies Ltd. State responsive operations relating to flash memory cells
US8996788B2 (en) 2012-02-09 2015-03-31 Densbits Technologies Ltd. Configurable flash interface
US9190162B2 (en) 2012-03-13 2015-11-17 Micron Technology, Inc. Nonconsecutive sensing of multilevel memory cells
US8996793B1 (en) 2012-04-24 2015-03-31 Densbits Technologies Ltd. System, method and computer readable medium for generating soft information
US8838937B1 (en) 2012-05-23 2014-09-16 Densbits Technologies Ltd. Methods, systems and computer readable medium for writing and reading data
KR101996004B1 (en) * 2012-05-29 2019-07-03 삼성전자주식회사 Programming method of nonvolatile memory device and memory system having the same
US8879325B1 (en) 2012-05-30 2014-11-04 Densbits Technologies Ltd. System, method and computer program product for processing read threshold information and for reading a flash memory module
US9053819B2 (en) 2012-07-11 2015-06-09 Sandisk Technologies Inc. Programming method to tighten threshold voltage width with avoiding program disturb
KR20140020154A (en) * 2012-08-08 2014-02-18 에스케이하이닉스 주식회사 Semiconductor memory device and erasing method thereof
US9081664B2 (en) * 2012-08-10 2015-07-14 Kabushiki Kaisha Toshiba Memory system capable of preventing data destruction
US9921954B1 (en) 2012-08-27 2018-03-20 Avago Technologies General Ip (Singapore) Pte. Ltd. Method and system for split flash memory management between host and storage controller
US9368225B1 (en) 2012-11-21 2016-06-14 Avago Technologies General Ip (Singapore) Pte. Ltd. Determining read thresholds based upon read error direction statistics
US9069659B1 (en) 2013-01-03 2015-06-30 Densbits Technologies Ltd. Read threshold determination using reference read threshold
JP2014175028A (en) * 2013-03-08 2014-09-22 Toshiba Corp Nonvolatile semiconductor memory device
US9136876B1 (en) 2013-06-13 2015-09-15 Densbits Technologies Ltd. Size limited multi-dimensional decoding
KR102090677B1 (en) 2013-09-16 2020-03-18 삼성전자주식회사 Non-volatile memory device and method of operation thereof
US9413491B1 (en) 2013-10-08 2016-08-09 Avago Technologies General Ip (Singapore) Pte. Ltd. System and method for multiple dimension decoding and encoding a message
US9348694B1 (en) 2013-10-09 2016-05-24 Avago Technologies General Ip (Singapore) Pte. Ltd. Detecting and managing bad columns
US9397706B1 (en) 2013-10-09 2016-07-19 Avago Technologies General Ip (Singapore) Pte. Ltd. System and method for irregular multiple dimension decoding and encoding
US9786388B1 (en) 2013-10-09 2017-10-10 Avago Technologies General Ip (Singapore) Pte. Ltd. Detecting and managing bad columns
US9536612B1 (en) 2014-01-23 2017-01-03 Avago Technologies General Ip (Singapore) Pte. Ltd Digital signaling processing for three dimensional flash memory arrays
US10120792B1 (en) 2014-01-29 2018-11-06 Avago Technologies General Ip (Singapore) Pte. Ltd. Programming an embedded flash storage device
US9542262B1 (en) 2014-05-29 2017-01-10 Avago Technologies General Ip (Singapore) Pte. Ltd. Error correction
US9892033B1 (en) 2014-06-24 2018-02-13 Avago Technologies General Ip (Singapore) Pte. Ltd. Management of memory units
US9972393B1 (en) 2014-07-03 2018-05-15 Avago Technologies General Ip (Singapore) Pte. Ltd. Accelerating programming of a flash memory module
US9584159B1 (en) 2014-07-03 2017-02-28 Avago Technologies General Ip (Singapore) Pte. Ltd. Interleaved encoding
US9449702B1 (en) 2014-07-08 2016-09-20 Avago Technologies General Ip (Singapore) Pte. Ltd. Power management
US9230674B1 (en) * 2014-10-22 2016-01-05 Synopsys, Inc. Non-volatile memory with negative bias
US9524211B1 (en) 2014-11-18 2016-12-20 Avago Technologies General Ip (Singapore) Pte. Ltd. Codeword management
US10305515B1 (en) 2015-02-02 2019-05-28 Avago Technologies International Sales Pte. Limited System and method for encoding using multiple linear feedback shift registers
US10289480B2 (en) * 2015-03-12 2019-05-14 Toshiba Memory Corporation Memory system
US10628255B1 (en) 2015-06-11 2020-04-21 Avago Technologies International Sales Pte. Limited Multi-dimensional decoding
US9851921B1 (en) 2015-07-05 2017-12-26 Avago Technologies General Ip (Singapore) Pte. Ltd. Flash memory chip processing
US20170025179A1 (en) * 2015-07-24 2017-01-26 Macronix International Co., Ltd. Non-volatile memory device for reducing bit line recovery time
US9378809B1 (en) * 2015-08-05 2016-06-28 Apple Inc. Relaxing verification conditions in memory programming and erasure operations
US9842655B2 (en) 2015-12-08 2017-12-12 Intel Corporation Reducing verification checks when programming a memory device
US9954558B1 (en) 2016-03-03 2018-04-24 Avago Technologies General Ip (Singapore) Pte. Ltd. Fast decoding of data stored in a flash memory
US10146604B2 (en) * 2016-08-23 2018-12-04 Oracle International Corporation Bad block detection and predictive analytics in NAND flash storage devices
JP2018147535A (en) * 2017-03-07 2018-09-20 東芝メモリ株式会社 Semiconductor memory device and memory system
JP6779819B2 (en) * 2017-03-22 2020-11-04 キオクシア株式会社 Semiconductor storage device
JP2020087491A (en) * 2018-11-21 2020-06-04 キオクシア株式会社 Semiconductor storage device
US11264110B2 (en) * 2020-02-13 2022-03-01 Sandisk Technologies Llc Refresh operations for memory cells based on susceptibility to read errors
US11043280B1 (en) * 2020-02-13 2021-06-22 Sandisk Technologies Llc Refresh operations for dedicated groups of blocks of memory cells
JP2021182458A (en) * 2020-05-19 2021-11-25 キオクシア株式会社 Semiconductor storage device

Family Cites Families (105)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4163147A (en) * 1978-01-20 1979-07-31 Sperry Rand Corporation Double bit error correction using double bit complementing
US5357462A (en) 1991-09-24 1994-10-18 Kabushiki Kaisha Toshiba Electrically erasable and programmable non-volatile semiconductor memory with automatic write-verify controller
US6240018B1 (en) * 1993-03-31 2001-05-29 Kabushiki Kaisha Toshiba Nonvolatile semiconductor memory device having verify function
US5555204A (en) * 1993-06-29 1996-09-10 Kabushiki Kaisha Toshiba Non-volatile semiconductor memory device
US6559256B2 (en) * 1994-12-28 2003-05-06 Cambridge Display Technology Ltd. Polymers for use in optical devices
JPH08194679A (en) * 1995-01-19 1996-07-30 Texas Instr Japan Ltd Method and device for processing digital signal and memory cell reading method
JP3210259B2 (en) 1996-04-19 2001-09-17 株式会社東芝 Semiconductor storage device and storage system
KR100244864B1 (en) * 1996-03-18 2000-03-02 니시무로 타이죠 Non-volatile semiconductor memory
JP3740212B2 (en) * 1996-05-01 2006-02-01 株式会社ルネサステクノロジ Nonvolatile semiconductor memory device
JPH09326197A (en) 1996-06-06 1997-12-16 Toshiba Corp Nonvolatile semiconductor storage device and bit line charging method
US6134148A (en) * 1997-09-30 2000-10-17 Hitachi, Ltd. Semiconductor integrated circuit and data processing system
JP3409986B2 (en) * 1997-01-31 2003-05-26 株式会社東芝 Multi-valued memory
JP3481817B2 (en) * 1997-04-07 2003-12-22 株式会社東芝 Semiconductor storage device
JPH11149788A (en) * 1997-11-17 1999-06-02 Oki Electric Ind Co Ltd Semiconductor storage and its control method
US6058042A (en) * 1997-12-26 2000-05-02 Sony Corporation Semiconductor nonvolatile memory device and method of data programming the same
JP3883687B2 (en) * 1998-02-16 2007-02-21 株式会社ルネサステクノロジ Semiconductor device, memory card and data processing system
US6333871B1 (en) * 1998-02-16 2001-12-25 Hitachi, Ltd. Nonvolatile semiconductor memory including a controller for providing an improved reprogram operation
JP3204200B2 (en) * 1998-02-25 2001-09-04 日本電気株式会社 Semiconductor memory device
US5934190A (en) 1998-03-20 1999-08-10 Charles M. Jessup Extruded plastic screen printing frame protector with integral hinged arm
JP4090570B2 (en) * 1998-06-02 2008-05-28 株式会社ルネサステクノロジ Semiconductor device, data processing system, and nonvolatile memory cell threshold value changing method
JP3590270B2 (en) 1998-08-26 2004-11-17 株式会社東芝 Semiconductor storage device
JP2000078872A (en) 1998-09-01 2000-03-14 Yaskawa Electric Corp Control method of movable body
JP4306042B2 (en) 1998-09-16 2009-07-29 ソニー株式会社 NONVOLATILE SEMICONDUCTOR MEMORY DEVICE, NONVOLATILE SEMICONDUCTOR MEMORY DEVICE VERIFY METHOD AND READ METHOD
JP4154771B2 (en) 1998-11-10 2008-09-24 ソニー株式会社 Nonvolatile semiconductor memory device and data writing method thereof
JP2000163977A (en) 1998-11-20 2000-06-16 Sony Corp Nonvolatile semiconductor storage device and its data writing method
JP2000163976A (en) 1998-11-30 2000-06-16 Sony Corp Nonvolatile semiconductor storage device and its verifying method
JP3905990B2 (en) 1998-12-25 2007-04-18 株式会社東芝 Storage device and storage method thereof
US6407944B1 (en) * 1998-12-29 2002-06-18 Samsung Electronics Co., Ltd. Method for protecting an over-erasure of redundant memory cells during test for high-density nonvolatile memory semiconductor devices
KR100388179B1 (en) * 1999-02-08 2003-06-19 가부시끼가이샤 도시바 Nonvolatile semiconductor memory device
JP4246831B2 (en) 1999-02-08 2009-04-02 株式会社東芝 Data identification method for semiconductor integrated circuit device
US6552580B2 (en) * 1999-05-24 2003-04-22 Level One Communications Inc. Bias technique for operating point control in multistage circuits
JP3420121B2 (en) * 1999-06-30 2003-06-23 Necエレクトロニクス株式会社 Nonvolatile semiconductor memory device
JP2001067884A (en) * 1999-08-31 2001-03-16 Hitachi Ltd Nonvolatile semiconductor memory device
JP2001093288A (en) * 1999-09-20 2001-04-06 Toshiba Corp Non-volatile semiconductor memory
USRE40110E1 (en) * 1999-09-20 2008-02-26 Kabushiki Kaisha Toshiba Nonvolatile semiconductor memory device for storing multivalued data
JP3863330B2 (en) * 1999-09-28 2006-12-27 株式会社東芝 Nonvolatile semiconductor memory
JP3569185B2 (en) * 1999-12-24 2004-09-22 Necエレクトロニクス株式会社 Nonvolatile semiconductor memory device
US6246610B1 (en) * 2000-02-22 2001-06-12 Advanced Micro Devices, Inc. Symmetrical program and erase scheme to improve erase time degradation in NAND devices
JP4322395B2 (en) 2000-04-27 2009-08-26 株式会社東芝 Nonvolatile semiconductor memory device
US6928001B2 (en) * 2000-12-07 2005-08-09 Saifun Semiconductors Ltd. Programming and erasing methods for a non-volatile memory cell
JP2001325794A (en) * 2000-05-16 2001-11-22 Mitsubishi Electric Corp Semiconductor memory
JP3653449B2 (en) * 2000-06-15 2005-05-25 シャープ株式会社 Nonvolatile semiconductor memory device
JP3117691B1 (en) 2000-08-03 2000-12-18 生化学工業株式会社 Novel heparitinase and method for producing the same
JP4184586B2 (en) * 2000-09-28 2008-11-19 株式会社東芝 Semiconductor memory device
JP3922516B2 (en) * 2000-09-28 2007-05-30 株式会社ルネサステクノロジ Nonvolatile memory and writing method of nonvolatile memory
JP4082482B2 (en) * 2000-12-11 2008-04-30 株式会社ルネサステクノロジ Storage system and data processing system
JP3631463B2 (en) 2001-12-27 2005-03-23 株式会社東芝 Nonvolatile semiconductor memory device
JP2002288988A (en) * 2001-03-28 2002-10-04 Mitsubishi Electric Corp Non-volatile semiconductor memory
WO2002082460A1 (en) * 2001-04-02 2002-10-17 Hitachi, Ltd. Semiconductor non-volatile storage device
US6584017B2 (en) * 2001-04-05 2003-06-24 Saifun Semiconductors Ltd. Method for programming a reference cell
US6522580B2 (en) 2001-06-27 2003-02-18 Sandisk Corporation Operating techniques for reducing effects of coupling between storage elements of a non-volatile memory operated in multiple data states
JP2003032700A (en) 2001-07-17 2003-01-31 Hitachi Ltd Video processor
JP3870772B2 (en) * 2001-12-06 2007-01-24 セイコーエプソン株式会社 Semiconductor memory device and electronic apparatus using the same
JP3977799B2 (en) * 2003-12-09 2007-09-19 株式会社東芝 Nonvolatile semiconductor memory device
US7301806B2 (en) * 2001-12-27 2007-11-27 Kabushiki Kaisha Toshiba Non-volatile semiconductor memory device adapted to store a multi-valued in a single memory cell
JP3908957B2 (en) * 2002-01-24 2007-04-25 シャープ株式会社 Nonvolatile semiconductor memory device
US7190620B2 (en) * 2002-01-31 2007-03-13 Saifun Semiconductors Ltd. Method for operating a memory device
JP4004811B2 (en) * 2002-02-06 2007-11-07 株式会社東芝 Nonvolatile semiconductor memory device
JP2003242787A (en) * 2002-02-14 2003-08-29 Mitsubishi Electric Corp Nonvolatile semiconductor memory device
US6731528B2 (en) * 2002-05-03 2004-05-04 Micron Technology, Inc. Dual write cycle programmable conductor memory system and method of operation
JP2004022070A (en) * 2002-06-17 2004-01-22 Renesas Technology Corp Semiconductor storage device
JP2003109385A (en) 2002-06-17 2003-04-11 Fujitsu Ltd Semiconductor device
US6894931B2 (en) * 2002-06-20 2005-05-17 Kabushiki Kaisha Toshiba Nonvolatile semiconductor memory device
JP4270832B2 (en) 2002-09-26 2009-06-03 株式会社東芝 Nonvolatile semiconductor memory
US7136304B2 (en) * 2002-10-29 2006-11-14 Saifun Semiconductor Ltd Method, system and circuit for programming a non-volatile memory array
KR100521364B1 (en) * 2002-11-18 2005-10-12 삼성전자주식회사 Flash memory device for verifying successful programming of flash cells and the method thereof
JP3935139B2 (en) * 2002-11-29 2007-06-20 株式会社東芝 Semiconductor memory device
US6657891B1 (en) * 2002-11-29 2003-12-02 Kabushiki Kaisha Toshiba Semiconductor memory device for storing multivalued data
KR100496866B1 (en) * 2002-12-05 2005-06-22 삼성전자주식회사 Flash memory device having uniform threshold voltage distribution without under-programed or over-programed flash cells and program verify method thereof
US7178004B2 (en) * 2003-01-31 2007-02-13 Yan Polansky Memory array programming circuit and a method for using the circuit
US6914823B2 (en) * 2003-07-29 2005-07-05 Sandisk Corporation Detecting over programmed memory after further programming
US7050346B2 (en) * 2003-07-29 2006-05-23 Kabushiki Kaisha Toshiba Non-volatile semiconductor memory device and electric device with the same
US7108226B2 (en) 2003-10-10 2006-09-19 The Boeing Company Interior seating architecture for aircraft
JP4041057B2 (en) * 2003-11-13 2008-01-30 株式会社東芝 Nonvolatile semiconductor memory device
US6965534B2 (en) * 2003-12-16 2005-11-15 Infineon Technologies Ag Random access memory using precharge timers in test mode
US6937511B2 (en) * 2004-01-27 2005-08-30 Macronix International Co., Ltd. Circuit and method for programming charge storage memory cells
JP4170952B2 (en) * 2004-01-30 2008-10-22 株式会社東芝 Semiconductor memory device
US7009887B1 (en) * 2004-06-03 2006-03-07 Fasl Llc Method of determining voltage compensation for flash memory devices
US6934190B1 (en) * 2004-06-09 2005-08-23 Advanced Micro Devices, Inc. Ramp source hot-hole programming for trap based non-volatile memory devices
EP2348710B1 (en) * 2004-07-01 2015-07-29 Mitsubishi Electric Corporation Random access video information recording method and apparatus
JP4113166B2 (en) * 2004-07-20 2008-07-09 株式会社東芝 Semiconductor memory device
US7106226B2 (en) * 2004-09-28 2006-09-12 Mediatek, Inc. Determination of key bit positions in gray codes
JP4713873B2 (en) * 2004-11-12 2011-06-29 株式会社東芝 Semiconductor memory device
JP4786171B2 (en) 2004-12-10 2011-10-05 株式会社東芝 Semiconductor memory device
JP4768298B2 (en) * 2005-03-28 2011-09-07 株式会社東芝 Nonvolatile semiconductor memory device
US7403424B2 (en) * 2005-03-31 2008-07-22 Sandisk Corporation Erasing non-volatile memory using individual verification and additional erasing of subsets of memory cells
US7486530B2 (en) * 2005-04-28 2009-02-03 Micron Technology, Inc. Method of comparison between cache and data register for non-volatile memory
KR100648286B1 (en) * 2005-07-04 2006-11-23 삼성전자주식회사 Flash memory device capable of performing multi-bit and single-bit program operations with a single page buffer structure
JP4846314B2 (en) * 2005-09-22 2011-12-28 株式会社東芝 Semiconductor memory device
US7813170B2 (en) * 2005-11-11 2010-10-12 Kabushiki Kaisha Toshiba Semiconductor memory device capable of memorizing multivalued data
US7286423B2 (en) * 2006-02-27 2007-10-23 Freescale Semiconductor, Inc. Bit line precharge in embedded memory
JP5142478B2 (en) * 2006-04-13 2013-02-13 株式会社東芝 Semiconductor memory device
JP4945187B2 (en) * 2006-07-31 2012-06-06 株式会社東芝 Semiconductor memory device
KR100771520B1 (en) * 2006-10-23 2007-10-30 삼성전자주식회사 Flash memory device and program method thereof
US8842076B2 (en) 2008-07-07 2014-09-23 Rockstar Consortium Us Lp Multi-touch touchscreen incorporating pen tracking
US7940546B2 (en) * 2009-01-30 2011-05-10 Arm Limited ROM array
KR101036720B1 (en) * 2009-02-02 2011-05-24 주식회사 하이닉스반도체 Method of operating a non volatile memory device
KR101015644B1 (en) * 2009-05-29 2011-02-22 주식회사 하이닉스반도체 Nonvolatile memory device and method of programing the same
US8295098B2 (en) * 2010-06-16 2012-10-23 Micron Technology, Inc. Local sensing in a memory device
KR101666941B1 (en) * 2010-07-06 2016-10-17 삼성전자주식회사 Non-volatile memory device, method of operating the same, and semiconductor system having the same
JP2012032238A (en) 2010-07-29 2012-02-16 Sakura Seiki Kk Producing method of tissue array
JP2012069186A (en) * 2010-09-22 2012-04-05 Toshiba Corp Nonvolatile semiconductor memory device
US8829135B2 (en) 2011-06-03 2014-09-09 Basf Se Process for continuously producing water-absorbing polymer particles
JP2013118028A (en) 2011-12-02 2013-06-13 Toshiba Corp Semiconductor memory device
JP2014157650A (en) 2013-02-18 2014-08-28 Toshiba Corp Semiconductor memory device

Cited By (34)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2007193911A (en) * 2006-01-20 2007-08-02 Toshiba Corp Semiconductor memory device
US7505312B2 (en) 2006-01-31 2009-03-17 Kabushiki Kaisha Toshiba Nonvolatile semiconductor memory device capable of controlling proximity effect due to coupling between adjacent charge storage layers
US7292474B2 (en) 2006-01-31 2007-11-06 Kabushiki Kaisha Toshiba Semiconductor integrated circuit device
JP2007335069A (en) * 2006-06-12 2007-12-27 Samsung Electronics Co Ltd Nonvolatile memory device and its operating method
JP2008065977A (en) * 2006-09-06 2008-03-21 Samsung Electronics Co Ltd Program method for multi-level non-volatile memory device
JP2008090993A (en) * 2006-09-29 2008-04-17 Hynix Semiconductor Inc Method for programming nand flash memory element
JP2008165967A (en) * 2006-12-28 2008-07-17 Samsung Electronics Co Ltd Memory cell programming method for reducing coupling effect
JP2008198337A (en) * 2007-01-17 2008-08-28 Toshiba Corp Semiconductor storage device
JP2008269773A (en) * 2007-04-24 2008-11-06 Hynix Semiconductor Inc Method of operating flash memory device, and control circuit therefor
JP2009004077A (en) * 2007-06-22 2009-01-08 Samsung Electronics Co Ltd Non-volatile memory device and method of operating the same
JP2009059453A (en) * 2007-09-03 2009-03-19 Toshiba Corp Nonvolatile semiconductor memory device and memory system
KR101160748B1 (en) 2007-09-03 2012-06-28 가부시끼가이샤 도시바 Nonvolatile semiconductor memory device and memory system
US7916547B2 (en) 2007-09-14 2011-03-29 Kabushiki Kaisha Toshiba Method for controlling a non-volatile semiconductor memory device
USRE48244E1 (en) 2007-09-14 2020-10-06 Toshiba Memory Corporation Non-volatile semiconductor memory device including application of different voltages to memory cells based on their proximity to a selected memory cell
USRE46749E1 (en) 2007-09-14 2018-03-06 Toshiba Memory Corporation Method for controlling a non-volatile semiconductor memory device
JP2009129479A (en) * 2007-11-20 2009-06-11 Toshiba Corp Method of controlling threshold in nonvolatile semiconductor memory device
JP2010040109A (en) * 2008-08-05 2010-02-18 Toshiba Corp Nonvolatile semiconductor memory device
US8054682B2 (en) 2008-09-23 2011-11-08 Samsung Electronics Co., Ltd. Non-volatile memory device and page buffer circuit thereof
US8456920B2 (en) 2010-04-09 2013-06-04 Kabushiki Kaisha Toshiba Semiconductor memory device capable of executing high-speed page copy
JP2011253608A (en) * 2010-05-31 2011-12-15 Samsung Electronics Co Ltd Nonvolatile memory device having dynamic verification mode selection and operating method, driving method, and programming method thereof, memory system, memory card, and solid-state driver
US9224483B2 (en) 2010-05-31 2015-12-29 Samsung Electronics Co., Ltd. Nonvolatile memory device, system and programming method with dynamic verification mode selection
JP2011150788A (en) * 2011-05-13 2011-08-04 Toshiba Corp Semiconductor memory
JP2012014827A (en) * 2011-09-12 2012-01-19 Toshiba Corp Semiconductor memory device
US8837213B2 (en) 2012-04-27 2014-09-16 Kabushiki Kaisha Toshiba Semiconductor memory device which stores multilevel data
JP2013232259A (en) * 2012-04-27 2013-11-14 Toshiba Corp Semiconductor memory device
JP2013254542A (en) * 2012-06-07 2013-12-19 Toshiba Corp Semiconductor memory
US9390800B2 (en) 2012-06-07 2016-07-12 Kabushiki Kaisha Toshiba Semiconductor memory and semiconductor memory control method
US9761307B2 (en) 2014-04-16 2017-09-12 Toshiba Memory Corporation Semiconductor memory device
US9953704B2 (en) 2014-04-16 2018-04-24 Toshiba Memory Corporation Semiconductor memory device
US10418096B2 (en) 2014-04-16 2019-09-17 Toshiba Memory Corporation Semiconductor memory device
US9349442B2 (en) 2014-04-16 2016-05-24 Kabushiki Kaisha Toshiba Semiconductor memory device
US10818348B2 (en) 2014-04-16 2020-10-27 Toshiba Memory Corporation Semiconductor memory device
US11074969B2 (en) 2014-04-16 2021-07-27 Toshiba Memory Corporation Semiconductor memory device
US11651817B2 (en) 2014-04-16 2023-05-16 Kioxia Corporation Semiconductor memory device

Also Published As

Publication number Publication date
US7245528B2 (en) 2007-07-17
US9142299B2 (en) 2015-09-22
US10878895B2 (en) 2020-12-29
US9858992B2 (en) 2018-01-02
US10431297B2 (en) 2019-10-01
US20190074057A1 (en) 2019-03-07
JP4170952B2 (en) 2008-10-22
US20210104274A1 (en) 2021-04-08
US20100214852A1 (en) 2010-08-26
US20160284396A1 (en) 2016-09-29
US20150348618A1 (en) 2015-12-03
US9627048B2 (en) 2017-04-18
US8542538B2 (en) 2013-09-24
US20180096723A1 (en) 2018-04-05
US20140029337A1 (en) 2014-01-30
KR100688369B1 (en) 2007-03-02
US7738302B2 (en) 2010-06-15
US20070253250A1 (en) 2007-11-01
US8385130B2 (en) 2013-02-26
US20130148424A1 (en) 2013-06-13
US7376009B2 (en) 2008-05-20
US10096358B2 (en) 2018-10-09
US11309019B2 (en) 2022-04-19
US20170178721A1 (en) 2017-06-22
US20190362781A1 (en) 2019-11-28
US9390802B2 (en) 2016-07-12
US20200251165A1 (en) 2020-08-06
US20050169057A1 (en) 2005-08-04
US20080219058A1 (en) 2008-09-11
US10699781B2 (en) 2020-06-30
US8154930B2 (en) 2012-04-10
US20120163091A1 (en) 2012-06-28
KR20050078193A (en) 2005-08-04

Similar Documents

Publication Publication Date Title
JP4170952B2 (en) Semiconductor memory device
US6657891B1 (en) Semiconductor memory device for storing multivalued data
US7016226B2 (en) Semiconductor memory device for storing multivalued data
US7295468B2 (en) Nonvolatile semiconductor memory device
JP4713873B2 (en) Semiconductor memory device
JP5284391B2 (en) Semiconductor memory device
JP4489084B2 (en) Nonvolatile semiconductor memory device

Legal Events

Date Code Title Description
A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20080131

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20080205

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20080407

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20080507

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20080707

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20080805

A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20080807

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20110815

Year of fee payment: 3

R151 Written notification of patent or utility model registration

Ref document number: 4170952

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R151

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20110815

Year of fee payment: 3

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20110815

Year of fee payment: 3

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20120815

Year of fee payment: 4

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20120815

Year of fee payment: 4

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20130815

Year of fee payment: 5

S111 Request for change of ownership or part of ownership

Free format text: JAPANESE INTERMEDIATE CODE: R313111

R350 Written notification of registration of transfer

Free format text: JAPANESE INTERMEDIATE CODE: R350

S111 Request for change of ownership or part of ownership

Free format text: JAPANESE INTERMEDIATE CODE: R313111

R350 Written notification of registration of transfer

Free format text: JAPANESE INTERMEDIATE CODE: R350