JP6117779B2 - メモリセルプログラミング装置およびメモリセルプログラミング方法 - Google Patents

メモリセルプログラミング装置およびメモリセルプログラミング方法 Download PDF

Info

Publication number
JP6117779B2
JP6117779B2 JP2014518988A JP2014518988A JP6117779B2 JP 6117779 B2 JP6117779 B2 JP 6117779B2 JP 2014518988 A JP2014518988 A JP 2014518988A JP 2014518988 A JP2014518988 A JP 2014518988A JP 6117779 B2 JP6117779 B2 JP 6117779B2
Authority
JP
Japan
Prior art keywords
page
data
page data
programmed
programming
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.)
Active
Application number
JP2014518988A
Other languages
English (en)
Other versions
JP2014518430A (ja
Inventor
河合 鉱一
鉱一 河合
作井 康司
康司 作井
エス. フィーリー,ピーター
エス. フィーリー,ピーター
Original Assignee
マイクロン テクノロジー, インク.
マイクロン テクノロジー, インク.
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
Application filed by マイクロン テクノロジー, インク., マイクロン テクノロジー, インク. filed Critical マイクロン テクノロジー, インク.
Publication of JP2014518430A publication Critical patent/JP2014518430A/ja
Application granted granted Critical
Publication of JP6117779B2 publication Critical patent/JP6117779B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • 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
    • 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
    • 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/3404Convergence or correction of memory cell threshold voltages; Repair or recovery of overerased or 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/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/34Determination of programming status, e.g. threshold voltage, overprogramming or underprogramming, retention
    • G11C16/3418Disturbance prevention or evaluation; Refreshing of disturbed memory data
    • G11C16/3427Circuits or methods to prevent or reduce disturbance of the state of a memory cell when neighbouring cells are read or written
    • 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

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Hardware Design (AREA)
  • Read Only Memory (AREA)
  • Non-Volatile Memory (AREA)

Description

本開示は、概して、メモリに関し、特に1つ以上の実施形態では、本開示は、メモリセルをプログラミングすることに関する。
メモリデバイスは、典型的には、コンピュータまたはその他の電子デバイスの内部回路、半導体回路、集積回路として用いられている。ランダムアクセスメモリ(RAM)、リードオンリーメモリ(ROM)、ダイナミックRAM(DRAM)、シンクロナスDRAM(SDRAM)、およびフラッシュメモリなど様々な種類のメモリがある。
フラッシュメモリデバイスは、幅広い範囲の電子的用途において、よく使用される非揮発メモリのソースへと発展している。フラッシュメモリデバイスは、典型的には、高メモリ密度、高信頼性、および低電力消費を可能にする1トランジスタメモリセルを使用する。セルの閾値電圧は、電荷蓄積構造(例えばフローティングゲートまたは電荷捕獲)のプログラミング、またはその他の物理現象(例えば位相変化または偏光)によって変化し、この変化が各セルのデータ状態を決定する。フラッシュメモリの通常の利用先には、パーソナルコンピュータ、パーソナルデジタルアシスタント(PDA)、デジタルカメラ、デジタルメディアプレーヤー、デジタルレコーダー、ゲーム、家電製品、車両、無線デバイス、携帯電話、およびリムーバブルメモリモジュールが含まれ、フラッシュメモリの利用先は拡大し続けている。
フラッシュメモリは、典型的には、NORフラッシュおよびNANDフラッシュとして知られている2つの基本アーキテクチャの1つを利用している。デバイスを読み取るのに用いられる論理からアーキテクチャが由来する。NORフラッシュアーキテクチャでは、メモリセルの論理列が、典型的にはビットラインと呼ばれるような1つのデータラインに結合された各メモリセルと並列に結合される。NANDフラッシュアーキテクチャでは、1列のメモリセルが、1つのビットラインに結合された列の第1のメモリセルとだけ直列に結合される。
電子システムの性能が向上し、その複雑さが増すにつれ、システム内にさらに追加されるメモリへの要求も高まっている。しかしながら、システムのコスト削減を引き続き進めていくためには、部品数を最小限に抑えなければならない。多重レベルセル(MLC)などの技術を用いて集積回路のメモリ密度を上げることによって、このコスト削減は達成できる。例えば、MLC NANDフラッシュメモリは、非常に費用効率に優れた非揮発メモリである。
多重レベルセルは、データ状態、例えば、ビットパターンをセルの特定の閾値電圧(Vt)範囲に割り当てることによって、従来のフラッシュセルのアナログ性質をうまく利用することができる。当該業界では、これらのデータ状態をしばしば「レベル」と称する。この技術は、セルに割り当てられる電圧範囲の数量とメモリセルの寿命動作中に割り当てられた電圧範囲の安定性に応じて、メモリセルの1つのセルにつき2つ以上のビットの情報の記憶を可能にする。
多くのフラッシュメモリでは、単一レベルセル(SLC)と多重レベルセル(MLC)メモリのいずれの場合でも、1つにはメモリ密度増加などによって電荷蓄積構造結合が増加している。アクセスライン(例えばワードラインと呼ばれるようなライン)間およびデータライン(例えばビットラインと呼ばれるようなライン)間で結合が行われる。メモリの隣接ページのワードライン間、例えば、偶数/奇数メモリページ間の結合問題は、メモリ内でプログラミングされるデータのビットパターンに応じる。プログラミングが原因でセルの閾値電圧が変化すると、閾値電圧の変化がさらに結合の影響を強めることもありうる。
上述の理由により、および本明細書を読んで理解することにより当業者に明白となるであろう他の理由により、当技術分野では、メモリ補償を改善する必要がある。
本開示の一実施形態による方法のフローチャートである。 図1の方法によってプログラミングされる単一レベルセルメモリに関する閾値電圧レベルのグラフである。 図1の方法によってプログラミングされる多重レベルセルメモリに関する閾値電圧レベルのグラフである。 本開示の別の実施形態による方法のフローチャートである。 図4の方法によってプログラミングされるメモリに関する閾値電圧レベルのグラフである。 本開示の別の実施形態による方法のフローチャートである。 本開示の一実施形態による電子システムの概略ブロック図である。
以下の本実施形態の詳細な説明において、その一部を形成し、例として、特定の実施形態が実施される態様で示される、添付の図面が参照される。これらの実施例を、当業者が本発明を実施することができるように十分詳細に説明する。また、他の実施形態を利用してもよく、本開示の範囲から逸脱せずに、処理上、電気的、または機械的な変更を行ってもよい。したがって、以下の詳細な説明は、制限的な意味で解釈されるべきではない。
メモリをプログラミングする方法100を図1に示す。方法100は、ブロック102で、第1のベリファイレベルを用いて第1のページデータをプログラミングすることと、ブロック104で、第1のページデータをプログラミングされる第2(例えば隣接する)ページデータと比較することと、ブロック106で、第1のページデータのサブセットをさらにプログラミングすることを決定すること、ブロック108で、第2のベリファイレベルを用いてサブセットをプログラミングすることとを含む。1つの実施形態において、ブロック104に示される比較することは、論理和関数で第1のページデータと第2のページデータの逆数を組み合わせることによって実行される。1つの実施形態において、論理和関数を用いて、サブセットは以下の通り決定される。
第2のページについてデータをプログラミングするセルが消去されたまま(例えば、論理1のまま)であるとき、第1のページについてデータをプログラミングする隣接セルへの結合影響に注目すべき点はないように思われる。このような状況で、第1のベリファイレベルにプログラミングされたセルは、より高い、(例えば、目標レベルに対応する)第2のベリファイレベルまで安全にプログラミングすることが可能である。第2のページについてデータをプログラミングするセルを(例えば、論理0まで)プログラミングする場合、そのプログラミング用電圧が第1のページについてデータをプログラミングする隣接セルに与える結合影響は顕著であるように思われる。このような状況で、第2のページデータをプログラミングすることによる結合がそのセルの閾値電圧を目標レベルに移行させることになるので、第1のベリファイレベルまでプログラミングされたセルをさらにプログラミングすることができないようにする。
図2は、プログラミング動作の例200を図示する。最初に、すべてのセルを消去するので、セルはいずれも消去閾値電圧から始まる。本例の目的のために、第1のページデータは「nQ202」と識別され、0(プログラム)と1(消去)の値で表され、このときデータnQは「0101010110」と表される。第2のページデータは「(n+1)Q204」と識別され、第1のページ同様、0(プログラム)と1(消去)の値で表され、このときデータ(n+1)Qは「1101101010」と表される。データ(n+1)Qの逆数(「(n+1)Q’206」とも称される)は「0010010101」である。
本例において、データnQは、閾値電圧レベル0(プログラム)(ベリファイ1)を用いてプログラミングされる。データnQとプログラミングされるセルのうち5つのセルがプログラミングされ、5つは消去されたままである。データ(n+1)Qは、判定され、反転され、論理和関数でデータnQと組み合わせられる。データ202とデータ206を論理和関数で組み合わせた結果がデータ208であり、このデータはアイテム208から20810について0111010111として表される。アイテム208、208、208、208、および20810は、第1のページデータnQ202に対応するプログラミングされたセル(以後「第1のページのプログラミングされたセル」と称する)についての論理和結果を示している。アイテム208、208、208、208、および208は、第1のページデータnQ202に対応する消去された(1)セル(以後「第1のページの消去されたセル」と称する)についての論理和結果を示している。電荷蓄積構造から電荷蓄積構造結合までのディスターブによって、それらのセルの閾値電圧値が消去閾値からずれるとは考えにくいので、0か1に関係なく、第1のページの消去されたセルに対応する結果は無視できる。第1のページのプログラミングされたセルに対応する1の結果は、第2のページの対応するセルも同様にプログラミングされることを示している。つまり、それらのセルに関連したディスターブがありうるということである。1つの実施例においては、これがきっかけとなり、第1のページの対応するセルをさらにプログラミングすることが抑制される。第1のページのプログラミングされたセルに対応する0の結果は、第2のページの対応するセルは消去されたままでいることを示している。つまり、それらのセルに関連したディスターブはまったくない、またはほとんどないということである。1つの実施例においては、これがきっかけとなり、第2の閾値電圧レベル(ベリファイ2)を用いて、結果208、208、208に対応する第1のページのセルがさらにプログラミングされる。プログラミングはそのまま第2のページのプログラミングに継続される。
図3は、プログラミング動作の別の例300を図示する。MLCメモリは、消去レベルが0であることだけでなく、図3に示されるようにレベル1、2、3として複数のプログラミングレベルを有しているという点で、SLCメモリと異なる。例300は、4つのレベルを記憶可能なメモリセルの値が2ビットの例である。1つの実施形態において、例のMLCのプログラミングは次のような順番で行われる。最初に第1の下ページn、続いて第2の(例えば隣接する)下ページn+1、第1の上ページn+2、そして第2の上ページn+3がプログラミングされる。
まず、すべてのセルを消去するので、セルはいずれも消去閾値電圧から始まる。本例の目的のために、第1のページをレベル0と1にプログラミングする場合、第1の下ページデータは「nQ302」と識別され、0(プログラム)と1(消去)の値で表され、このときデータnQは「0101010110」と表される。第2の上ページデータは「(n+3)Q304」と識別され、0(プログラム)と1(消去)の値で表され、このときデータ(n+3)Q304は「1101101010」と表される。データ(n+3)Qの逆数(「(n+3)Q’306」とも称される)は「0010010101」である。MLCをレベル2と3にプログラミングするために、さらにベリファイレベル1と1が用いられる。
本例で、第1のページはレベル0と1に次のようにしてプログラミングされる。データnQは、閾値電圧レベル0(プログラム)(ベリファイ1)を用いてプログラミングされる。データnQとプログラミングされるセルのうち5つのセルがプログラミングされ、5つは消去されたままである。データ(n+3)Qは、判定され、反転され、論理和関数でデータnQと組み合わせられる。データ302とデータ306を論理和関数で組み合わせた結果がデータ308であり、このデータはアイテム308から30810について0111010111として表される。アイテム308、308、308、308、および30810は、第1のページデータnQ302に対応するプログラミングされたセルについての論理和結果を示している。アイテム308、308、308、308、および308は、第1のページデータnQ302に対応する消去された(1)セルについての論理和結果を示している。それらのセルの結合からのディスターブによって、セルの閾値電圧値が消去閾値からずれるとは考えにくいので、0か1に関係なく、第1のページの消去されたセルに対応する結果は無視できる。第1のページのプログラミングされたセルに対応する1の結果は、レベル2と3のプログラミング中に、第2のページの対応するセルも同様にプログラミングされることを示している。つまり、それらのセルに関連したディスターブがありうるということである。1つの実施形態においては、これがきっかけとなり、第1のページの対応するセルをさらにプログラミングすることが抑制される。第1のページのプログラミングされたセルに対応する0の結果は、第2のページのレベル2と3へのプログラミング中に、第2のページの対応するセルはプログラミングされないことを示している。つまり、それらのセルに関連したディスターブはまったくない、またはほとんどないということである。1つの実施形態においては、これがきっかけとなり、308の結果である0から第2の閾値電圧レベル(ベリファイ2)を用いて、nQのセルがさらにプログラミングされる。
第1のページのレベル0と1へのプログラミングに続いて、上ページのプログラミングが行われる。本例の目的のために、第1のページをレベル2と3にプログラミングする場合、第1の上ページデータは「(n+2)Q352」と識別され、0(プログラム)と1(消去)の値で表され、このときデータ(n+2)Qは「0111010010」と表される。第2の上ページデータは「(n+3)Q354」と識別され、0(プログラム)と1(消去)の値で表され、このときデータ(n+3)Qは「1101101010」と表される。データ(n+3)Qの逆数(「(n+3)Q’356」とも称される)は「0010010101」である。
本例で、第1のページはレベル2と3に次のようにしてプログラミングされる。データ(n+2)Qは、閾値電圧レベル2または3(プログラム)(ベリファイ1またはベリファイ1)を用いてプログラミングされる。本例で、(n+2)Qは「0111010010」として表される。データ(n+2)Qとプログラミングされるセルのうち、5つのセルがレベル2と3のプログラミング中にプログラミングされ、5つはレベル2と3のプログラミング中にプログラミングされない。データ(n+3)Qは、判定され、反転され、論理和関数でデータ(n+2)Qと組み合わせられる。データ352とデータ356を論理和関数で組み合わせた結果がデータ358であり、このデータはアイテム358から35810について0111010111として表される。アイテム358、358、358、358、および35810は、レベル2と3のプログラミング中にプログラミングされた第1のページのセルについての論理和結果を示している。アイテム358、358、358、358、および358は、レベル2と3のプログラミング中にプログラミングされない第1のページのセルについての論理和結果を示している。それらのセルの結合からのディスターブによって、セルの閾値電圧値が現在の閾値からずれるとは考えにくいので、0か1に関係なく、レベル2と3のプログラミング中にプログラミングされない第1のページのセルに対応する結果は無視できる。レベル2と3のプログラミング中にプログラミングされた第1のページのセルに対応する1の結果は、レベル2と3のプログラミング中に、第2のページの対応するセルも同様にプログラミングされることを示している。つまり、それらのセルに関連したディスターブがありうるということである。1つの実施形態においては、これがきっかけとなり、第1のページの対応するセルをさらにプログラミングすることが抑制される。レベル2と3のプログラミング中に第1のページのプログラミングされたセルに対応する0の結果は、レベル2と3のプログラミング中に、第2のページの対応するセルはプログラミングされないことを示している。つまり、それらのセルに関連したディスターブはまったくない、またはほとんどないということである。1つの実施形態においては、これがきっかけとなり、2つの第2の閾値電圧レベル(ベリファイ2とベリファイ2)の1つを用いて、結果、358 、358 、358 に対応する第1のページのセルがさらにプログラミングされる。
さまざまな実施形態において、第1のページデータは、メモリの偶数ページデータであってよく、第2のページデータは、メモリの奇数ページデータであってよい。別の実施形態において、第1のページデータは、1つの行のセルまたは1つの行のセルの一部でプログラミングされるデータに対応していてよく、第2のページデータは、隣接する行のセルまたは隣接する行のセルの一部でプログラミングされるデータに対応していてよい。
論理和関数での組み合わせは、開示の範囲から逸脱せずに、様々な構成部材を用いて行えばよい。様々な実施形態において、論理和関数を専用ハードウェア回路として、またはコントローラ内部で実行できるが、これはあくまでも一例であり、発明を制限するものではない。論理和関数をどのように実行するかについての選択は、速度とダイスペースとの関係を考慮することによってなされる。
図1乃至3について説明した様々な実施形態は、ビットラインのディスターブに対処するビットライン動作とともに、シールドされたビットライン構造を用いて実行される。実施形態は、ワードラインのディスターブにも対処可能であり、他の実施形態では、開示の範囲から逸脱せずに、公知のビットラインのディスターブの対処方法と組み合わせてもよい。
図4は、別の実施形態にかかるMLCメモリのプログラミング方法400を示す。図5は、方法400に従ったプログラミングレベルのグラフ500を示す。方法400は、ブロック402で第1のページデータをプログラミングすることと、ブロック404で第2(例えば隣接する)ページデータが第1のページデータに与える結合影響を判定することと、ブロック406で判定した結合影響と閾値の比較に応じて、第1のページデータのプログラミングを調整することとを含む。1つの実施形態において、ブロック404に示される判定することとは、第2のページデータをロードして、ロードした第2のページデータをプログラミングした第1のページデータと比較することによって実行される。1つの実施形態において、調整することとは、上ページのプログラミング中にプログラミングされない第2のページデータの対応するセルに隣接する第1のページデータでプログラミングされるセルをプログラミングすることをさらに含む。
1つの実施形態において、結合影響を判定することは、第2のページデータでプログラミングされるセルはどのレベルまでプログラミングされるのかを判定することを含む。第2のページデータでプログラミングされるセルが、より高い閾値電圧レベル(例えば、図5に示されるように、MLCセル当たり2ビットの場合のレベル1またはレベル3)にプログラミングされるとき、結合によってセルをそれぞれのレベルにプログラミングすることに関連する閾値電圧のディスターブを引き起こす可能性があるので、第1のページデータでプログラミングされる対応するセルについて初期のプログラミングレベルは変化しない。第2のページデータでプログラミングされるセルが、より低い閾値電圧レベル(例えば、図5に示されるように、MLCセル当たり2ビットの場合のレベル0またはレベル2)にプログラミングされるとき、結合によってセルをそれぞれのレベルにプログラミングすることに関連する閾値電圧のディスターブを引き起こす可能性がないので、追加のプログラミング処理によって、第1のページのセルをより高い閾値電圧分布にプログラミングする。その後、奇数ページのプログラミングが行われる。この奇数ページのプログラミングによって、第2のページデータのセルをプログラミングすることに対応する第1のページのセルを、より高い閾値電圧レベルまで移行させ、その結果、第2のページをプログラミングした後、閾値電圧の分布はより狭まる。
図5は、方法400に従ってプログラミングする例500を図示する。第1のページデータをプログラミングした後、第1のページデータとプログラミングされたメモリセルの閾値電圧分布は、プログラミングレベルとしてレベル0、1、2、および3(LV0、LV1、LV2、およびLV3)を持つ502に示されている。第2のページデータをロードした後、第1のページデータとプログラミングされたセルの読み出しが行われ、504として示されるように、対応のセルが第2のページデータのプログラミング中レベル0またはレベル2にプログラミングされる、第1のページデータとプログラミングされるセルについてさらにプログラミングされる。分布504は、さらにプログラミングされることのないレベルについての分布を示し、分布504は、さらにプログラミングされるレベルについての分布を示している。対応のセルが第2のページデータのプログラミング中レベル1またはレベル3にプログラミングされる、第1のページデータとプログラミングされるセルについては、さらにプログラミングが行われることはない。第2のページデータをプログラミングした後に得られる、第2のページのプログラミングについての分布は506に示されている。第2のページのプログラミングではまた、分布504に結合影響を与え、508で示されるようなプログラミングされた第1のページデータを示す分布504最終分布まで移行する。
図6に示される別の実施形態では、メモリをプログラミングする別の方法600が示される。方法600は、ブロック602で偶数ページデータをプログラミングすることと、ブロック604で奇数ページデータをロードすることと、ブロック606で偶数ページデータを読み出すことと、ブロック608で奇数ページデータをプログラミングしたことが、偶数ページデータのプログラミングに与える結合影響を判定することと、ブロック610で結合影響が閾値より少ないと判定されたことに応じて、偶数ページデータをさらにプログラミングすることと、およびブロック612で奇数ページデータをプログラミングすることを含む。1つの実施形態において、判定することは、偶数ページデータとプログラミングされるセルと奇数ページデータとプログラミングされる対応するセルとの間で閾値電圧の移動量を判定することを含む。
図7は、開示の1つの実施形態に係るメモリデバイス701の簡略ブロック図であり、メモリデバイス701で開示の様々な実施形態が実行される。メモリデバイス701は、行と列に配列されたメモリセルアレイ704を備える。主にNANDメモリアレイを参照しながら様々な実施形態を説明するが、その様々な実施形態はメモリセルアレイ704の特定のアーキテクチャに限定されるものではない。本実施形態に好適なその他のアーキテクチャの例としては、NORアレイ、ANDアレイ、仮想接地アレイなどがある。しかしながら通常、ここに記載の実施形態は例えば、各メモリセルの閾値電圧を示すデータ信号を生成できるようなアレイアーキテクチャであればいずれも適応可能である。さらに、ここに記載の実施形態は、開示の範囲を逸脱することなく、SLCおよびMLCメモリで用いることができる。
行デコーダ回路708および列デコーダ回路710は、メモリデバイス701に与えられるアドレス信号をデコードするために設けられる。アドレス信号は、メモリアレイ704にアクセスするために受け取られ、デコードされる。また、メモリデバイス701は、コマンド、アドレス、およびデータのメモリデバイス701への入力、ならびにデータおよび状況情報のメモリデバイス701からの出力を管理するための入出力(I/O)制御回路712を備える。アドレスレジスタ714は、I/O制御回路712と行デコーダ回路708および列デコーダ回路710の間に接続され、デコードの前にアドレス信号をラッチする。コマンドレジスタ724は、I/O制御回路712と制御ロジック716との間に接続され、入力されるコマンドをラッチする。1つの実施形態において、制御ロジック716、制御回路712、および/またはファームウェアが個々に、組み合わせられて、またはその他の構成要素と組み合わせられてコントローラを形成する。しかし、ここで用いられている通り、コントローラは必ずしもこのような構成部材のいずれかをまたはすべてを含む必要はない。いくつかの実施形態において、コントローラは、(例えば、メモリアレイと同一のダイに配置される)内部コントローラおよび/または外部コントローラとを備えることができる。制御ロジック716は、コマンドに応じてメモリアレイ704へのアクセスを制御し、外部プロセッサ730用に状態情報を生成する。制御ロジック716は、行デコーダ回路708と列デコーダ回路710に接続され、アドレスに応じて行デコーダ回路708と列デコーダ回路710を制御する。
制御ロジック716は、サンプルホールド回路718に接続してもよい。サンプルホールド回路718は、アナログデータ信号の形式で入力または出力データをラッチする。例えば、サンプルホールド回路は、1つのメモリセルに書き込まれるデータを表す入力データ信号か、1つのメモリセルから検出された閾値電圧を示す出力データ信号のいずれかをサンプリングするためのコンデンサまたはその他のアナログストレージデバイスを備えるようにしてもよい。さらに、サンプルホールド回路718は、より強いデータ信号を外部デバイスに与えるためにサンプリングされた信号を増幅および/またはバッファリングするための要素を備えていてもよい。
アナログデータ信号の処理では、CMOS撮像装置技術の分野で公知のアプローチに類似したアプローチをとってもよい。CMOS撮像装置技術では、入射照明に応じて撮像装置の画素で生成される電荷レベルがコンデンサに蓄えられる。その後、電荷レベルは、基準コンデンサを備えた差動増幅器を用いて信号に変換され、第2の入力として差動増幅器に入力される。さらに、作動増幅器の出力は、アナログ・デジタルコンバータ(ADC)に送られ、照明の強度を表すデジタル値が得られる。本実施形態において、メモリセルの読み出しまたはプログラミングのために、メモリセルの実際のまたは目標閾値電圧を示すデータ信号に応じて、電荷がコンデンサに蓄えられる。その後、この電荷は接地入力またはその他基準信号を第2の入力とする作動増幅器を用いてアナログデータ信号に変換される。さらに、作動増幅器の出力は、読み出し動作、またはメモリデバイスのプログラミングにおける1回以上のベリファイ動作中の比較のために用いられる場合、I/O制御回路712に送られ、メモリデバイスから出力されるようにしてもよい。なお、I/O制御回路712は、メモリデバイス701がアナログまたはデジタルデータインターフェースとの通信に適応可能になるように、オプションとして、アナログ・デジタル変換機能とデジタル・アナログ変換(DAC)機能を備えて、アナログデータ信号からの読み出しデータをデジタルビットパターンに変換して、デジタルビットパターンからの書込みデータをアナログ信号に変換するようにしてもよい。
プログラミング動作中、メモリアレイ704の対象メモリセルを、その閾値電圧レベルを示す電圧がサンプルホールド回路718に保持されたレベルと一致するまでプログラミングしてもよい。このプログラミングをするには、例えば、差動検出デバイスを用いて、保持された電圧レベルを対象メモリセルの閾値電圧と比較すればよい。従来のメモリプログラミングに非常に類似しているが、プログラミングパルスを対象メモリセルに与えて、所望の値に達するか上回るまで閾値電圧を増加させるようにしてもよい。読み出し動作では、対象メモリセルの閾値電圧レベルがサンプルホールド回路718に与えられ、ADC/DAC機能がメモリデバイスの外部または内部に設けられているかに応じて、直接アナログ信号として、またはアナログ信号のデジタル化表現として(図7に図示されない)外部プロセッサに転送される。
セルの閾値電圧はさまざまな様式で決定すればよい。例えば、典型的には、ワードラインと称されているようなアクセスラインで、対象メモリセルが活性化される時点で電圧をサンプリングする。あるいは、増加電圧を対象メモリセルの第1のソース/ドレイン側に印加して、閾値電圧を、制御ゲート電圧と他方のソース/ドレイン側の電圧間の差異としてみなすことができる。電圧をコンデンサに接続することにより、電荷がサンプリングした電圧を蓄えるためのコンデンサと共有されるだろう。サンプリングした電圧は閾値電圧と等しくする必要はなく、その電圧を示すものであればよい。例えば、増加電圧をメモリセルの第1のソース/ドレイン側に印加して、公知の電圧を制御ゲートに印加する場合、メモリセルの第2のソース/ドレイン側で生じる電圧はメモリセルの閾値電圧を示すものとなるので、メモリセルの第2のソース/ドレイン側で生じる電圧をデータ信号とみなすことができる。
サンプルホールド回路718は、各データ値についてキャッシング、すなわち複数の保存場所を含み、メモリデバイス701が、第1のデータ値を外部プロセッサに送っている間に次のデータ値を読む、または第1のデータ値をメモリアレイ704に書込みしている間に次のデータ値を受け取るようにしてもよい。状態レジスタ722が、I/O制御回路712と制御ロジック716の間に接続されて、外部プロセッサに出力するための状態情報をラッチする。
メモリデバイス701は、制御リンク732を介して制御ロジック716で制御信号を受け取る。制御信号には、チップイネーブルCE#と、コマンドラッチイネーブルCLEと、アドレスラッチイネーブルALEと、ライトイネーブルWE#を含まれればよい。メモリデバイス701は、(コマンド信号の形式の)コマンドと、(アドレス信号の形式の)アドレスと、(データ信号の形式の)データを、多重入出力(I/O)バス734を介して外部プロセッサから受け取り、データをI/Oバス734を介して外部プロセッサに出力すればよい。
特定の例では、I/Oバス734の入出力(I/O)ピン[7:0]を介して、I/O制御回路712でコマンドを受け取り、そのコマンドをコマンドレジスタ724内に書き込む。I/Oバス734の入出力(I/O)ピン[7:0]を介して、I/O制御回路712でアドレスを受け取り、そのアドレスをアドレスレジスタ714内に書き込む。8つの並列信号を受け取れるようなデバイス用の入出力(I/O)ピン[7:0]を介して、または16の並列信号を受け取れるようなデバイス用の入出力(I/O)ピン[15:0]を介して、I/O制御回路712でデータを受け取り、そのデータをサンプルホールド回路718に転送する。また、8つの並列信号を送信できるようなデバイス用の入出力(I/O)ピン[7:0]を介して、または16の並列信号を送信できるようなデバイス用の入出力(I/O)ピン[15:0]を介して、データを出力することもできる。その他の回路および信号を追加することができること、および図7のメモリデバイスを開示の実施形態に焦点を当てるのに与するように単純化されていることは当業者であれば理解されるであろう。
結合を減らし、メモリをプログラミングするための方法は、メモリ700などのメモリ上で、様々な実施形態で実行可能である。そうした方法は、図1乃至6を参照してここで示され、説明されている。
図7を、サンプルホールド回路718について説明してきたが、開示の範囲を逸脱せず、サンプルホールド回路718に代えて制御ロジック716をデータラッチに接続させ得ることも理解されるであろう。データは、入力または出力のいずれの場合のラッチデータもラッチする。書き込み動作時、メモリアレイ704の対象メモリセルは、例えば上記のプログラミングパルスを2組用いて、閾値電圧レベルを示す電圧がデータラッチに保持されたデータと一致するまでプログラミングされる。一例として、これは、差動検出デバイスを用いて、保持データを対象メモリセルの閾値電圧と比較することによって実行することができる。
さらに、図7のメモリデバイスを種々の信号を受け取り、出力するための従来から公知の技術に従って説明してきたが、記載した特定の信号およびI/O構成によって、種々の実施形態が制限されることはないことに注意されたい。例えば、コマンドおよびアドレス信号は、データ信号を受け取るものとは別の入力で受け取られることもできるであろうし、あるいはデータ信号が、I/Oバス734の単一I/Oライン上で、シリアル方式で送信されてもよいだろう。データ信号は個々のビットではなくビットパターンを表すため、8ビットのデータ信号のシリアル通信が、個々のビットを表す8信号のパラレル通信同様効率的であるかもしれない。
本明細書において特定の実施形態が示され、記載されているが、同じ目的を実現するように考慮されている構成を、示された特定の実施形態に置き換えてもよいことが、当業者に理解されるであろう。本発明の多くの応用例が当業者に明らかであろう。したがって、本出願は、本開示のいかなる応用例または変形例も網羅することを意図するものである。

Claims (6)

  1. メモリセルをプログラミングする方法であって、
    第1のベリファイレベルを用いて第1のページデータを第1のページにプログラミングすることと、
    前記第1のページの中で更にプログラミングすべきサブセットを決定し、当該サブセットに対する更なるプログラミングを第2のベリファイレベルを用いて行うことと、
    を含み、
    前記サブセットを決定することは、
    前記第1のページと物理的に隣接する第2のページにプログラミングされる第2のページデータの逆数を求めることと、
    理和関数において、前記第1のページデータを前記第2のページデータの前記逆数と組み合わせること
    当該組み合わせ結果に基づき前記サブセットを特定することと、
    有する、方法。
  2. 前記第1のページの中でさらにプログラミングすべきサブセットとして決定されたメモリセルは、前記第1のベリファイレベルを用いてプログラムされたメモリセルであって前記第2のページデータが消去したままと指定する第2のページの中のメモリセルと物理的に隣接しているメモリセルである、請求項1に記載の方法。
  3. 前記第のベリファイレベルは、前記第のベリファイレベルよりも高い、請求項1または2に記載の方法。
  4. 多重レベルセルとしてのメモリセルに、下ページデータおよび上ページデータを有するページデータをプログラミングする方法であって、
    第1のベリファイレベルを用いて第1のページデータの前記下ページデータを第1のページにプログラミングすることと、
    前記第1のページデータの前記下ページデータがプログラミングされた前記第1のページの中で更にプログラミングすべき第1のサブセットを決定し、当該第1のサブセットに対する第1の更なるプログラミングを第2のベリファイレベルを用いて行うことと、
    しかる後、第3および第4のベリファイレベルを用いて前記第1のページデータの前記上ページデータを前記第1のページにプログラミングすることと、
    前記第1のページデータの前記上ページデータがプログラミングされた前記第1のページの中で更にプログラミングすべき第2のサブセットを決定し、当該第2のサブセットに対する第2の更なるプログラミングを第5および第6のベリファイレベルを用いて行うことと、
    を含み、
    前記第1のサブセットを決定することは、
    前記第1のページと物理的に隣接する第2のページにプログラミングされる第2のページデータの逆数を求めることと、
    論理和関数において、前記第1のページデータの前記下ページデータを前記第2のページデータの前記逆数と組み合わせることと、
    当該組み合わせ結果に基づき前記第1のサブセットを特定することと、
    を有し、
    前記第2のサブセットを決定することは、
    前記第2のページデータの逆数を求めることと、
    論理和関数において、前記第1のページデータの前記上ページデータを前記第2のページデータの前記逆数と組み合わせることと、
    当該組み合わせ結果に基づき前記第2のサブセットを特定することと、
    有する、方法。
  5. 複数の物理ページに配置されるメモリセルのアレイと、
    請求項1に記載の方法を実行するように構成される、コントローラと、
    を備える、 デバイス。
  6. 複数の物理ページに配置される、メモリセルのアレイと、
    請求項4に記載の方法を実行するように構成される、コントローラと、
    備える、デバイス。
JP2014518988A 2011-07-07 2012-06-28 メモリセルプログラミング装置およびメモリセルプログラミング方法 Active JP6117779B2 (ja)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US13/178,217 US8537623B2 (en) 2011-07-07 2011-07-07 Devices and methods of programming memory cells
US13/178,217 2011-07-07
PCT/US2012/044522 WO2013006355A2 (en) 2011-07-07 2012-06-28 Devices and methods of programming memory cells

Publications (2)

Publication Number Publication Date
JP2014518430A JP2014518430A (ja) 2014-07-28
JP6117779B2 true JP6117779B2 (ja) 2017-04-19

Family

ID=47437633

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2014518988A Active JP6117779B2 (ja) 2011-07-07 2012-06-28 メモリセルプログラミング装置およびメモリセルプログラミング方法

Country Status (6)

Country Link
US (2) US8537623B2 (ja)
EP (1) EP2729935A4 (ja)
JP (1) JP6117779B2 (ja)
KR (1) KR101634884B1 (ja)
CN (1) CN103718247B (ja)
WO (1) WO2013006355A2 (ja)

Families Citing this family (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2013122799A (ja) * 2011-12-09 2013-06-20 Toshiba Corp 不揮発性半導体記憶装置
JP6457364B2 (ja) 2015-09-11 2019-01-23 東芝メモリ株式会社 メモリシステム
US9666282B1 (en) * 2016-05-03 2017-05-30 Micron Technology, Inc. Program inhibiting in memory devices
US9589659B1 (en) 2016-05-25 2017-03-07 Micron Technology, Inc. Pre-compensation of memory threshold voltage
EP3427644B1 (en) 2017-07-14 2022-12-28 Asahi Kasei Kabushiki Kaisha Concentration measuring module, dialyzer, and concentration calculating method
US10607693B2 (en) * 2018-06-29 2020-03-31 Micron Technology, Inc. Misplacement mitigation algorithm
US11972812B2 (en) * 2021-12-13 2024-04-30 Sandisk Technologies Llc Non-volatile memory with data refresh based on data states of adjacent memory cells

Family Cites Families (32)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP4023953B2 (ja) * 1999-06-22 2007-12-19 株式会社ルネサステクノロジ 不揮発性半導体記憶装置
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
JP3935139B2 (ja) * 2002-11-29 2007-06-20 株式会社東芝 半導体記憶装置
JP4005000B2 (ja) * 2003-07-04 2007-11-07 株式会社東芝 半導体記憶装置及びデータ書き込み方法。
US6996004B1 (en) 2003-11-04 2006-02-07 Advanced Micro Devices, Inc. Minimization of FG-FG coupling in flash memory
US6888758B1 (en) 2004-01-21 2005-05-03 Sandisk Corporation Programming non-volatile memory
JP4410188B2 (ja) * 2004-11-12 2010-02-03 株式会社東芝 半導体記憶装置のデータ書き込み方法
US7221592B2 (en) * 2005-02-25 2007-05-22 Micron Technology, Inc. Multiple level programming in a non-volatile memory device
JP4157563B2 (ja) 2006-01-31 2008-10-01 株式会社東芝 半導体集積回路装置
US7400532B2 (en) 2006-02-16 2008-07-15 Micron Technology, Inc. Programming method to reduce gate coupling interference for non-volatile memory
KR100763353B1 (ko) * 2006-04-26 2007-10-04 삼성전자주식회사 인접하는 메모리셀과의 커플링 노이즈를 저감시키는불휘발성 반도체 메모리 장치
US7952922B2 (en) * 2006-06-06 2011-05-31 Micron Technology, Inc. Method for programming a non-volatile memory device to reduce floating-gate-to-floating-gate coupling effect
KR101073116B1 (ko) 2006-07-20 2011-10-13 샌디스크 코포레이션 커플링을 사용하는 이웃 감지에 기반한 커플링 보상
US7400535B2 (en) 2006-07-20 2008-07-15 Sandisk Corporation System that compensates for coupling during programming
US7894269B2 (en) 2006-07-20 2011-02-22 Sandisk Corporation Nonvolatile memory and method for compensating during programming for perturbing charges of neighboring cells
JP4940300B2 (ja) * 2006-07-20 2012-05-30 サンディスク コーポレイション プログラミング中における結合の補償
KR100805840B1 (ko) 2006-09-01 2008-02-21 삼성전자주식회사 캐시를 이용한 플래시 메모리 장치 및 그것의 프로그램방법
US7486566B2 (en) * 2006-12-28 2009-02-03 Intel Corporation Methods, apparatus, and systems for flash memory bit line charging
JP4869088B2 (ja) * 2007-01-22 2012-02-01 株式会社東芝 半導体記憶装置及びその書き込み方法
US7599224B2 (en) 2007-07-03 2009-10-06 Sandisk Corporation Systems for coarse/fine program verification in non-volatile memory using different reference levels for improved sensing
KR101378349B1 (ko) * 2008-01-30 2014-03-28 삼성전자주식회사 메모리 장치 및 메모리 데이터 읽기 방법
KR100953045B1 (ko) * 2008-05-23 2010-04-14 주식회사 하이닉스반도체 불휘발성 메모리 장치의 프로그램 방법
US7746691B2 (en) * 2008-06-10 2010-06-29 Micron Technology, Inc. Methods and apparatus utilizing predicted coupling effect in the programming of non-volatile memory
US7848144B2 (en) * 2008-06-16 2010-12-07 Sandisk Corporation Reverse order page writing in flash memories
KR101436506B1 (ko) * 2008-07-23 2014-09-02 삼성전자주식회사 메모리 장치 및 메모리 데이터 프로그래밍 방법
US8482976B2 (en) * 2008-12-09 2013-07-09 Kabushiki Kaisha Toshiba Semiconductor memory device and semiconductor memory system storing multilevel data
JP2010165400A (ja) * 2009-01-14 2010-07-29 Toshiba Corp 不揮発性半導体記憶装置及びそのシステム
KR101534274B1 (ko) 2009-02-25 2015-07-06 삼성전자주식회사 메모리 시스템 및 그것의 프로그램 방법
KR101600539B1 (ko) * 2009-04-07 2016-03-08 삼성전자주식회사 불휘발성 메모리 장치의 프로그램 방법
US7898864B2 (en) 2009-06-24 2011-03-01 Sandisk Corporation Read operation for memory with compensation for coupling based on write-erase cycles
US8130543B2 (en) * 2009-08-13 2012-03-06 Macronix International Co., Ltd. Method and apparatus for increasing memory programming efficiency through dynamic switching of sense amplifiers
KR101099911B1 (ko) * 2009-12-17 2011-12-28 주식회사 하이닉스반도체 반도체 메모리 장치 및 그 동작 방법

Also Published As

Publication number Publication date
EP2729935A4 (en) 2015-04-08
WO2013006355A3 (en) 2013-04-04
US9312023B2 (en) 2016-04-12
KR101634884B1 (ko) 2016-06-29
US20130010537A1 (en) 2013-01-10
EP2729935A2 (en) 2014-05-14
CN103718247A (zh) 2014-04-09
US20140016411A1 (en) 2014-01-16
CN103718247B (zh) 2017-03-08
KR20140033224A (ko) 2014-03-17
US8537623B2 (en) 2013-09-17
WO2013006355A2 (en) 2013-01-10
JP2014518430A (ja) 2014-07-28

Similar Documents

Publication Publication Date Title
US11948644B2 (en) Two-part programming of memory cells
JP5483204B2 (ja) Mlcnandにおける不均等閾値電圧範囲
US8233329B2 (en) Architecture and method for memory programming
JP6117779B2 (ja) メモリセルプログラミング装置およびメモリセルプログラミング方法
US9484101B2 (en) Methods of programming memories
JP2010530112A (ja) ソリッドステートメモリ内での粗密プログラミング
US9177651B2 (en) Programming methods and memories
US20090129152A1 (en) Program and read method for mlc

Legal Events

Date Code Title Description
A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20140227

Free format text: JAPANESE INTERMEDIATE CODE: A821

Effective date: 20140106

Free format text: JAPANESE INTERMEDIATE CODE: A821

Effective date: 20140227

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20140227

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20141107

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20141118

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20150202

Free format text: JAPANESE INTERMEDIATE CODE: A821

Effective date: 20150202

A02 Decision of refusal

Free format text: JAPANESE INTERMEDIATE CODE: A02

Effective date: 20150811

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A821

Effective date: 20151207

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20151207

A911 Transfer to examiner for re-examination before appeal (zenchi)

Free format text: JAPANESE INTERMEDIATE CODE: A911

Effective date: 20151214

A912 Re-examination (zenchi) completed and case transferred to appeal board

Free format text: JAPANESE INTERMEDIATE CODE: A912

Effective date: 20160304

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A821

Effective date: 20160719

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20161228

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20170323

R150 Certificate of patent or registration of utility model

Ref document number: 6117779

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250