JP4758648B2 - 不揮発性記憶システムにおける平均消去カウントの維持 - Google Patents

不揮発性記憶システムにおける平均消去カウントの維持 Download PDF

Info

Publication number
JP4758648B2
JP4758648B2 JP2004548310A JP2004548310A JP4758648B2 JP 4758648 B2 JP4758648 B2 JP 4758648B2 JP 2004548310 A JP2004548310 A JP 2004548310A JP 2004548310 A JP2004548310 A JP 2004548310A JP 4758648 B2 JP4758648 B2 JP 4758648B2
Authority
JP
Japan
Prior art keywords
block
erase count
blocks
erase
erased
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.)
Expired - Lifetime
Application number
JP2004548310A
Other languages
English (en)
Other versions
JP2006504220A (ja
Inventor
チャン,ロバート
クゥワミ,バーマン
サベット−シャーギー,ファーシッド
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.)
SanDisk Corp
Original Assignee
SanDisk 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
Application filed by SanDisk Corp filed Critical SanDisk Corp
Publication of JP2006504220A publication Critical patent/JP2006504220A/ja
Application granted granted Critical
Publication of JP4758648B2 publication Critical patent/JP4758648B2/ja
Anticipated expiration legal-status Critical
Expired - Lifetime legal-status Critical Current

Links

Images

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
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/0223User address space allocation, e.g. contiguous or non contiguous base addressing
    • G06F12/023Free address space management
    • G06F12/0238Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory
    • G06F12/0246Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory in block erasable memory, e.g. flash memory
    • 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/349Arrangements for evaluating degradation, retention or wearout, e.g. by counting erase cycles
    • 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/349Arrangements for evaluating degradation, retention or wearout, e.g. by counting erase cycles
    • G11C16/3495Circuits or methods to detect or delay wearout of nonvolatile EPROM or EEPROM memory devices, e.g. by counting numbers of erase or reprogram cycles, by using multiple memory areas serially or cyclically
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/72Details relating to flash memory management
    • G06F2212/7211Wear leveling

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Techniques For Improving Reliability Of Storages (AREA)
  • Read Only Memory (AREA)
  • Agricultural Chemicals And Associated Chemicals (AREA)
  • Memory System Of A Hierarchy Structure (AREA)
  • Tires In General (AREA)

Description

本発明は、一般に、大量デジタルデータ記憶システムに関する。より具体的には、本発明は、不揮発性記憶システムの記憶領域に関連付けられた摩耗がほぼすべての記憶領域にわたって拡散されることを可能にするために使用される消去カウントを維持することを効率的に可能にするシステムおよび方法に関する。
本発明は、同時係属米国特許出願_(弁理士整理番号SANDP005/SDK0278.000US)、名称「AUTOMATED WEAR LEVELING IN NON−VOLATILE STORAGE SYSTEMS」、同時係属米国特許出願10/281739(弁理士整理番号SANDP023/SDK0366.000US)、名称「WEAR=LEVELING IN NON−VOLATILE STORAGE SYSTEMS」、2002年10月28日出願、同時係属米国特許出願10/281670(弁理士整理番号SANDP025/SDK0366.002US)、名称「TRACKING THE MOST FREQUENTLY ERASED BLOCKS IN NON−VOLATILE MEMORY SYSTEMS」、2002年10月28日出願、同時係属米国特許出願10/281824(弁理士整理番号SANDP026/SDK0366.003)、名称「TRACKING THE LEAST FREQUENTLY ERASED BLOCKS IN NON−VOLATILE MEMORY SYSTEMS」、2002年10月28日出願、同時係属米国特許出願10/281631(弁理士整理番号SANDP028/SDK0371.000US)、名称「METHOD AND APPARATUS FOR SPLITTING A LOGICAL BLOCK」、2002年10月28日出願、同時係属米国特許出願10/281855(弁理士整理番号SANDP029/SDK0410.000US)、名称「METHOD AND APPARATUS FOR GROUPING PAGES WITHIN A BLOCK」、2002年10月28日出願、同時係属米国特許出願10/281762(弁理士整理番号SANDP030/SDK0416.000US)、名称「METHOD AND APPARATUS FOR RESOLVING PHYSICAL BLOCKS ASSOCIATED WITH A COMMON LOGICAL BLOCK」、2002年10月28日出願、同時係属米国特許出願10/281696(弁理士整理番号SANDP031/SDK0420.000US)、名称「MAINTAINING ERASE COUNTS IN NON−VOLATILE STORAGE SYSTEMS」、2002年10月28日出願、同時係属米国特許出願10/281626(弁理士整理番号SANDP032/SDK0420.001US)、名称「METHOD AND APPARATUS FOR MANAGING AN ERASE COUNT BLOCK」、2002年10月28日出願、同時係属米国特許出願10/281804(弁理士整理番号SANDP033/SDK0426.000US)、名称「METHOD AND APPARATUS FOR PERFORMING MULTI−PAGE READ AND WRITE OPERATIONS IN A NON−VOLATILE MEMORY SYSTEM」、2002年10月28日出願、米国特許第6081447号、および米国特許第6230233号に関する。これらは、それぞれ、参照によって本明細書に完全に組み込まれる。
フラッシュメモリ記憶システムなどの不揮発性メモリの使用は、そのようなメモリシステムのコンパクトな物理的サイズ、および不揮発性メモリが反復して再プログラムされる能力のために増大している。フラッシュメモリ記憶システムのコンパクトな物理的サイズにより、ますます普及している装置においてそのような記憶システムを使用することが促進される。フラッシュメモリ記憶システムを使用する装置には、デジタルカメラ、デジタルカムコーダ、デジタル音楽プレーヤ、手持ち式パーソナルコンピュータ、および大域的位置決め装置があるが、これに限定されるものではない。フラッシュメモリ記憶システムに含まれる不揮発性メモリを反復して再プログラムする能力により、フラッシュメモリ記憶システムが使用および再使用されることが可能になる。
一般に、フラッシュメモリ記憶システムは、フラッシュ・メモリ・カードおよびフラッシュ・メモリ・チップ・セットを含むことが可能である。フラッシュ・メモリ・チップ・セットは、一般に、フラッシュメモリ構成要素および制御装置構成要素を含む。通常、フラッシュ・メモリ・チップ・セットは、埋込みシステムに組み立てられるように構成されることが可能である。そのようなアセンブリまたはホストシステムの製造業者は、通常、構成要素形態のフラッシュメモリ、ならびに他の構成要素を獲得し、次いでフラッシュメモリおよび他の構成要素をホストシステムに組み立てる。
不揮発性メモリ、またはより具体的にはフラッシュ・メモリ・システム内のフラッシュ・メモリ・ブロックは、反復してプログラムおよび消去されることが可能であるが、各ブロックまたは物理的位置は、ブロックが摩耗する前に、すなわち、メモリがより小さくなり始める前に、ある回数のみ消去されることが可能である。すなわち、各ブロックは、プログラムおよび消去サイクルの制限を有する。いくつかのメモリでは、ブロックが使用不能と見なされる前に、約1万回、ブロックが消去されることが可能である。他のメモリでは、ブロックが摩耗されたと見なされる前に、約数10万回またはさらには最高で100万回、ブロックが消去されることが可能である。ブロックが摩耗して、それにより、フラッシュ・メモリ・システムの全記憶ボリュームの一部に対し使用の損失または性能の著しい低下が生じるとき、フラッシュ・メモリ・システムのユーザは、たとえば記憶データを損失する、またはデータを記憶することができないなど、悪影響を受ける可能性がある。
フラッシュ・メモリ・システム内におけるブロックまたは物理的位置に関する摩耗は、ブロックのそれぞれがどの程度プログラムされるかに応じて変化する。ブロック、またはより一般的には記憶要素が、1度プログラムされ、次いで事実上決して再プログラムされない場合、プログラムおよび消去サイクルの数、したがってブロックに関連付けられる摩耗は、一般に比較的小さい。ブロックが、循環されるなど、反復して書き込まれ、かつ消去される場合、ブロックに関連付けられる摩耗は、一般に比較的大きい。論理ブロックアドレス(LBA)が、フラッシュ・メモリ・システムに記憶されているデータにアクセスするために、フラッシュ・メモリ・システムにアクセスする、またはそれを使用するシステムなど、ホストによって使用される際に、ホストがデータを書き込み、かつ上書きするために同じLBAを反復して使用する場合、当業者なら理解するように、フラッシュ・メモリ・システム内の同じ物理的位置またはブロックは、反復して書き込まれ、かつ消去される。
いくつかのブロックが、他のブロックが比較的摩耗していない間に事実上摩耗される場合、摩耗ブロックの存在は、一般に、フラッシュ・メモリ・システムの全性能を損なう。摩耗ブロック自体に関連する性能の低下に加えて、フラッシュ・メモリ・システムの全性能は、摩耗されていない不十分な数のブロックが所望のデータを記憶するために利用可能であるとき、損なわれる可能性がある。しばしば、フラッシュ・メモリ・システムは、限界数の摩耗ブロックがフラッシュ・メモリ・システムに存在するとき、フラッシュ・メモリ・システムの多くの他のセルが比較的摩耗していないときでも、使用不能であると見なされる可能性がある。相当数の比較的摩耗していないブロックを含むフラッシュ・メモリ・システムが、使用不能であると見なされるとき、そのフラッシュ・メモリ・システムに関連付けられる多くのリソースは、事実上浪費される。
フラッシュ・メモリ・システム内のブロックが比較的一様(
即ち、均一)に摩耗される可能性を増大させるために、摩耗一様化動作が、しばしば実施される。摩耗一様化動作は、当業者なら理解するように、一般に、特定のLBAに関連付けられた物理的位置またはブロックが、同じLBAが同じ物理的位置またはブロックに常に関連付けられるとは限らないように、変更されることが可能であるように構成される。LBAのブロック関連付けを変化させることによって、他のブロックが摩耗する前かなり前に、特定のブロックが摩耗することがある可能性が低くなる。
1つの従来の摩耗一様化プロセスは、顧客またはホストのLBAの2つの比較的大きな部分がマッピングされる物理的位置をスワップすることを含む。すなわち、記憶セルの比較的大きなセクションに関連付けられたLBAが、スワップされる。そのようなスワップは、ホストの使用によりなど、顧客からの手動コマンドにより開始され、その結果、顧客には透過的ではない。また、記憶セルの2つの比較的大きなセクション間でデータを移動させることを含むスワップ動作は、時間がかかり、したがって、非効率的である。さらに、フラッシュ・メモリ・システム全体の性能は、フラッシュ・メモリ・システム全体に関連付けられた著しいリソースを消費する比較的長い継続時間のスワップ動作によって、悪影響を受ける可能性がある。当業者なら理解するように、第1位置からデータを移動させることは、通常、データを他の位置にコピーすることと、データを第1位置から消去することとを含む。
他の従来の摩耗一様化プロセスは、ブロックが摩耗することを可能にすることを含む。ブロックが事実上摩耗した後、セクタが記憶されているブロックが摩耗した後に、または使用不能になった後に、ブロックに割り当てられたセクタは、そのセクタに関連付けられたアドレスをスペア領域にマッピングすることによって、再度割り当てられることが可能である。スペア領域またはブロックの数は限定され、かつ貴重であるので、使用不能ブロックに関連付けられたセクタがマッピングされることが可能であるスペア領域が常に存在するとは限らない可能性がある。さらに、ブロックが使用不能になった後でのみ、セクタを事実上再度マッピングすることにより、一般に、フラッシュ・メモリ・システム全体の性能を低下させる。
したがって、フラッシュメモリ記憶システム内において摩耗一様化を効率的かつほぼ透過的に実施する方法および装置が所望される。すなわち、計算リソースを著しく使用することを必要とせずに、フラッシュメモリ記憶システムに関連付けられた物理位置においてより一様な摩耗を促進する摩耗一様化プロセスが必要とされる。
本発明は、不揮発性メモリシステムのシステムメモリにおいて平均消去カウントを維持するためのシステムおよび方法に関する。本発明の一態様によれば、メモリシステムの不揮発性メモリ内にあるいくつかのブロックの各ブロックが消去された平均回数を決定する方法は、各ブロックが消去された回数を示す各ブロックの消去カウントを得ることを含む。すべての消去カウントが得られた後、消去カウントは合計され、ブロック数の各ブロックが消去された平均回数を示す平均消去カウントが、合計をブロック数によって実質的に除算することによって創出される。
一実施形態では、消去カウントは、ブロックから得られる。そのような実施形態では、消去カウントは、ブロックの冗長領域またはオーバーヘッド領域から得られることが可能である。他の実施形態では、消去カウントは、ブロック数の各ブロックの消去カウントを含むメモリシステムの消去カウントブロックから得られる。
平均消去カウントを維持することによって、全メモリシステム内の平均ブロックが消去された回数の特徴付けが、容易に得られることが可能である。ブロックが消去されるとき、ブロックが消去された回数が表示されない可能性がある。その結果、ブロックに関連する摩耗の量は、容易には決定または推定されない可能性がある。そのようなブロックが何回消去された可能性が高い回数を示す平均消去カウントを使用することにより、ブロックの摩耗の妥当な推定が決定されることが可能になる。したがって、摩耗一様化は、より効率的に行われることが可能である。
本発明の他の態様によれば、データ構造が、複数のブロックの各使用可能なブロックが消去された回数の表示を提供する第1インジケータ、および複数のブロックに含まれるブロックの総数を示す第2インジケータを含む。一実施形態では、データ構造は、第1インジケータおよび第2インジケータを含むヘッダをも含む。
本発明の他の態様によれば、消去ブロックを使用のために実質的に準備する方法が、消去ブロックを得ることと、複数のブロックの各ブロックが消去された回数を特徴付けるインジケータを得ることと、複数のブロックの各ブロックが消去された回数を特徴付けるインジケータを、消去ブロックが消去された回数の表示として消去ブロックに記憶することとを含む。一実施形態では、方法は、また、消去ブロックが消去された回数のインジケータが利用可能であるときを判定することと、消去ブロックが消去された回数のインジケータが利用可能であると判定されるとき、消去ブロックが消去された回数のインジケータを消去ブロックに記憶することとを含む。そのような実施形態では、複数のブロックの各ブロックが消去された回数を特徴付けるインジケータを得ることは、実質的に、消去ブロックが消去された回数のインジケータが利用可能でないときのみ、複数のブロックの各ブロックが消去された回数を特徴付けるインジケータを得ることを含み、複数のブロックの各ブロックが消去された回数を特徴付けるインジケータを記憶することは、実質的に、消去ブロックが消去された回数のインジケータが利用可能ではないと判定されるときのみ、複数のブロックの各ブロックが消去された回数を特徴付けるインジケータを記憶することを含む。
本発明は、添付の図面に関連して取り入れられた以下の記述を参照することによって、最適に理解されることが可能である。
フラッシュ・メモリ・システム内の不揮発性メモリ記憶ブロックは、反復してプログラムおよび消去されることが可能であるが、各ブロックは、一般に、ブロックが摩耗する前に、有限回のみ消去されることが可能である。ブロックが摩耗するとき、摩耗ブロックを含むフラッシュメモリ記憶システムの全記憶ボリュームの一部に関連する性能の比較的著しい低下が生じ、その部分に記憶されているデータが損失される可能性があり、または、データをその部分に記憶することが不可能になる可能性がある。
ブロックがフラッシュメモリ記憶システム内においてより一様に摩耗する可能性を増大させるために、ブロックは、より一様に使用されることが可能である。たとえば消去カウントを使用することにより、各ブロックが消去された回数を追跡することによって、システム内のメモリがより一様に使用されることが可能である。消去カウント管理技術が、特定のブロックが、そのブロックに関連付けられた冗長領域において消去された回数を追跡する消去カウントを記憶することが可能である。表が、使用中のブロックが比較的大きい消去カウントを有するブロックおよび比較的小さい消去カウントを有するブロックから事実上分離されることを実質的に可能にするシステムメモリにおいて構築されることが可能である。使用中のブロックが消去されるとき、ブロックは、適宜、比較的大きい消去カウントを有するブロックの表、または比較的小さい消去カウントを有するブロックの表に「追加」されることが可能である。同様に、ブロックが、比較的大きい消去カウントを有するブロックの表、または比較的小さい消去カウントを有するブロックの表から、ブロックマッピング表に、すなわち使用中のブロックの1セットの表に、ブロックマッピング表から再度割り当てられたあらゆるブロックを実質的に置き換えるために、「移動」されることが可能である。
ブロックをカテゴリ化することによって、ブロックがより一様に使用されることが可能であるが、その理由は、各ブロックの使用が、ブロックに関連付けられた摩耗を一様にするように、より有効に管理されることが可能であるからである。さらに、ブロックを表にカテゴリ化することは、小さい消去カウントを有するブロックおよび大きい消去カウントを有するブロックが容易に識別されることを可能にし、したがって、著しい量の計算リソースを使用しない。したがって、摩耗一様化は、比較的効率的に行われる。その結果、フラッシュ・メモリ・システムの寿命は、フラッシュ・メモリ・システムの性能に著しい影響を与えずに、大幅に延長されることが可能である。
ブロックのカテゴリ化を容易にするために、消去カウントブロックが、フラッシュ・メモリ・システム内において割り付けられることが可能である。そのようなブロックは、データをフラッシュ・メモリ・システム内に記憶するために使用されることが可能であるほぼすべてのブロックの消去カウントを含むように構成されることが可能である。ブロックが消去されるとき、ブロックの消去カウントは、通常、消去される。関連付けられた消去カウントを消去カウントブロックに有するほぼすべてのブロックの消去カウントを記憶することによって、消去ブロックの消去カウントは、たとえば、消去カウントブロックから消去カウントを読み取ることによって、容易に得られることが可能である。
フラッシュ・メモリ・システム、またはより一般的には不揮発性メモリ装置は、一般に、フラッシュ・メモリ・カードおよびチップセットを含む。通常、フラッシュ・メモリ・システムは、ホストシステムがフラッシュ・メモリ・システムにデータを書き込み、またはフラッシュ・メモリ・システムからデータを読み取ることが可能であるように、ホストシステムと関連して使用される。しかし、いくつかのフラッシュ・メモリ・システムは、埋込みフラッシュメモリと、埋込みフラッシュメモリの制御装置として実質的に作用するようにホスト上で実行されるソフトウエアとを含む。まず図1aを参照すると、コンパクトフラッシュ(登録商標)・メモリ・カードまたは埋込みシステムなど、不揮発性メモリ装置を含む汎用ホストシステムが記述される。ホストまたはコンピュータシステム100は、一般に、マイクロプロセッサ108、ランダム・アクセス・メモリ(RAM)112、および入力/出力回路116が通信することを可能にするシステムバス104を含む。ホストシステム100は、例示の目的では図示されていないディスプレイ装置およびネットワーキング装置など、他の構成要素を一般に含むことが可能であることを理解されたい。
一般に、ホストシステム100は、静止画像情報、音声情報、およびビデオ画像情報などを含むが、これに限定されない情報を得ることができるとすることが可能である。そのような情報は、実時間で得られることが可能であり、また、無線方式でホストシステム100に伝送されることが可能である。ホストシステム100は、実質的にあらゆるシステムとすることが可能であるが、ホストシステム100は、通常、デジタルカメラ、ビデオカメラ、セルラ通信装置、オーディオプレーヤ、またはビデオプレーヤなどのシステムである。しかし、ホストシステム100は、一般に、データまたは情報を記憶し、またデータまたは情報を取り出すほぼあらゆるシステムとすることが可能であることを理解されたい。
ホストシステム100は、データを得るのみである、またはデータを取り出すのみであるシステムとすることも可能である。すなわち、ホストシステム100は、データを記憶する専用システムとすることが可能であり、または、ホストシステム100は、データを読み取る専用システムとすることが可能である。例として、ホストシステム100は、データを書き込む、または記憶するようにのみ構成されるメモリライタとすることが可能である。代替として、ホストシステム100は、データを読み取る、または取り出すように通常構成され、またデータを得るようには構成されないMP3プレーヤなどの装置とすることが可能である。
一実施形態では、取外し可能不揮発性メモリ装置である不揮発性メモリ装置120が、情報を記憶するためにバス104とインタフェースするように構成される。随意選択のインタフェースブロック130により、不揮発性メモリ装置120がバス104と間接的にインタフェースすることが可能になると考えられる。存在するとき、入力/出力回路ブロック130が、当業者になら理解するように、バス104に対する負荷を低減するように作用する。不揮発性メモリ装置120は、不揮発性メモリ124および随意選択メモリ制御システム128を含む。一実施形態では、不揮発性メモリ装置120は、単一チップまたはダイの上において実施されることが可能である。代替として、不揮発性メモリ装置120は、マルチチップモジュールの上において、またはチップセットを形成することが可能であり、かつ不揮発性メモリ装置120として共に使用されることが可能である複数の離散構成要素の上において実施されることが可能である。不揮発性メモリ装置120の一実施形態が、図1bを参照して以下でより詳細に記述される。
たとえばNANDフラッシュメモリなどのフラッシュメモリである不揮発性メモリ124は、必要に応じてデータにアクセスして読み取ることが可能であるように、データを記憶するように構成される。不揮発性メモリ124に記憶されているデータは、適宜、消去されることも可能であるが、不揮発性メモリ124のいくつかのデータは、消去可能ではないとすることが可能であることを理解されたい。データを記憶する、データを読み取る、およびデータを消去するプロセスは、一般に、メモリ制御システム128によって制御され、または、メモリ制御システム128が存在しないときは、マイクロプロセッサ108によって実行されるソフトウエアによって制御される。不揮発性メモリ124の動作は、本質的に不揮発性メモリ124のセクションをほぼ一様に摩耗させることによって、不揮発性メモリ124の寿命がほぼ最大になるように管理されることが可能である。
不揮発性メモリ装置120は、随意選択メモリ制御システム128、すなわち制御装置を含むとして一般的に記述された。しばしば、不揮発性メモリ装置120は、不揮発性メモリ124およびメモリ制御システム128について別々のチップ、すなわち制御装置機能を含むことが可能である。例として、PCカード、コンパクトフラッシュ(登録商標)カード、マルチメディアカード、およびセキュア・デジタル・カードを含むがこれに限定されない不揮発性メモリ装置は、別々のチップ上で実施されることが可能である制御装置を含むが、他の不揮発性メモリ装置は、別々のチップ上で実施される制御装置を含まないことが可能である。不揮発性メモリ装置120が別々のメモリおよび制御装置のチップを含まない実施形態では、メモリおよび制御装置の機能は、当業者には理解されるように、単一チップに統合されることが可能である。代替として、メモリ制御システム128の機能は、上記で議論されたように、たとえば不揮発性メモリ装置120がメモリ制御装置128を含まない実施形態では、マイクロプロセッサ108によって提供されることが可能である。
図1bを参照すると、本発明の実施形態による不揮発性メモリ装置120が、より詳細に記述される。上述されたように、不揮発性メモリ装置120は、不揮発性メモリ124を含み、また、メモリ制御システム128を含むことが可能である。メモリ124および制御システム128、または制御装置は、不揮発性メモリ装置120の構成要素とすることが可能であるが、メモリ124がNAND装置に埋め込まれるとき、図1cに関して以下で議論されるように、不揮発性メモリ装置120は、制御システム128を含まないことが可能である。メモリ124は、半導体基板の上に形成されたメモリセルのアレイとすることが可能であり、2つ以上の電荷レベルの1つをメモリセルの個々の記憶要素に記憶することによって、データの1つまたは複数のビットが、個々のメモリセルに記憶される。不揮発性フラッシュ電気的消去可能プログラム可能読取り専用メモリ(EEPROM)は、そのようなシステムの一般的なタイプのメモリの例である。
存在するとき、制御システム128は、データを記憶するために、メモリシステムを使用しているホストコンピュータまたは他のシステムとバス15で通信する。バス15は、一般に、図1aのバス104の一部である。制御システム128は、ホストによって提供されるデータを書き込み、ホストによって要求されたデータを読み取り、動作メモリ124において様々なハウスキーピング機能を実施するために、メモリ・セル・アレイ11を含むことが可能であるメモリ124の動作も制御する。制御システム128は、一般に、関連する不揮発性ソフトウエアメモリ、様々な論理回路などを有する汎用マイクロプロセッサを含む。1つまたは複数の状態機械も、特定のルーチンの性能を制御するために、しばしば含まれる。
メモリ・セル・アレイ11は、通常、アドレスでコーダ17を経て制御システム128またはマイクロプロセッサ108によってアドレスされる。デコーダ17は、制御システム128によってアドレスされているメモリセルのグループに対し、データをプログラムするため、またはそのグループからデータを読み取るため、またはそのグループを消去するために、適切な電圧をアレイ11のゲートおよびビット線に印加することができる。追加の回路19が、セルの対処されたグループにプログラムされているデータに依拠するアレイの要素に印加された電圧を制御するプログラミングドライバを含むことができる。回路19は、メモリセルのアドレスされたグループからデータを読み取るのに必要な感知増幅器および他の回路をも含むことができる。アレイ11内にプログラムされるデータ、またはアレイ11から最近読み取られたデータは、図示されるように、制御システム128の外部とすることが可能である、または制御システム128の内部にあることが可能である、バッファメモリ21に記憶されることが可能である。制御システム128は、通常、コマンドおよび状況データなどを一時的に記憶する様々なレジスタをも含む。
アレイ11は、多数のBLOCK0〜Nのメモリセルに分割される。フラッシュEEPROMシステムに一般的であるように、ブロックは、通常、消去の最小単位とすることができる。すなわち、各ブロックは、共に消去される最小数のメモリセルを含むことができる。各ブロックは、図2にも示されるように、通常、いくつかのページに分割される。ページは、通常、プログラミングの最小単位とすることができる。すなわち、基本的なプログラミング動作が、メモリセルの1ページの最小限にデータを書き込み、またはそれからデータを読み取ることができる。データの1つまたは複数のセクタが、各ページ内に通常記憶される。図1bに示されるように、1つのセクタが、ユーザデータおよびオーバーヘッドデータを含む。オーバーヘッドデータは、セクタのユーザデータから計算されたエラー補正コード(ECC)を通常含む。制御システム128の一部23が、データがアレイ11にプログラムされているとき、ECCを計算し、また、データがアレイ11から読み取られているとき、ECCを検査することができる。代替として、ECCは、それらが属するユーザデータとは異なるページ、または異なるブロックに記憶されることができる。
ユーザデータのセクタは、磁気ディスクドライブのセクタのサイズに対応して、通常512バイトである。オーバーヘッドデータは、通常、追加の16バイトであるが、オーバーヘッドデータに含まれるバイト数は、変更されることが可能であることを理解されたい。データの1つのセクタが、各ページに含まれることが最も一般的であるが、代わりに、2つ以上のセクタが、ページを形成することが可能である。任意の数のページが、ブロックを形成することが一般に可能である。例として、ブロックは、8ページから最高で512、1024、またはそれを超えるページから形成されることが可能である。ブロックの数は、望ましいデータ記憶能力をメモリシステムに提供するように選択される。アレイ11は、いくつかのサブアレイ(図示せず)に通常分割され、それぞれは、様々なメモリ動作の実行において並行の程度を増大させるために、互いにある程度独立に動作するある割合のブロックを含むことができる。複数サブアレイの使用の例が、参照によって本明細書に完全に組み込まれている米国特許第5890192号において記載されている。
一実施形態では、NANDフラッシュメモリなどの不揮発性メモリは、ホストシステムなどのシステムに埋め込まれる。図1cは、埋込み不揮発性メモリを含むホストシステムの概略図である。ホストまたはコンピュータシステム150が、ホストシステム150の他の構成要素(図示せず)の中でも、マイクロプロセッサ158、RAM162、および入力/出力回路166が通信することを可能にするシステムバス154を一般に含む。フラッシュメモリなどの不揮発性メモリ174により、情報をホストシステム150内に記憶することが可能になる。不揮発性メモリ174から情報を読み取り、かつ不揮発性メモリ174に情報を書き込むことが可能であるように、インタフェース180が、不揮発性メモリ174とバス154との間に提供されることが可能である。
不揮発性メモリ174は、不揮発性メモリ174を制御するように構成されるソフトウエアまたはファームウエアあるいはその両方を有効に実行するマイクロプロセッサ158によって管理されることが可能である。すなわち、マイクロプロセッサ158は、不揮発性メモリ174を制御することを可能にするコード装置(図示せず)、すなわちソフトウエアコード装置またはファームウエアコード装置を実行することが可能である。そのようなコード装置は、マイクロプロセッサ158の内部にCPUが実装されたフラッシュメモリ、別々のフラッシュROM、または不揮発性メモリ174の内部とすることが可能であり、以下で記述されるように、不揮発性メモリ174の物理ブロックに対処することを可能にすると考えられ、また、情報を物理ブロックに記憶する、情報を物理ブロックから読み取る、および情報を物理ブロックから消去することを可能にすると考えられる。
図1aの不揮発性メモリ124の記憶要素などの特定のセクションが、反復して書き込まれ、消去されるなど、連続的にプログラムされるとき、その特定の領域は、一般に、連続的にプログラムされない領域より迅速に摩耗される。不揮発性メモリ124内の異なる領域の摩耗を事実上「一様にする」ために、連続的にプログラムされる領域がより少なくプログラムされ、一方、連続的にプログラムされない領域がより多くプログラムされることが可能であるように、摩耗一様化が、ほぼ自動的に実施されることが可能である。
一般に、摩耗一様化を実施するために、物理位置に関連付けられる1セットのセクタなど、反復してプログラムされるブロックが、反復してプログラムされない物理位置に関連付けられるブロックとスワップされることが可能である。すなわち、反復してプログラムされ、したがって消去された物理的ブロックが、より頻繁でなくプログラムされ、かつ消去された物理的ブロックとスワップされることが可能である。
本発明の一実施形態では、特定の物理ブロックが反復してプログラムされ、かつ消去されたかを容易に判定するために、消去カウントがブロックと共に記憶されることが可能である。すなわち、ブロックが消去された回数を追跡するカウンタが維持されて、ブロックが消去されるたびに増分されることが可能である。そのような消去カウントは、特定のブロックが、より頻繁ではなく消去された他のブロックとスワップされるべきであるかの判定を容易にするために使用されることが可能である。図2は、本発明の実施形態による、フラッシュメモリの一部の概略図である。フラッシュメモリ200は、ページ204に分割されることが可能である。約512バイトのユーザデータを一般に含む各ページ204は、冗長領域206を実際に含み、たとえば、ページ204aは、冗長領域206aを含む。各冗長領域206またはオーバーヘッド領域は、グループ識別子216、更新インデックス212、および消去カウント214を通常含むが、これに限定されない、最高で約16バイトの情報を含むことが可能である。
通常、任意の数のページ204が、ブロック210に含まれる。例示を容易にするために、ページ204a、204bが、ブロック210に含まれるように示されているが、ブロック210に含まれるページ204の数は、大きく変化することが可能であることを理解されたい。記述される実施形態では、ブロック210は、約64ページを含むように構成されることが可能である。たとえば、フラッシュメモリ200が約512メガビット(Mb)を含むとき、フラッシュメモリ200は、それぞれが32ページの約4096ブロックに事実上分割されることが可能である。
以前に記述されたように、消去カウント214は、ユーザデータが関連ブロックから消去されるたびに増分されることが可能である。たとえば、ブロック210に関連付けられる消去カウント214は、データがブロック210から消去されるたびに増分されることが可能である。ブロック210に含まれる各ページ204a、204bは、一般に消去カウント214を有するので、各ページ204a、204bに関連付けられた消去カウント214は、ブロック210が消去されるとき、増分されることが可能である。
一般に、データを含むブロックが消去されるとき、ブロックのデータ領域および冗長領域の両方が消去される、または空にされる。消去されたブロックは、通常、スペア・ブロック・プールに追加され、スペア・ブロック・プールは、他の表の消去ブロックなど、他の消去ブロックの消去カウントより小さい消去カウントを有する消去カウントを含む。スペアブロック表は、本質的に、最低頻度消去ブロック表とすることが可能であり、これについては以下で記述される。本発明の一実施形態では、大きな消去カウントを有する消去ブロックが、他の表の消去ブロックと比較してより大きい消去カウントを含む消去ブロックを含むプールに追加される。大きな消去カウントを有する消去ブロックを含むプールは、最高頻度消去ブロック表とすることが可能であり、これについても以下で記述される。消去されたばかりのブロックの消去カウントは、1つだけ増分され、カウントの値に応じて、最低頻度消去ブロック表または最高頻度消去ブロック表に保存される。
図2に戻ると、消去カウント214などの消去カウントが、初期化要求中にアクセスされることが可能である。たとえば、埋込みフラッシュメモリを含むシステムなどのシステムが給電されるとき、システム内のスペアブロックがローで実行されているとき、ユーザがブロックの割付けを均衡させることを要求するとき、およびユーザがブロックの使用がより一様に行われることを要求するとき、初期化要求が作成されることが可能である。図3は、本発明の実施形態による、フラッシュ・メモリ・システムに関する初期化要求を処理することに関連するステップを示すプロセス流れ図である。一般に、初期化要求は、たとえば周期的に、またはトリガ条件が満たされるとき、ユーザによって開始される、またはフラッシュ・メモリ・システムに関連付けられた制御装置によってほぼ自動的に開始されることが可能である。初期化要求に応答するプロセス300が、ステップ304において開始され、初期化要求が実際に受信される。初期化要求は、初期化されるフラッシュメモリと通信する制御装置またはプロセッサによって受信されることが可能である。そのような要求は、たとえば、給電時に、またはブロック割付けが均衡されるときに、ホストを介してユーザによって提供されることが可能である。
初期化要求が受信された後、ステップ306において、平均消去カウントが得られる。一実施形態では、平均消去カウントは、システムに関連付けられたNANDメモリに書き込まれる消去カウントブロックに記憶されるが、平均消去カウントは、構造に関連付けられたNANDメモリのほぼあらゆるデータ構造に記憶される、または書き込まれることが可能であることを理解されたい。平均消去カウントおよび各ブロックの消去カウントを含む消去カウントブロック(ECB)は、フラッシュメモリのブロックに記憶される。システムが当初フォーマットされるときなど、消去カウントが創出されるとき、表の平均消去カウントおよび各ブロックの消去カウントは、通常、ゼロの値に初期化されることを理解されたい。消去カウントブロックが、図8aに関して以下で記述される。平均消去カウントが得られた後、システム内のほぼすべてのブロックの消去カウントが得られる。図2に関して上述されたように、データを含む特定のブロックの消去カウントは、そのブロックに関連付けられる冗長領域に記憶されることが可能である。したがって、データを含むほぼすべてのブロックの消去カウントを得ることは、各ブロックに関連付けられた冗長領域にアクセスすることと、各消去カウントを消去カウントブロックに記憶することとを含むことが可能である。
初期化要求時に、消去ブロックの消去カウントは、消去カウントブロックから得られる。消去カウントブロックは、そのブロックの冗長領域が消去されるので、一般にその値を維持する。システム全体がシャットダウンされるとき、終了要求が通常作成され、したがって、ほぼすべてのブロックの最後の消去カウントを得るように、消去カウント表が更新される。任意の所与の時間において、ブロックは、最高頻度消去ブロック表、最低頻度消去ブロック表、消去カウントブロック、またはブロックマッピング表に属する。消去カウントブロックに属するブロックの消去カウントは、ブロックの冗長領域に記憶される。データを含むブロックの消去カウントは、しばしば、ブロックマッピング表に属し、冗長領域に記憶される。ブロックマッピング表に属する消去ブロックの消去カウントは、ゼロの消去カウントを有するが、その理由は、ブロックが事実上全く使用されていないからである。最低頻度消去ブロック表または最高頻度消去ブロック表のブロックから消去カウントを得ることは、表から値を得ることを含むが、その理由は、表の各エントリが、消去ブロックのブロック数およびその消去カウントの両方を一般に含むからである。初期化要求の処理を完了すると直ちに、消去カウントブロックは、一般に、すべてのブロックの現行消去カウントで更新される。
ステップ320において、ブロックマッピング表が、ホストシステムメモリなどのシステムメモリにおいて割り付けられる。当業者なら理解するように、ブロックマッピング表は、論理ブロックアドレス(LBA)と物理ブロックアドレス(PBA)との間のマッピングを提供するように構成されることが可能である。さらに、最高頻度消去ブロック表および最低頻度消去ブロック表も、ステップ320において割り付けられる。
最高頻度消去ブロック表は、通常、最も頻繁に消去された消去ブロックに関する情報を有効に保持するようにサイズ決めされ、そうでない場合は構成される。すなわち、最高頻度消去ブロックが、消去カウントおよびマッピング情報など、システムの最高消去カウントを有する消去ブロックに属する情報を保持するように構成される。同様に、最低頻度消去ブロック表が、一般に、最低消去カウントを有する消去ブロックに属する情報を収容するようにサイズ決めされ、そうでない場合は構成される。最高頻度消去ブロック表のサイズおよび最低頻度消去ブロック表のサイズは、大きく変化することが可能であるが、サイズは、最高頻度で消去されると指定されるブロックの数、および最低頻度で消去されると指定されるブロックの数に依拠する。通常、最高頻度消去ブロック表は、一般に、最低頻度消去ブロック表より少ない消去ブロックの情報を収容するようにサイズ決めされる。例として、最高頻度消去ブロック表は、約18の消去ブロックの情報を収容するようにサイズ決めされることが可能であり、一方、最低頻度消去ブロック表は、約70の消去ブロックに関する情報を収容するようにサイズ決めされることが可能である。代替として、最高頻度消去ブロック表は、約10の消去ブロックの情報を収容するようにサイズ決めされることが可能であり、一方、最低頻度消去ブロック表は、約50の消去ブロックの情報を収容するようにサイズ決めされることが可能である。
表がステップ320において割り付けられた後、消去ブロックが、ステップ324において識別される。次いで、ステップ328において、「N」の消去ブロックが、最高頻度消去ブロックに割り当てられ、かつ本質的に、最高頻度消去ブロック表に割り当てられることが可能である。一実施形態では、「N」の消去ブロックは、すべての消去カウントの比較によって決定される最高消去カウントを有する「N」の消去ブロックとすることが可能である。代替として、最高頻度消去ブロック表に記憶される「N」の消去ブロックは、ステップ306において得られる平均消去カウントとの比較に基づいて決定されることが可能である。たとえば、「N」の消去ブロックは、平均消去カウントより大きい約24パーセントなどの少なくとも所与のパーセンテージである消去カウントを有する「N」の消去ブロックとすることが可能である。
最高頻度消去ブロックが有効にポピュレートされた後、ステップ332において、「M」の消去ブロックが、識別され、最低頻度消去ブロック表に有効に割り当てられることが可能である。「M」の消去ブロックは、一般に、システムに関連付けられたすべての消去ブロックの最低消去カウントを有する「M」の消去ブロックとすることが可能であり、または、「M」の消去ブロックは、平均消去カウントより小さい少なくとも所与のパーセンテージである消去カウントを有する「M」の消去ブロックとすることが可能である。「M」の消去ブロックは、事実上、適宜ブロックマッピング表に割り当てられるスペアブロックである。
残りの消去ブロック、すなわち最低頻度消去ブロック表または最高頻度消去ブロック表に割り当てられなかった消去ブロックが、ステップ336において、「未消去」ブロックと共に、ブロックマッピング表に割り当てられる。すなわち、残りの消去ブロックならびに関連付けられた冗長領域以外においてデータを含むブロックが、ブロックマッピング表に関連付けられる。
たとえば対応するブロックに属する消去カウントおよびマッピング情報と共に、ブロックマッピング表、最低頻度消去ブロック表、および最高頻度消去ブロック表が有効にポピュレートされた後、平均消去カウントが、ステップ338において決定されることが可能である。平均消去カウントを決定することは、通常、ステップ308において得られた個々のブロックの消去カウントを合計することと、ブロックの総数によって合計を除算することとを含む。平均消去カウントは、初期化要求に応答して決定されることが可能であるが、平均消去カウントは、ほぼ随時、更新される、またはそうでない場合は決定されることが可能であることを理解されたい。平均消去カウントを計算する1つの方法に関連するステップが、図13に関して以下で記述される。
ステップ338において計算された平均消去カウントは、システムに関連付けられた消去カウントブロックに記憶される。以前に記述されたように、平均消去カウントは、システムに関連付けられたNANDメモリに書き込まれる消去カウントブロックに記憶される。平均消去カウントを消去カウントブロックに記憶すると直ちに、静止ブロック、またはデータを含み、かつ比較的小さい関連付けられた消去カウントを有するブロックが、ステップ342において処理されることが可能である。静止ブロックを処理する一方法に関連するステップは、図4に関して以下で記述される。静止ブロックが処理された後、初期化要求を処理するプロセスは、完了される。
フラッシュメモリに関連付けられたブロックのグループ内には、任意の所与の時間において、消去されるブロック、およびデータ、すなわちユーザデータを含むブロックが通常存在する。データを含むブロックのいくつかは、「通常」ブロックと見なされることが可能であり、一方、他は、静止ブロックと見なされることが可能である。静止ブロックは、まれにしか変更されないデータを含むブロックである。すなわち、静止ブロックは、まれにしか消去されない。通常、静止ブロックは、フラッシュメモリに記憶されている比較的古いドキュメント、フラッシュメモリに記憶されている実行可能なプログラム、またはフラッシュメモリに記憶されているオペレーティングシステムに関連付けられることが可能である。静止ブロックは、一般に、フラッシュメモリ内の大半のブロックの消去カウントよりかなり小さい消去カウントを有することが可能である。一実施形態では、ブロックの消去カウントが、フラッシュ・メモリ・システムに関連付けられた平均消去カウントの約20パーセントなど、あるパーセンテージより小さい場合、データを含むブロックが静止ブロックと見なされることが可能である。
静止ブロックは、まれにしか変更されないデータを含むので、静止ブロックに含まれるデータは、比較的大きい消去カウントを有するブロックにコピーされることが可能である。すなわち、特定の物理ブロックの内容が比較的静止しており、したがって一般に変更されない場合、比較的小さい消去カウントを有する当初の物理ブロックを、最も頻繁に変更される内容を記憶するために使用することを可能にするために、内容は、比較的大きい消去カウントを有する異なる物理ブロックに有効に再度割り当てられることが可能である。図4を参照すると、静止ブロックを処理することに関連するステップ、すなわち図3のステップ342が、本発明の実施形態により記述される。システムの静止ブロックを処理するプロセス342が、ステップ404において開始され、ブロック「A」など、消去されていないブロックの消去カウントがアクセスされる。ブロック「A」の消去カウントがアクセスされた後、ステップ408において、不消去ブロック「A」の消去カウントが、システムに関連付けられた平均消去カウントと比較して非常に小さいかについて判定が行われる。
不消去ブロック「A」の消去カウントが、平均消去カウントと比較して小さいかに関する判定は、ほぼあらゆる適切な基準に基づくことが可能であるが、一実施形態では、判定は、ブロック「A」の消去カウントが、平均消去カウントの端数に関連付けられた値より小さい値を有するかに基づいて行われる。たとえば、ブロック「A」の消去カウントは、消去カウントが平均消去カウントの所定のパーセンテージより小さいとき、小さいと見なされることが可能である。
ステップ408において、ブロック「A」の消去カウントが平均消去カウントと比較して非常に小さくないと判定される場合、ブロック「A」は、静止ブロックではない可能性が最も高いことを意味する。ブロック「A」は、ブロック「A」の消去カウントが非常に小さいとは見なされない場合でも、依然として静止ブロックであるとすることが可能であるが、そのような場合のブロック「A」の消去カウントは、他のブロックとのブロック「A」のスワップを事実上トリガしないことを理解されたい。したがって、静止ブロックを処理するプロセスは、完了される。
代替として、ステップ408において、ブロック「A」の消去カウントが平均消去カウントと比較して非常に小さいと判定される場合、ブロック小さい消去カウントを有するブロック「A」が、比較的頻繁に変更されるデータを記憶するのに自由であるとすることが可能であるように、「A」の内容は、比較的大きい消去カウントを有するブロックに書き込まれることが可能である。すなわち、ブロック「A」の消去カウントが平均消去カウントと比較して非常に小さいとき、ブロック「A」は静止ブロックであることを意味する。したがって、プロセス流れは、ステップ408からステップ412に移行し、ブロック「A」は、静止ブロックと識別される。ブロック「A」が静止ブロックと識別された後、ステップ416において、ブロック、すなわちブロック「B」が、最高頻度消去ブロック表によって識別された最高頻度消去ブロックのグループから得られることが可能である。
ブロック「B」が得られた後、ステップ420において、ブロック「A」の内容は、ブロック「B」にコピーされる。すなわち、ステップ420において、ブロック「A」に含まれるユーザデータは、ブロック「B」にコピーされる。ブロック「A」の内容がブロック「B」にコピーされた後、ステップ424において、ブロック「A」は消去される。通常、ブロック「A」が消去されるとき、ブロック「A」に関連付けられた消去カウントは増分される。ブロック「C」などのブロックが、ブロック「C」の関連付けが、最低頻度消去ブロック表から最高頻度消去ブロック表に有効に変更されるように、ステップ428において最低頻度消去ブロックのグループから最高頻度消去ブロックのグループに移動されることが可能である。すなわち、ブロック「C」は、最低頻度消去ブロック表から分離されて、最高頻度消去ブロック表に関連付けられる。そのような移動により、最低頻度消去ブロック表のスペースが、小さい消去カウントを有し、したがってシステムの最低頻度消去ブロックの1つであるブロック「A」を収容するように、有効に開放されることが可能になる。通常、ブロック「C」は、最低頻度消去ブロック表において最高消去カウントを有するブロックである。
ブロック「C」を最低頻度消去ブロックのグループから移動させる、またはそうでない場合はブロック「C」を最低頻度消去ブロックから分離すると直ちに、プロセス流れは、ステップ428からステップ432に移行し、ステップ432において、ブロック「A」は、ブロックマッピング表から最低頻度消去ブロックに有効に移動される。次いで、ステップ434において、ブロック「A」に以前に含まれていた内容を含むブロック「B」が、ブロックマッピング表に関連付けられる。当業者なら理解するように、ブロック「B」をブロックマッピング表に「移動」させることは、通常、この段階でブロック「B」に関連付けられるブロック「A」に関連付けられていた論理ブロックアドレスのマッピングを更新することを含む。ブロック「C」に属する情報が、最高頻度消去ブロック表に存在し、ブロック「B」に属する情報が、ブロックマッピング表に存在し、ブロック「A」に属する情報が、最低頻度消去ブロック表に存在するとき、静止ブロックを処理するプロセスは完了される。プロセス342は、システムに関連付けられたほぼすべての静止ブロックが識別され、処理されるまで、反復されることが可能であることを理解されたい。
一般に、ブロックマッピング表、最低頻度消去ブロック表、および最高頻度消去ブロック表は、初期化要求がフラッシュ・メモリ・システム全体に送信されるとき、図1aのRAM112など、システムメモリにおいて創出されることが可能である。表を構築するために、スペースが、表を収容するように、システムメモリにおいてまず割り付けられることが可能である。
前述されたように、ブロックマッピング表、最低頻度消去ブロック表、および最高頻度消去ブロック表が、平均消去カウントの場合のように、システムメモリにおいて創出される。各ブロックの平均消去カウントおよび消去カウントも、消去カウントブロックに書き込まれる。図5aは、本発明の実施形態による、システムメモリの概略的なブロック図である。システムメモリ454およびフラッシュメモリ460が、全システムに含まれ、たとえば、メモリカードの構成要素またはNANDメモリなどのフラッシュメモリ460が埋め込まれるホスト装置の構成要素と事実上することが可能である。システムメモリ454は、ブロックが関連付けられることが可能であるブロックマッピング表462を記憶するように構成される。通常、ブロックマッピング表462は、LBAを、フラッシュメモリ460に関連付けられた物理ブロックに関連付けるために使用されることが可能である。
システムメモリ454は、ブロックマッピング表462と同様に、初期化要求に応答して一般に形成される最低頻度消去ブロック表466および最高頻度消去ブロック表470をも保持する。ブロックの平均消去カウントをフラッシュメモリ460内に保持するように構成される平均消去カウント474が、フラッシュ・メモリ・システム全体がフォーマットされるとき創出される。一実施形態では、消去カウントブロック480が、ほぼすべてのブロック465の消去カウントをフラッシュメモリ460内に含むように構成される。初期化要求が作成されるたびに、更新された平均消去カウントが計算されて、消去カウントブロック480に記憶されることが可能である。
図5bは、本発明の実施形態による、「通常」ブロックのグループ、最低頻度消去ブロックのグループ、および最高頻度消去ブロックのグループの概略図である。ブロック502のグループは、一般にユーザデータを含む通常ブロックまたは静止ブロックとすることが可能である、あるいは消去されることが可能であるが、最高頻度消去ブロックまたは最低頻度消去ブロックではない可能性があるブロック514を含む。最低頻度消去ブロック506のグループが、全システム内において消去ブロックの最低消去カウントを有するブロック518を一般に含み、一方、最高頻度消去ブロック510のグループが、消去ブロックの最高消去カウントを全システム内において有するブロック522を一般に含む。一般に、ブロック518は、スペアブロックとして有効に使用される。
ブロック514が消去されるとき、消去ブロック514が、比較的小さい関連付けられた消去カウントまたは比較的大きい関連付けられた消去カウントを有するかについて判定されることが可能である。消去ブロック514が、比較的小さい関連付けられた消去ブロックを有するとき、消去ブロック514は、最低頻度消去ブロック506のグループに追加されることが可能である。一方、消去ブロック514が、比較的大きい関連付けられた消去カウントを有するとき、消去ブロック514は、最高頻度消去ブロック510のグループに再度割り当てられることが可能である。
ほぼあらゆるサイズとすることが可能である最低頻度消去ブロック506のグループは、分類されたグループとすることが可能である。すなわち、ブロック518は、消去カウントに基づいて実質的に分類されることが可能である。分類は、通常、ブロック518に関連付けられたエントリを含む対応する最低頻度消去ブロック表(図示せず)において反映される。たとえば、新しいブロック518が最低頻度消去ブロック506のグループに移動される、または追加される、あるいはそうでない場合は関連付けられるたびに、ブロック518は、最低頻度消去ブロック506のグループにおける最低頻度消去ブロック518が、グループ502になど、再度割り当てられる次のブロック518とすることが可能であるように、消去カウントに基づいて本質的に分類されることが可能である。すなわち、データがコピーされる新しいブロックが必要であるとき、ブロック518の最低消去ブロック518は、最低頻度消去ブロック表を使用して識別されて、最低頻度消去ブロック506のグループから取り入れられる。通常、必要とされないデータを含むブロック514が消去されるとき、そのブロック514は、最低頻度消去ブロック506のグループに分類されることが可能であり、最低頻度消去ブロック表は、相応して更新されることが可能である。すなわち、追加ブロックに対応するエントリが、最低頻度消去ブロック表に含まれることが可能である。
最高頻度消去ブロック510のグループのブロック522も、最低頻度消去ブロック506のグループに記憶されているブロック518と同様に、消去カウントに基づいて実質的に分類されることが可能である。分類は、通常、ブロック522を識別するように作用する最高頻度消去ブロック表(図示せず)においてエントリを分離することによって実施される。一実施形態では、ブロック522に関連付けられた平均消去カウントが、計算されることが可能である。すなわち、最高頻度消去ブロック510のグループの平均消去カウントが、決定されることが可能である。グループ502からのブロック514が消去され、消去ブロック514の消去カウントが、約20パーセントを超えるなど所与のパーセンテージを超えることによって、最高頻度消去ブロック510のグループの平均消去カウントを超えることが判明するとき、消去ブロック514は、最高頻度消去ブロック510のグループに追加されることが可能である。新しいブロック522が最高頻度消去ブロック510のグループに有効に追加されるとき、最低消去カウントを有する頻度消去ブロック510のグループ内のブロック522が、グループ520に再度割り当てられることが可能である。そのような再度割当ては、通常、関連付けられたブロックマッピング表、最低頻度消去ブロック表、および最高頻度消去ブロック表(図示せず)を更新することによって反映される。
グループ502、最低頻度消去ブロック506のグループ、および最高頻度消去ブロック510との間においてブロックをスワップまたは更新することは、一般に、グループ502に含まれるブロック514が消去または更新されるときに行われることが可能である。代替として、ブロックのスワップまたは更新は、実質的に、スペアブロックがグループ502において使用されるために割り付けられることが所望されるたびに、行われることが可能である。次に図6を参照すると、ブロックのより一様な摩耗を見込むために、埋込みフラッシュメモリを有するホストシステムなどのメモリシステム全体においてブロックのスワップまたは更新を実施する1つの方法が、本発明の実施形態により記述される。ブロックのスワップまたは更新を実施するプロセス600が、ステップ604において開始され、ブロック「Y」などのブロックが、ブロックマッピング表から「得られ」、そうでない場合は、ブロックマッピング表を使用して識別される。得られるブロックは、内容をコピーまたは更新するために、ブロックマピング表から有効にスワップされるブロックである。
ブロック「Y」が得られた後、ステップ608において、ブロック「X」などのブロックが、最低頻度消去ブロック表から有効に得られる。すなわち、スペアブロックが、適切なスペアブロックを識別するために、最低頻度消去ブロック表を使用して最低頻度消去ブロックのグループから得られる。一般に、ブロック「X」は、最低頻度消去ブロックのグループにおいて最低消去カウントを有するブロックであるが、ブロック「X」は、最低頻度消去ブロックのグループ、したがって最低頻度消去ブロック表に関連付けられたほぼあらゆるブロックとすることが可能である。ブロック「Y」に記憶されているデータ内容、またはブロック「Y」の当初の内容と置き換えられる新しい内容が、ステップ612においてブロック「X」にコピーされる。
ブロック「Y」の内容がブロック「X」にコピーされた後、ブロック「X」は、ステップ616において、ブロックマピング表に有効に移動される、または関連付けられる。すなわち、ブロック「Y」およびブロック「X」に関連するマッピングは、ブロック「Y」に以前にマッピングされたLBAがブロック「X」に再度マッピングされるように、有効に更新される。ブロック「X」がブロックマッピング表に有効に移動されるとき、ステップ620において、ブロック「Y」は消去される。具体的には、ユーザ内容など、ブロック「Y」に記憶されているデータ内容は、ほぼあらゆる適切な技術を使用して消去されることが可能である。次いで、ブロック「Y」に関連付けられた冗長領域に記憶されているブロック「Y」に関連付けられた消去カウントは、ブロック「Y」が再び消去されたことを示すために、ステップ624において増分される。一実施形態では、消去カウントブロックに有効に記憶されている「Y」の消去カウントが、更新されることが可能であることを理解されたい。
ステップ628において、最高頻度消去ブロック表において最低消去カウントを有するブロックが識別される。上述されたように、一実施形態では、最高頻度消去ブロック表において参照されるブロックが、それぞれの消去カウントに従って分類される。ブロックを分類することは、ブロックの消去カウントに従って、最高頻度消去ブロック表内においてブロックに対する参照を位置決めすることを含むことが可能である。したがって、最高消去カウントを有するブロックを識別することは、最低消去カウントを有するブロック参照に収容するように構成される最高頻度消去ブロック表内の位置において、ブロック参照にアクセスすることを一般に含む。
最高頻度消去ブロック表において参照された最低消去カウントを有するブロックが識別された後、プロセス流れは、ステップ628からステップ632に移行し、ブロック「Y」の消去カウントが、最高頻度消去ブロック表において参照された最低消去カウントを有するブロックの消去カウントより大きいかについて判定される。ブロック「Y」の消去カウントが、最高頻度消去カウント表において参照された最低消去カウントを有するブロックの消去カウントより大きくないと判定される場合、ブロック「Y」は、頻繁に消去されると見なされないことを意味する。したがって、プロセス流れは、ステップ632からステップ636に進行し、ブロック「Y」は、最低頻度消去ブロックのグループから移動され、最低頻度消去ブロック表に有効に移動される。すなわち、ブロック「Y」に対応するエントリが、最低頻度消去ブロック表に追加される。一実施形態では、ブロック「Y」を最低頻度消去ブロックのグループに移動させることは、各ブロックの消去カウントを使用して最低頻度消去ブロック表においてほぼすべてのブロック参照を分類することを含むことが可能である。ブロック「Y」が最低頻度消去ブロック表に有効に移動された後、ブロックをスワップまたは更新するプロセスは、完了される。
ステップ632に戻ると、ステップ632において、ブロック「Y」の消去カウントが、最高頻度消去ブロック表に関連付けられた最低消去カウントを超えると判定される場合、ブロック「Y」は、最高頻度消去ブロックのグループに移動されるべきであり、かつ最高頻度消去ブロック表に有効に移動されるべきであることを意味する。ブロック「Y」が最高頻度消去ブロック表において参照される余地が存在するために、最高頻度消去ブロック表において参照された最低消去カウントを有するブロックなどのブロックが、最高頻度消去ブロック表から除去されることが、実際上必要である。したがって、ステップ640において、最高頻度消去ブロック表において参照された最低消去カウントを有するブロックは、最低頻度消去ブロックのグループに移動され、かつ最低頻度消去ブロック表に有効に移動される。ブロックを最低頻度消去ブロックのグループに移動させることは、各ブロックの消去カウントに従って、最低頻度消去ブロック表においてブロック参照を再度分類することを含むことが可能である。
最高頻度消去ブロック表において最低消去カウントを有するブロックが、最高頻度消去ブロック表から有効に移動された後、ステップ644において、ブロック「Y」は、最高頻度消去ブロック表に有効に移動される。一実施形態では、ブロック「Y」を最高頻度消去ブロックのグループに移動させ、したがって最高頻度消去ブロック表に有効に移動させることは、ブロック「Y」を含めて、各ブロックの消去カウントに従って最高頻度消去ブロックを分類することを含むことが可能である。ブロック「Y」が最高頻度消去ブロック表に有効に移動されるとき、ブロックをスワップまたは更新するプロセスは、完了される。
一般に、ブロックをスワップまたは更新する要求に応答することなど、表を維持すること、初期化要求に対処すること、および摩耗一様化を実施することに関連付けられる機能は、プログラムコード装置などのソフトウエアにおいて、またはファームウエアとしてホストシステムに提供される。摩耗一様化が行われることを可能にするために、ホストシステムに提供されるソフトウエアまたはファームウエアに関連付けられる適切なシステムアーキテクチャの一実施形態が、図7に示される。システムアーキテクチャ700は、アプリケーションインタフェース704、システム・マネジャ・モジュール708、データ・マネジャ・モジュール712、データ保全マネジャ716、ならびに装置マネジャおよびインタフェースモジュール720などを含むが、これに限定されない、様々なモジュールを一般に含む。一般に、システムアーキテクチャ700は、図1aのプロセッサ108など、プロセッサによってアクセスされることが可能であるソフトウエアコード装置またはファームウエアを使用して実施されることが可能である。
一般に、アプリケーション・インタフェース・モジュール704は、初期化要求の過程中に媒体を初期化するために、フラッシュメモリ(図示せず)、またはより一般的には媒体と通信するように構成されることが可能である。アプリケーション・インタフェース・モジュール704は、媒体に関連付けられたセクタ、クラスタ、またはページから読み取られる、ならびにそれに書き込まれることも可能である。通常、媒体と通信することに加えて、アプリケーション・インタフェース・モジュール704は、システム・マネジャ・モジュール708およびデータ・マネジャ・モジュール712とも通信する。
一般に、アプリケーション・インタフェース・モジュール704は、ホスト、オペレーティングシステム、またはユーザと直接通信するように構成されることが可能である。アプリケーション・インタフェース・モジュール704は、システム・マネジャ・モジュール708およびデータ・マネジャ・モジュール712とも通信する。ユーザがフラッシュメモリを読み取る、それに書き込む、またはそれをフォーマットすることを望むとき、ユーザは、要求をオペレーティングシステムに送信し、要求は、アプリケーション・インタフェース・モジュール704に渡される。アプリケーション・インタフェース・モジュール704は、要求に応じて、要求をシステム・マネジャ・モジュール708またはデータ・マネジャ・モジュール712に向ける。
システム・マネジャ・モジュール708は、システム初期化サブモジュール724、消去カウントブロック管理サブモジュール726、および電力管理ブロックサブモジュール730を含む。システム初期化サブモジュール724は、一般に、初期化要求が処理されることを可能にするように構成され、通常、消去カウントブロック管理サブモジュール726と通信する。一実施形態では、システム初期化サブモジュール724は、ブロックの消去カウントが更新されることを可能にし、最低頻度使用ブロック表および最高頻度使用ブロック表を創出する役割を実質的に担う。
消去カウントブロック管理サブモジュール726は、たとえば消去カウントブロックに、ブロックの消去カウントを記憶する機能と、個々の消去カウントを使用して、平均消去カウントを計算ならびに更新する機能とを含む。すなわち、消去カウントブロック管理サブモジュール726により、有効に、消去カウントをカタログ化することが可能になり、かつ平均消去カウントを維持することが可能になる。さらに、一実施形態では、消去カウントブロック管理サブモジュール726は、また、システム全の初期化要求中に、消去カウントブロックのほぼすべてのブロックの消去カウントをほぼ同期させる。消去カウントブロック管理サブモジュール726は、平均消去カウントが消去カウントブロックに記憶されるように構成されることが可能であるが、電力管理ブロックサブモジュール730は、代わりに、平均消去カウントが記憶されることを可能にするために使用されることが可能であることを理解されたい。
アプリケーション・インタフェース・モジュール704と通信することに加えて、システム・マネジャ・モジュール708は、データ・マネジャ・モジュール712、ならびに装置マネジャおよびインタフェースモジュール720とも通信する。システム・マネジャ・モジュール708およびアプリケーション・インタフェース・モジュール704の両方と通信するデータ・マネジャ・モジュール712は、ページまたはブロックのマッピングを提供する機能を含むことが可能である。データ・マネジャ・モジュール712は、オペレーティングシステムおよびファイル・システム・インタフェース層に関連する機能を含むことも可能である。
システム・マネジャ・モジュール708、データ・マネジャ712、およびデータ保全マネジャ716と通信する装置マネジャおよびインタフェースモジュール720は、通常、フラッシュ・メモリ・インタフェースを提供し、I/Oインタフェースなど、ハードウエアアブストラクションに関連する機能を含む。データ保全マネジャモジュール716は、機能の中でも、ECCハンドリングを提供する。
上述されたように、不揮発性メモリシステムの各ブロックの消去カウントが、不揮発性メモリシステムに関連付けられたシステムまたはNANDメモリに記憶される確保されたブロックである消去カウントブロックに記憶されることが可能である。消去カウントブロックは、各ブロックの消去カウントの他に、平均消去カウント平均消去カウントを含むことも可能である。図8aは、本発明の実施形態による、消去カウントブロックの概略図である。消去カウントブロック800は、消去カウントブロック800が、消去カウントブロック800を含む全不揮発性メモリ内に、各ブロックすなわち物理ブロックについてあるビット数を含むように、一般にサイズ決めされる。各ブロックに有効に割り付けられるビット数は、ブロックの全消去カウントが割り付けられたビット数によって適応されることが可能であるように選択されることが可能である。一実施形態では、消去カウントブロック800は、各ブロックについて約3バイトを含むことが可能であるが、その理由は、3バイトは、約10万の大きさの消去カウントに適応するために、一般に十分であるからである。3バイトが各ブロックに割り付けられるとき、ブロックあたり64ページを有する約2048のブロックを含む512Mbシステムでは、消去カウントブロック800は、約6000バイトなど、約12ページを含むようにサイズ決めされることが可能である。
消去カウントブロック800は、当業者なら理解するように、消去カウントなどのデータを記憶するために使用されることが可能である約512バイトをしばしば含むページ810を含む。図示されるように、第1ページ810aが、ブロック「0」から「169」の消去カウントエントリを含むように構成されることが可能であり、一方、第2ページ810bが、ブロック「170」から「339」の消去カウントエントリを含むように構成されることが可能である。ブロック「1」、すなわち物理ブロック「1」の消去カウントが書き込まれる、または読み取られるとき、第1ページ810aの3から5のバイトがアクセスされることが可能であるが、その理由は、第1ページ810aのバイト3から5は、図8bおよび8cに関して以下で記述されるように、ブロック「1」に対応する消去カウントエントリを含むように構成されるからである。
消去カウントブロック800は、ページ810を含むことに加えて、消去カウントブロック800内のほぼあらゆる箇所に一般に配置されることが可能であるヘッダ820をも含む。ヘッダ820は、図9に関して以下で議論され、ページ810に記憶されている消去カウントに関連付けられたブロックを含む不揮発性フラッシュメモリに関する情報を含む消去カウントブロック800のページとすることが可能である。
図8bは、本発明の実施形態による、図8aの消去カウントブロック800のページ810aなど、消去カウントブロック内のページの概略図である。ページ810aは、約170の物理ブロックに対応するエントリ830を保持するように構成される。図示されるように、エントリ830は、ページ810aの第1エントリ830aがブロック「0」の消去カウントを含むように構成され、第2エントリ830bがブロック「1」の消去カウントを含むように構成されるように、ブロックの消去カウントを含む。ページ180aの最終エントリ830dが、ブロック「169」の消去カウントを保持するように構成される。
各エントリ830は、ほぼ同じバイト数を含む。図8cに示されるように、ブロック「0」に対応するエントリ830aは、ページ810aにおいてバイト0から2とすることが可能であり、一方、ブロック「2」に対応するエントリ830cは、ページ810aにおいてバイト6から8とすることが可能である。以前に記述されたように、各エントリ830は、約3バイトを含むことが可能であるが、各エントリ830のバイト数、およびしたがってページ810aのエントリ830の数は、変更されることが可能であることを理解されたい。例として、一実施形態では、各エントリ830は、約4バイトを含むことが可能である。
ページ810aの各エントリ830は、消去カウントを含むように構成されるが、エントリ830は、必ずしも消去カウントを含むとは限らない。たとえば、製造または工場の欠陥などのために、特定のブロックが使用不能であり、また、そのブロックに書き込まれる、またはそのブロックから読み取られることが可能ではない場合、そのブロックは、一般に消去カウントを有さない。したがって、図8aの消去カウントブロック800などの消去カウントブロックは、使用不能ブロックの消去カウントを含むエントリを一般に有さない。代わりに、消去カウントを保持するのではなく、使用不能ブロックのエントリ830は、ブロックを使用不能であると識別するように構成されるインジケータまたはマーキングを保持することが可能である。
図8dは、本発明の実施形態による、消去カウント、および特定のブロックが使用不能であることを示すエントリを含む、図8aの消去カウントブロック800のページ810aなど、消去カウントブロックのページの概略図である。ブロックが使用可能であるとき、または書き込まれる、もしくは読み取られることが可能であるとき、ブロックは、一般に、消去カウントを有する。たとえば、ブロック「0」に対応する消去カウントを含むように構成されるページ810aのエントリ830aは、ブロック「0」が100回消去されたとき、「100」の値を含むことが可能である。同様に、ページ810aのエントリ830bは、ブロック「1」が30回消去されたとき、「30」の値を含むことが可能である。
たとえばブロック「2」内に記憶されているマーキングにより、ブロック「2」が使用不能ブロックであると識別された場合、ブロック「2」に対応するページ810aのエントリ830cは、ブロック「2」が使用可能ではないことを示すように構成されたマーキングを含むことが可能である。一実施形態では、エントリ830cの「FFFFFF」のマーキングが、工場の欠陥のために、ブロック「2」が使用不能であることを示すことが可能である。ほぼあらゆるマーキングが、ブロックが使用不能であることを示すために使用されることが可能であることを理解されたい。
上記で議論されたように、図8aの消去カウントブロック800などの消去カウントブロックが、ヘッダ820を通常含み、ヘッダは、一実施形態では、不揮発性メモリシステム内のブロックに一般に関する情報を含む消去カウントブロック800内のページである。次に図9を参照すると、図8aの消去カウントブロック800のヘッダ820など、消去カウントブロックのヘッダが、本発明の実施形態により記述される。ヘッダ820は、消去カウントブロック内のほぼあらゆる箇所に配置されることが可能であり、情報を記憶するために使用されることが可能である約512バイトを含むことが可能である。ヘッダ820に記憶されている情報は、署名850aおよび区分情報850bを含む。署名850aは、セキュリティチェックのために使用されることが可能である。
平均消去カウントが、不揮発性メモリのシステムメモリのほぼあらゆる箇所に記憶されることが可能であるが、記述される実施形態では、平均消去カウントは、情報850bとしてヘッダ820に記憶される。
電力が、消去カウントブロックを含む不揮発性メモリにまず提供されるとき、消去カウントブロックが、一般に初期化される、そうでない場合は消去カウトブロックが作成される。すなわち、不揮発性メモリシステムの不揮発性メモリがまずフォーマットされるとき、消去カウントブロックが、通常、初期化される。図10を参照すると、不揮発性メモリシステムの不揮発性メモリがまずフォーマットされるとき、消去カウントブロックを初期化する1つの方法に関連するステップが、本発明の実施形態により記述される。プロセス1000が、ステップ1004において開始され、不揮発性メモリシステム内のすべてのブロック、またはより具体的にはすべての物理ブロックが調査される。ブロックを調査することは、どのブロックが使用不能である可能性があるか、すなわち、どのブロックが不揮発性メモリの製造業者によって使用不能であると識別されることが可能であるかを判定するために、ブロックの内容を調査することを含むことが可能である。したがって、ステップ1008において、不揮発性メモリ内の使用不能ブロックが識別される。使用不能ブロックを識別することは、工場の欠陥を有する、またはそうでない場合は含むブロックを識別するために既知である、たとえば「FFFFFF」などの特定のマーキングであるマーキングを含む各ブロックを識別することを含むことが可能である。
ほぼすべての使用不能ブロックが識別された後、使用不能ブロックは、ステップ1012において、使用不能であると消去カウントブロックにおいてマークされる、またはそうでない場合は識別される。特定のブロックを使用不能であるとマークすることは、特定のマーキングまたはコードを、そのブロックが使用不能であると識別するブロックについて確保される消去カウントブロックの一部に配置することを含むことが可能である。消去カウントブロックにおいて使用不能ブロックをマークすることは、不揮発性メモリ内の使用不能ブロックの総数のカウントを含むように、消去カウントブロックのヘッダを更新することをも通常含むことを理解されたい。
使用不能ブロックが消去カウントブロックにおいてマークされた後、使用可能ブロック、または工場の欠陥を有さないブロックの消去されていない消去カウントが、ステップ1016において初期化される。消去カウントを初期化することは、消去されていない各ブロックの消去カウントをゼロの値に設定することを含むことが可能である。ブロックの消去カウントが、ブロックに関連付けられた冗長領域またはオーバーヘッド領域の少なくとも1つに通常記憶される。次いで、消去されたおよび消去されていない使用可能ブロックの両方である使用可能ブロックに対応する消去カウントは、ステップ1020において、消去カウントブロックにおいて設定されることが可能である。通常、消去カウントブロックに記憶されている消去カウントが、ゼロの値に設定される、またはそうでない場合は初期化されることが可能であり、あるいは未消去ブロックの場合、対応する未消去ブロックに記憶されている消去カウントと同じ値に設定される、またはそうでない場合は初期化されることが可能である。すなわち、未消去ブロックの消去カウントは、一般に、そのブロックに対応する位置の消去カウントブロックに記憶されている消去カウントと同じである。消去カウントが消去カウントブロックにおいてエントリとして設定された後、平均消去カウントは、ステップ1034において、消去カウントブロックにおいて設定されることが可能である。以前に議論されたように、平均消去カウントは、消去カウントブロックのヘッダに記憶されることが可能である。使用可能ブロックの消去カウントが、すべてゼロの値に初期化されるとき、平均消去カウントは、当初、ゼロの値に設定されることが可能である。不揮発性メモリに含まれる不揮発性メモリをフォーマットするプロセスは、平均消去カウントが設定された後、完了される。
初期化プロセスが不揮発性メモリシステム内において処理されるたびに、消去カウントブロックのエントリが更新されることが可能である。しかし、消去カウントブロックは、たとえばユーザによって出されるコマンドに応答して、ほぼ随時更新されることが一般に可能であることを理解されたい。次に図11を参照すると、初期化要求に応答して消去カウントブロックを更新する1つの方法に関連するステップが、本発明の実施形態により記述される。消去カウントブロックを更新するプロセス1100が、ステップ1108において開始され、未消去使用可能ブロックが得られる。当業者なら理解するように、未消去使用可能ブロックが、一般にデータを得て、有効に使用される。消去カウントブロックにおいて未消去使用可能ブロックについて記憶されている消去カウントエントリが、ステップ1108において得られる。すなわち、未消去使用可能ブロックの消去カウントに対応する消去カウントブロックのエントリが、読み取られる。ステップ1108において得られた未消去使用可能ブロックの消去カウントのエントリが読み取られた後、ステップ1116において、消去カウントエントリが、未消去使用可能ブロックに記憶されている消去カウントより小さい値を有するかについて判定される。
ステップ1116において、未消去使用可能ブロックについて消去カウントブロックに記憶されている消去カウントエントリが、未消去使用可能ブロックに記憶されている消去カウントより小さいと判定される場合、消去カウントブロックに記憶されている消去カウントエントリが現行のものではないことを意味する。したがって、プロセスの流れは、ステップ1116からステップ1120に移行し、未消去使用可能ブロックに対応するエントリとして消去カウントブロックに記憶される消去カウントは、更新される。消去カウントエントリを更新することは、未消去使用可能ブロックの現行消去カウントを消去カウントブロックに記憶することを通常含む。消去カウントエントリが更新された後、ステップ1124において、処理される未消去使用可能ブロックがさらに存在するかについて判定が行われる。
ステップ1124において、処理される未消去使用可能ブロックがさらに存在すると判定されるとき、プロセスの流れは、ステップ1108に戻り、他の未消去使用可能ブロックが得られる。代替として、消去カウントブロックのほぼすべての未消去使用可能ブロックの消去カウントエントリが更新されたなど、ほぼすべての未消去使用可能ブロックが処理されたと判定されるとき、ステップ1128において、不揮発性メモリ内のすべての使用可能ブロックの平均消去カウントが再計算される。当業者なら理解するように、平均消去カウントは、図13に関して以下で記述されるように、消去カウントブロックに記憶されているすべての消去カウントを合計し、次いで、消去カウントブロックに記憶されている消去カウントの数によって除算することによって、決定されることが可能である。平均消去カウントが再計算された後、再計算された平均消去カウントは、ステップ1132において、消去カウントブロックに記憶される。以前に議論されたように、平均消去カウントは、消去カウントブロックのヘッダに記憶されることが可能である。平均消去カウントが記憶された後、初期化要求に応答して消去カウントブロックを更新するプロセスは、完了される。
ステップ1116に戻ると、得られた未消去使用可能ブロックの消去カウントブロックの消去カウントエントリが、得られた未消去使用可能ブロックに記憶されている消去カウントより小さくないと判定されるとき、消去カウントブロックの消去カウントエントリが最新であることを意味する。したがって、プロセスの流れは、ステップ1116からステップ1124にほぼ直接移行し、処理される未消去使用可能ブロックがさらに存在するかについて判定される。
以前に議論されたように、ブロックの消去カウントが、ブロックに関連付けられた冗長領域またはオーバーヘッド領域に少なくとも1つに記憶される。たとえば、ブロックの消去カウントが、ブロック内の第1ページに関連付けられた少なくとも冗長領域に記憶されることが可能である。しかし、ブロックが消去されるとき、消去カウントを含めてブロックのほぼすべての内容が、通常消去される。したがって、消去ブロックが使用のために得られるとき、すなわち、消去ブロックが最低頻度消去ブロック表などのスペア・ブロック・プールから得られるとき、消去ブロックは、消去カウントを含まない。
通常、使用のためにスペア・ブロック・プール、すなわちスペアブロックから得られた消去ブロックの消去カウントが、消去カウントブロックから読み取られることが可能である。図12は、本発明の実施形態による、スペアブロックの消去カウントを得る1つの方法に関連するステップを示すプロセス流れ図である。スペアブロックの消去カウント1200を得るプロセスが、ステップ1204において開始され、得られたスペアブロックの消去エントリが、消去カウントブロックから読み取られる。具体的には、スペアブロックの消去カウントに対応する消去カウントブロックに記憶されているビットが読み取られる。次いで、ステップ1208において、消去カウントエントリのビットが有効であるかについて、判定が行われる。すなわち、スペアブロックの消去カウントエントリのビットが、以前に記憶された消去カウントを表すかについて、または、ビットが、増大する欠陥のために以前に利用不可能であったとスペアブロックを識別するかなど、スペアブロックの消去カウントエントリのビットが他のことを表すかについて、判定が行われる。
ステップ1208において、消去カウントエントリ、または消去カウントブロックから読み取られた消去カウントが、有効な消去カウントではないと有効に判定される場合、プロセスの流れは、ステップ1208からステップ1212に移行し、この消去ブロックは、消去ブロックがスペア・ブロック・プールから得られた場合、スペア・ブロック・プールから除去され、または、消去ブロックがスペア・ブロック・プールから得られなかった場合、スペア・ブロック・プールに追加されない。
代替として、ステップ1208において、スペアブロックの消去カウントブロックの消去カウントエントリの内容が、消去カウントとして使用されるのに有効であると判定される場合、プロセスの流れは、ステップ1208からステップ1216に移行し、消去カウントエントリの内容は、スペアブロックの消去カウントとして設定される。すなわち、スペアブロックの消去カウントブロックから読み取られた消去カウントが、有効な消去カウントである場合、消去カウントブロックから読み取られた消去カウントは、スペアブロックの実際の消去カウントとして設定される。スペアブロックの消去カウントが、消去カウントブロックから読み取られた消去カウントに設定された後、スペアブロックの消去カウントを得るプロセスは、完了される。
一般に、平均消去カウントを計算する、または再計算することに関連するステップは、大きく変更されることが可能である。図13は、本発明の実施形態による、平均消去カウントを計算する1つの方法を示すプロセス流れ図である。平均消去カウントを計算するプロセス1300が、ステップ1304において開始され、すべての使用可能ブロックの消去カウントが得られる。消去される未消去かつ使用可能なブロックにある使用可能ブロックが、関連付けられた消去カウントを有するので、使用不能ブロックが、一般に、消去カウントを有さない、または獲得可能な消去カウントを有さない間、使用可能ブロックのほぼ唯一の消去カウントが得られる。消去カウントは、消去カウントブロックから通常得られるが、未消去使用可能ブロックの消去カウントは、代わりに、未消去使用可能ブロックの冗長領域から得られることが可能であることを理解されたい。
使用可能ブロックの消去カウントが得られた後、使用可能ブロックの消去カウントは、ステップ1308において合計される。すなわち、使用可能ブロックの消去カウントは、共に加算される。次いで、ステップ1312において、使用可能ブロックの総数が、ステップ1312において決定される。使用可能ブロックの総数は、消去カウントブロックからブロックの総数および未使用ブロックの総数を得て、次いで、ブロックの総数から使用不能ブロックの総数を減算することによって、決定されることが可能である。代替として、使用可能ブロックの総数は、すべてのブロックを経て有効に循環させ、すべての使用可能ブロックのランニングカウントを維持することによって、得られることが可能である。
使用可能ブロックの総数が得られた後、すべての使用可能ブロックの消去カウントの合計は、平均消去カウントを生成するために、ステップ1316において使用可能ブロックの総数によって除算される。使用可能ブロックの総数が消去カウントの合計に分割された後、平均消去カウントを生成するプロセスは完了される。
本発明のごく少数の実施形態が記述されたが、本発明は、本発明の精神または範囲から逸脱せずに、多くの他の特有の形態において実現されることが可能であることを理解されたい。例として、消去カウントブロック内における消去カウントブロックのサイズおよびヘッダの位置は、大きく変更されることが可能である。さらに、消去カウントブロックのヘッダの内容も、特定のシステムの要件に応じて、変更されることが可能である。
不揮発性メモリシステムは、関連付けられたメモリ制御装置によって制御される、ホストシステムと関連付けられたソフトウエアまたはファームウエアを使用して制御されると記述されたが、消去カウント管理を含む摩耗一様化プロセスは、不揮発性メモリシステムの実質的に外部にある制御装置と通信する不揮発性メモリシステムに適用されることが可能であることを理解されたい。制御装置を使用する適切なメモリシステムには、PCカード、コンパクトフラッシュ(登録商標)カード、マルチメディアカード、セキュア・デジタル・カード、ならびにフラッシュメモリおよびフラッシュメモリ制御装置を含む埋込みチップセットがあるが、これに限定されるものではない。ホストシステムにロードされたソフトウエアまたはファームウエアを使用することにより制御されるメモリシステムは、埋込みメモリ装置を含む。一実施形態では、上述された消去管理技術および消去カウントブロック管理技術を使用することが可能であり、かつメモリシステムに関連付けられた制御装置を使用しないメモリシステムが、摩耗一様化を実施するために、ホストコンピュータシステムなど、ホストに関連付けられた制御装置を使用することが可能である。すなわち、ホストが、ホストの制御装置を使用することにより摩耗一様化が行われるメモリに直接対処し、かつ管理することが可能である。
消去カウントブロックは、いくつかのページを含むブロックであると一般的に記述された。しかし、システムメモリのほぼあらゆる適切なデータ構造が、消去カウントおよび平均消去カウントを保持するように構成されることが可能であることを理解されたい。
一実施形態では、消去カウントブロックが、不揮発性メモリシステム内のブロックの消去カウントに対応するほぼ唯一のエントリを含むことが可能である。そのような実施形態では、消去カウントのヘッダに一般に含まれる情報は、データ構造、または消去カウントブロックとは別であるブロックに記憶されることが可能である。すなわち、平均消去カウントなどの情報は、消去カウントブロックが、実質的に、ブロックに関連付けられた消去カウントに属するエントリを含むようにのみ構成されるとき、消去カウントブロックに、またはより具体的には消去カウントブロックのヘッダに、必ずしも記憶されるとは限らない可能性がある。代替として、消去カウントブロックのヘッダに記憶されるのではなく、平均消去カウントが、消去カウントブロックのほぼあらゆる箇所に代わりに記憶されることが可能である。
平均消去カウントは、すべての使用可能なブロックの消去カウントを合計し、次いで、使用可能ブロックの消去カウントの合計を使用可能ブロックの総数で除算することによって決定されると記述された。使用可能ブロックの総数で合計を除算するのではなく、合計は、ブロックの総数によって代わりに除算されることが可能であることを理解されたい。さらに、平均消去カウントは、一実施形態では、各ブロックが平均消去カウントにおいて本質的に考慮されるように、各使用不能ブロックの消去カウントを表すために現行平均消去カウントを使用することによって、すべてのブロックの消去カウントを共に有効に合計することによって決定されることが可能である。次いで、使用可能ブロックの実際の消去カウントおよび使用不能ブロックの現行平均消去カウントを含めて、すべての消去カウントの合計は、新しいまたは更新された平均消去カウントを生成するために、ブロックの総数によって除算されることが可能である。
ブロックの総数の各ブロックが消去された平均回数を有効に反映する平均消去カウントを計算するのではなく、各ブロックが消去された回数の他の特性が、代わりに計算されることが可能である。たとえば、使用ブロックなど、ブロックの総数の各ブロックが消去された中間数が、決定されることが可能である。
メモリシステム内のブロックの消去カウントを維持するために、消去カウントブロックを使用することが記述されたが、消去カウントブロックは、代わりに、消去されることが可能であるほぼあらゆるメモリ要素の消去カウントを維持するために使用されることが可能であることを理解されたい。例として、一実施形態では、消去カウントブロックまたはデータ構造が、ブロックではなく、ページの消去カウントを維持することが可能である。
一般に、摩耗一様化の様々なプロセスおよび方法に関連するステップは、大きく変更されることが可能である。ステップは、一般に、本発明の範囲の精神から逸脱せずに、追加、除去、変更、および再順序付けされることが可能である。したがって、本例は、例示的であり、かつ限定的ではないと見なされるべきであり、本発明は、本明細書において与えられた詳細に限定されるものではなく、添付の請求項の範囲内において修正されることが可能である。
本発明の実施形態による、不揮発性メモリ装置を含む汎用ホストシステムの概略図である。 本発明の実施形態による、図1aのメモリ装置120など、メモリ装置の概略図である。 埋込み不揮発性メモリを含むホストシステムの概略図である。 本発明の実施形態による、フラッシュメモリの一部の概略図である。 本発明の実施形態による、フラッシュ・メモリ・システムに関する初期化要求を処理することに関連するステップを示すプロセス流れ図である。 本発明の実施形態による、静止ブロックを処理する1つの方法に関連するステップを示すプロセス流れ図である。 本発明の実施形態による、システムメモリを示す概略的なブロック図である。 本発明の実施形態による、通常ブロック、最低頻度消去ブロック、および最高頻度消去ブロックを示す概略図である。 本発明の実施形態による、ブロックのより一様な摩耗を見込むために、メモリシステム全体のシステムメモリにおいてブロックスワップ/更新を実施する一方法を示す概略図である。 本発明の実施形態による、システムアーキテクチャを示す概略的なブロック図である。 本発明の実施形態による、消去カウントブロックの概略図である。 本発明の実施形態による、ページが位置に実質的に分割された、図8aの消去カウントブロック800のページ810aなど、消去カウントブロック内のページの概略図である。 本発明の実施形態による、ページがバイトに実質的に分割された、図8aの消去カウントブロック800のページ810aなど、消去カウントブロック内のページの概略図である。 本発明の実施形態による、消去カウント、および特定のブロックが使用不能であることを示すエントリを含む、図8aの消去カウントブロック800のページ810aなど、消去カウントブロックのページの概略図である。 本発明の実施形態による、図8aの消去カウントブロック800のヘッダ820など、消去カウントブロックのヘッダの概略図である。 本発明の実施形態による、不揮発性メモリシステムの不揮発性メモリがまずフォーマットされるとき、消去カウントブロックを初期化する1つの方法に関連するステップを示すプロセス流れ図である。 本発明の実施形態による、初期化応答に応答して消去カウントブロックを更新する1つの方法に関連するステップを示すプロセス流れ図である。 本発明の実施形態による、スペアブロックの消去カウントを得る1つの方法に関連するステップを示すプロセス流れ図である。 本発明の実施形態による、平均消去カウントを計算する1つの方法を示すプロセス流れ図である。

Claims (9)

  1. 不揮発性メモリ内における複数のブロックの各ブロックが消去された平均回数に従って、メモリシステムの不揮発性メモリを管理する方法であって、前記方法が、
    前記複数のブロックの第1のブロックに対して、当該第1のブロック内に記憶された当該ブロックの消去回数を示す消去カウントと前記メモリシステムのシステムメモリに記憶された前記第1のブロックに対する消去カウント値とを比較するステップと、
    前記第1のブロック内に記憶された消去カウントが前記システムメモリ内に記憶された前記第1のブロックに対する消去カウント値より大きいことを決定する前記比較ステップに応答して、前記システムメモリ内に記憶された前記第1のブロックに対する消去カウント値を前記第1のブロック内に記憶された消去カウントに対応するように更新するステップと、
    前記第1のブロック内に記憶された消去カウントが前記消去カウント値より大きいことを決定する前記比較ステップに応答して、前記複数のブロックの各ブロックに対する消去カウントを取得するステップであって、前記複数のブロックの数が前記不揮発性メモリ内の使用可能な総数であるステップと、
    前記複数のブロックに対する取得された消去カウントの合計を生成するステップであって、前記取得された消去カウントの合計が前記複数のブロックに対する複数のカウントから得られるものであるステップと、
    平均消去カウントを生成するステップであって、前記平均消去カウントが前記取得された消去カウントの合計から生成されるものであるステップと、
    前記メモリシステムのシステムメモリに、前記平均消去カウントのインジケータを記憶するステップであって、前記インジケータが摩耗一様化に用いられるものと、
    を備える方法。
  2. 前記不揮発性メモリが、NANDフラッシュメモリである、請求項1に記載の方法。
  3. 前記複数のブロックの各ブロックに対する消去カウントを取得するステップが、
    前記複数のブロックの各ブロックに対して、当該ブロック内に記憶された消去カウントを取得するステップを含み、更に、
    前記複数のブロックの各ブロックに対する消去カウントを取得するステップの後に、システムメモリ内に記憶された前記複数のブロックそれぞれに対する消去カウント値を前記ブロックに対する取得された消去カウントに対応するように更新するステップを含むことを特徴とする、請求項1に記載の方法。
  4. 前記平均消去カウントを生成するステップが、
    前記取得された消去カウントの合計を前記複数のブロックの数によって除算するステップを含むことを特徴とする、請求項3に記載の方法。
  5. 不揮発性メモリシステムであって、
    複数のブロックを含む不揮発性メモリであって、各ブロックが当該ブロックに対する消去カウントを含むオーバーヘッドデータを記憶するための冗長領域を含むものと、
    前記不揮発性メモリに関連付けられ、消去カウントブロックを含むシステムメモリと、
    前記消去カウントブロック管理する手段であって、
    前記複数のブロックの第1のブロックの冗長領域内に記憶された消去カウントと前記消去カウントブロック内に記憶された前記第1のブロックに関連する消去カウント値とを比較する動作であって、前記消去カウントが前記ブロックが消去された回数を示すように構成されているものと、
    前記第1のブロック内に記憶された消去カウントが前記第1のブロックに対する消去カウントブロック内に記憶された消去カウント値より大きいことを決定する前記比較動作に応答して、前記第1のブロックに対する前記消去カウントブロック内の消去カウント値を前記第1のブロック内に記憶された消去カウントに対応するように更新する動作と、
    前記第1のブロックに対する冗長領域に記憶された消去カウントが前記消去カウントブロック内に記憶された前記第一のブロックに対する消去カウント値より小さいことを決定する前記比較動作に応答して、前記複数のブロックの各ブロックに対する消去カウントを各ブロックの冗長領域から取得する動作と、
    前記複数のブロックの各ブロックが消去された平均回数を示す平均消去カウントを生成する動作であって、前記平均消去カウントが前記複数のブロックに対する複数の消去カウントから得られるものである動作と、
    を含む動作シーケンスを実行する事によって前記消去カウントブロックを管理する手段と、
    前記システムメモリに、前記平均消去カウントに対応する第1のインジケータを記憶する手段であって、前記インジケータが摩耗一様化に用いられるものと、
    を備える不揮発性メモリシステム。
  6. 前記平均消去カウントを生成する動作が、
    前記複数のブロックに対する取得された消去カウントの合計を生成する動作と、
    前記合計を前記複数のブロックの数によって除算する動作と、
    を含むことを特徴とする請求項5に記載の不揮発性メモリシステム。
  7. 前記管理手段が、
    消去カウントブロック管理ソフトウエア・サブモジュールと、
    前記消去カウントブロック管理ソフトウエア・サブモジュールを実行するためのマイクロプロセッサを含むことを特徴とする、請求項5に記載の不揮発性メモリシステム。
  8. 前記消去カウントブロック管理ソフトウエア・サブモジュールが、
    前記複数のブロックの各ブロックに対する消去カウントを得るプログラムコードであって、前記複数のブロックの各ブロックに対する消去カウントが、前記複数のブロックの各ブロックが消去された回数を示すように構成され、前記複数のブロックが、前記不揮発性メモリ内の使用可能なブロックである、プログラムコードと、
    前記複数のブロックに対する消去カウントの合計を生成するプログラムコードと、
    前記平均消去カウントを生成するプログラムコードであって、前記平均消去カウントが、前記複数のブロックが消去された平均回数を示すように構成され、前記平均消去カウントを生成する前記プログラムコードが、前記合計を前記複数のブロック内のブロック数によって除算するプログラムコードを含む、プログラムコードと、
    前記プログラムコードを記憶するメモリ領域と、
    を備えることを特徴とする請求項7に記載の不揮発性メモリシステム。
  9. 前記不揮発性メモリが、NANDフラッシュメモリである、請求項8に記載の前記メモリシステム。
JP2004548310A 2002-10-28 2003-09-10 不揮発性記憶システムにおける平均消去カウントの維持 Expired - Lifetime JP4758648B2 (ja)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US10/281,823 US7035967B2 (en) 2002-10-28 2002-10-28 Maintaining an average erase count in a non-volatile storage system
US10/281,823 2002-10-28
PCT/US2003/028215 WO2004040584A1 (en) 2002-10-28 2003-09-10 Maintaining an average erase count in a non-volatile storage system

Publications (2)

Publication Number Publication Date
JP2006504220A JP2006504220A (ja) 2006-02-02
JP4758648B2 true JP4758648B2 (ja) 2011-08-31

Family

ID=32228776

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2004548310A Expired - Lifetime JP4758648B2 (ja) 2002-10-28 2003-09-10 不揮発性記憶システムにおける平均消去カウントの維持

Country Status (10)

Country Link
US (2) US7035967B2 (ja)
EP (1) EP1559112B1 (ja)
JP (1) JP4758648B2 (ja)
KR (1) KR20050067203A (ja)
CN (1) CN1701389A (ja)
AT (1) ATE378684T1 (ja)
AU (1) AU2003270449A1 (ja)
DE (1) DE60317551T2 (ja)
TW (1) TWI247292B (ja)
WO (1) WO2004040584A1 (ja)

Families Citing this family (150)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2004040586A1 (en) * 2002-10-28 2004-05-13 Sandisk Corporation Automated wear leveling in non-volatile storage systems
US7328301B2 (en) * 2003-04-07 2008-02-05 Intel Corporation Dynamically mapping block-alterable memories
US20050055495A1 (en) * 2003-09-05 2005-03-10 Nokia Corporation Memory wear leveling
US7559004B1 (en) * 2003-10-01 2009-07-07 Sandisk Corporation Dynamic redundant area configuration in a non-volatile memory system
US20050114588A1 (en) * 2003-11-26 2005-05-26 Lucker Jonathan C. Method and apparatus to improve memory performance
US20050132128A1 (en) * 2003-12-15 2005-06-16 Jin-Yub Lee Flash memory device and flash memory system including buffer memory
KR100568115B1 (ko) 2004-06-30 2006-04-05 삼성전자주식회사 점진적 머지 방법 및 그것을 이용한 메모리 시스템
JP4527456B2 (ja) * 2004-07-06 2010-08-18 Necインフロンティア株式会社 メモリ寿命警告装置、および情報処理方法
US7441067B2 (en) 2004-11-15 2008-10-21 Sandisk Corporation Cyclic flash memory wear leveling
US7363421B2 (en) * 2005-01-13 2008-04-22 Stmicroelectronics S.R.L. Optimizing write/erase operations in memory devices
US7315917B2 (en) * 2005-01-20 2008-01-01 Sandisk Corporation Scheduling of housekeeping operations in flash memory systems
US7558906B2 (en) * 2005-08-03 2009-07-07 Sandisk Corporation Methods of managing blocks in nonvolatile memory
US7409489B2 (en) 2005-08-03 2008-08-05 Sandisk Corporation Scheduling of reclaim operations in non-volatile memory
US7552271B2 (en) * 2005-08-03 2009-06-23 Sandisk Corporation Nonvolatile memory with block management
US20070174549A1 (en) * 2006-01-24 2007-07-26 Yevgen Gyl Method for utilizing a memory interface to control partitioning of a memory module
US20070208904A1 (en) * 2006-03-03 2007-09-06 Wu-Han Hsieh Wear leveling method and apparatus for nonvolatile memory
GB0606639D0 (en) 2006-04-01 2006-05-10 Ibm Non-disruptive file system element reconfiguration on disk expansion
FR2899716A1 (fr) * 2006-04-07 2007-10-12 St Microelectronics Sa Procede de securisation de blocs de donnees dans une memoire programmable electriquement
US7778077B2 (en) * 2006-05-15 2010-08-17 Sandisk Corporation Non-volatile memory system with end of life calculation
US7971071B2 (en) * 2006-05-24 2011-06-28 Walkoe Wilbur J Integrated delivery and protection device for digital objects
JP4645538B2 (ja) * 2006-06-29 2011-03-09 ソニー株式会社 記録装置および寿命情報算出方法
US7536500B2 (en) * 2006-09-29 2009-05-19 Intel Corporation Header blocks for flash memory writes
US20080091901A1 (en) * 2006-10-12 2008-04-17 Alan David Bennett Method for non-volatile memory with worst-case control data management
US20080091871A1 (en) * 2006-10-12 2008-04-17 Alan David Bennett Non-volatile memory with worst-case control data management
US8079071B2 (en) 2006-11-14 2011-12-13 SanDisk Technologies, Inc. Methods for accessing content based on a session ticket
JP5171840B2 (ja) * 2006-11-24 2013-03-27 サンドフォース インコーポレイテッド メモリの寿命を縮める動作を遅延させる方法及びストレージシステム
US7747813B2 (en) * 2006-11-24 2010-06-29 Sandforce, Inc. Multi-memory device system and method for managing a lifetime thereof
US7809900B2 (en) * 2006-11-24 2010-10-05 Sandforce, Inc. System, method, and computer program product for delaying an operation that reduces a lifetime of memory
US20080126685A1 (en) * 2006-11-24 2008-05-29 Radoslav Danilak System, method, and computer program product for reducing memory write operations using an instruction set
US7904764B2 (en) * 2006-11-24 2011-03-08 Sandforce, Inc. Memory lifetime gauging system, method and computer program product
US7904619B2 (en) 2006-11-24 2011-03-08 Sandforce, Inc. System, method, and computer program product for reducing memory write operations using difference information
US8090980B2 (en) * 2006-12-08 2012-01-03 Sandforce, Inc. System, method, and computer program product for providing data redundancy in a plurality of storage devices
US7904672B2 (en) * 2006-12-08 2011-03-08 Sandforce, Inc. System and method for providing data redundancy after reducing memory writes
US9153337B2 (en) 2006-12-11 2015-10-06 Marvell World Trade Ltd. Fatigue management system and method for hybrid nonvolatile solid state memory system
US7710777B1 (en) * 2006-12-20 2010-05-04 Marvell International Ltd. Semi-volatile NAND flash memory
KR100817204B1 (ko) * 2006-12-22 2008-03-27 재단법인서울대학교산학협력재단 플래시 메모리의 매핑 방법 및 장치
US8356152B2 (en) * 2006-12-27 2013-01-15 Intel Corporation Initiative wear leveling for non-volatile memory
ATE517372T1 (de) * 2007-01-24 2011-08-15 Oce Tech Bv Bilderzeugungsvorrichtung mit funktion zum zählen der von der vorrichtung angezeigten bilder
JP5134255B2 (ja) * 2007-01-30 2013-01-30 富士通株式会社 データ記録システム
US7925151B2 (en) * 2007-01-31 2011-04-12 Kobre Kenneth R Device for redirecting and reflecting light from camera flash and methods for using same
US7731365B2 (en) * 2007-03-19 2010-06-08 Johnson&Johnson Vision Care, Inc. Method of fitting contact lenses
US7689762B2 (en) * 2007-05-03 2010-03-30 Atmel Corporation Storage device wear leveling
US7743203B2 (en) * 2007-05-11 2010-06-22 Spansion Llc Managing flash memory based upon usage history
US20080294813A1 (en) * 2007-05-24 2008-11-27 Sergey Anatolievich Gorobets Managing Housekeeping Operations in Flash Memory
US20080294814A1 (en) * 2007-05-24 2008-11-27 Sergey Anatolievich Gorobets Flash Memory System with Management of Housekeeping Operations
KR100857761B1 (ko) * 2007-06-14 2008-09-10 삼성전자주식회사 웨어 레벨링을 수행하는 메모리 시스템 및 그것의 쓰기방법
KR101413736B1 (ko) 2007-09-13 2014-07-02 삼성전자주식회사 향상된 신뢰성을 갖는 메모리 시스템 및 그것의웨어-레벨링 기법
TW200919448A (en) * 2007-10-17 2009-05-01 Silicon Motion Inc Storage device and method of accessing a status thereof
US7916543B2 (en) * 2007-10-22 2011-03-29 Micron Technology, Inc. Memory cell operation
US8296498B2 (en) * 2007-11-13 2012-10-23 Sandisk Technologies Inc. Method and system for virtual fast access non-volatile RAM
TWM332248U (en) * 2007-11-16 2008-05-11 Carry Technology Co Ltd Display apparatus for phonic recording and playing electronically digital picture
US7849275B2 (en) 2007-11-19 2010-12-07 Sandforce, Inc. System, method and a computer program product for writing data to different storage devices based on write frequency
US7903486B2 (en) * 2007-11-19 2011-03-08 Sandforce, Inc. System, method, and computer program product for increasing a lifetime of a plurality of blocks of memory
US9183133B2 (en) 2007-11-28 2015-11-10 Seagate Technology Llc System, method, and computer program product for increasing spare space in memory to extend a lifetime of the memory
JP4461170B2 (ja) * 2007-12-28 2010-05-12 株式会社東芝 メモリシステム
TWI354996B (en) 2007-12-31 2011-12-21 Phison Electronics Corp Wear leveling method and controller thereof
CN101499315B (zh) * 2008-01-30 2011-11-23 群联电子股份有限公司 快闪存储器平均磨损方法及其控制器
US7925822B2 (en) * 2008-01-31 2011-04-12 Sandisk Il Ltd Erase count recovery
JP2009266349A (ja) 2008-04-28 2009-11-12 Toshiba Corp 不揮発性半導体記憶装置
JP2009271848A (ja) * 2008-05-09 2009-11-19 Fujitsu Microelectronics Ltd ファイルシステム及びデータ管理方法
US7924623B2 (en) * 2008-05-27 2011-04-12 Micron Technology, Inc. Method for memory cell erasure with a programming monitor of reference cells
WO2009145923A1 (en) * 2008-05-30 2009-12-03 Aplus Flash Technology, Inc. Nand string based flash memory device, array and circuit having parallel bit lines and source lines
US8120959B2 (en) * 2008-05-30 2012-02-21 Aplus Flash Technology, Inc. NAND string based NAND/NOR flash memory cell, array, and memory device having parallel bit lines and source lines, having a programmable select gating transistor, and circuits and methods for operating same
US20100017566A1 (en) * 2008-07-15 2010-01-21 Radoslav Danilak System, method, and computer program product for interfacing computing device hardware of a computing device and an operating system utilizing a virtualization layer
US20100017588A1 (en) * 2008-07-15 2010-01-21 Radoslav Danilak System, method, and computer program product for providing an extended capability to a system
TWI385669B (zh) * 2008-07-23 2013-02-11 Phison Electronics Corp 用於快閃記憶體的平均磨損方法、儲存系統與控制器
US20100064093A1 (en) * 2008-09-09 2010-03-11 Radoslav Danilak System, method, and computer program product for converting data in a binary representation to a non-power of two representation
CN101354681B (zh) * 2008-09-23 2010-12-01 美商威睿电通公司 存储器系统、非易失性存储器的磨损均衡方法及装置
TWI470428B (zh) * 2008-10-03 2015-01-21 Phison Electronics Corp 用於非揮發性記憶體的資料程式規劃系統、記憶體管理方法及其控制器
US8001318B1 (en) * 2008-10-28 2011-08-16 Netapp, Inc. Wear leveling for low-wear areas of low-latency random read memory
KR101548175B1 (ko) * 2008-11-05 2015-08-28 삼성전자주식회사 싱글 레벨 메모리 셀 블락과 멀티 레벨 메모리 셀 블락을 포함하는 불휘발성 메모리 장치의 마모 레벨링 방법
US9063874B2 (en) * 2008-11-10 2015-06-23 SanDisk Technologies, Inc. Apparatus, system, and method for wear management
US9170897B2 (en) 2012-05-29 2015-10-27 SanDisk Technologies, Inc. Apparatus, system, and method for managing solid-state storage reliability
US8825940B1 (en) 2008-12-02 2014-09-02 Siliconsystems, Inc. Architecture for optimizing execution of storage access commands
US20100146236A1 (en) * 2008-12-08 2010-06-10 Radoslav Danilak System, method, and computer program product for rendering at least a portion of data useless in immediate response to a delete command
KR101033465B1 (ko) * 2008-12-30 2011-05-09 주식회사 하이닉스반도체 플래쉬 메모리 장치 및 및 이를 위한 리드동작 제어 방법
US8694718B2 (en) 2008-12-30 2014-04-08 Micron Technology, Inc. Wear leveling for erasable memories
US8094500B2 (en) 2009-01-05 2012-01-10 Sandisk Technologies Inc. Non-volatile memory and method with write cache partitioning
US8700840B2 (en) 2009-01-05 2014-04-15 SanDisk Technologies, Inc. Nonvolatile memory with write cache having flush/eviction methods
US8040744B2 (en) 2009-01-05 2011-10-18 Sandisk Technologies Inc. Spare block management of non-volatile memories
US8244960B2 (en) 2009-01-05 2012-08-14 Sandisk Technologies Inc. Non-volatile memory and method with write cache partition management methods
US9176859B2 (en) * 2009-01-07 2015-11-03 Siliconsystems, Inc. Systems and methods for improving the performance of non-volatile memory operations
US8120966B2 (en) * 2009-02-05 2012-02-21 Aplus Flash Technology, Inc. Method and apparatus for management of over-erasure in NAND-based NOR-type flash memory
TWI409819B (zh) * 2009-03-03 2013-09-21 Silicon Motion Inc 平均地使用一快閃記憶體的複數個區塊之方法以及相關之記憶裝置及其控制器
US10079048B2 (en) * 2009-03-24 2018-09-18 Western Digital Technologies, Inc. Adjusting access of non-volatile semiconductor memory based on access time
US8090905B2 (en) * 2009-03-27 2012-01-03 Sandforce, Inc. System, method, and computer program product for converting logical block address de-allocation information in a first format to a second format
US8230159B2 (en) 2009-03-27 2012-07-24 Lsi Corporation System, method, and computer program product for sending logical block address de-allocation status information
US20100250830A1 (en) * 2009-03-27 2010-09-30 Ross John Stenfort System, method, and computer program product for hardening data stored on a solid state disk
US8671258B2 (en) 2009-03-27 2014-03-11 Lsi Corporation Storage system logical block address de-allocation management
US8166258B2 (en) * 2009-07-24 2012-04-24 Lsi Corporation Skip operations for solid state disks
US8245112B2 (en) * 2009-06-04 2012-08-14 Lsi Corporation Flash memory organization
US20100306451A1 (en) * 2009-06-01 2010-12-02 Joshua Johnson Architecture for nand flash constraint enforcement
US9063561B2 (en) * 2009-05-06 2015-06-23 Avago Technologies General Ip (Singapore) Pte. Ltd. Direct memory access for loopback transfers in a media controller architecture
US8321639B2 (en) * 2009-12-30 2012-11-27 Lsi Corporation Command tracking for direct access block storage devices
US8555141B2 (en) * 2009-06-04 2013-10-08 Lsi Corporation Flash memory organization
US8219776B2 (en) * 2009-09-23 2012-07-10 Lsi Corporation Logical-to-physical address translation for solid state disks
US8516264B2 (en) * 2009-10-09 2013-08-20 Lsi Corporation Interlocking plain text passwords to data encryption keys
US8051241B2 (en) 2009-05-07 2011-11-01 Seagate Technology Llc Wear leveling technique for storage devices
US8250282B2 (en) * 2009-05-14 2012-08-21 Micron Technology, Inc. PCM memories for storage bus interfaces
US20110004718A1 (en) * 2009-07-02 2011-01-06 Ross John Stenfort System, method, and computer program product for ordering a plurality of write commands associated with a storage device
US9792074B2 (en) * 2009-07-06 2017-10-17 Seagate Technology Llc System, method, and computer program product for interfacing one or more storage devices with a plurality of bridge chips
US8140712B2 (en) * 2009-07-17 2012-03-20 Sandforce, Inc. System, method, and computer program product for inserting a gap in information sent from a drive to a host device
US8516166B2 (en) * 2009-07-20 2013-08-20 Lsi Corporation System, method, and computer program product for reducing a rate of data transfer to at least a portion of memory
US8447915B2 (en) * 2009-07-23 2013-05-21 Hitachi, Ltd. Flash memory device for allocating physical blocks to logical blocks based on an erase count
US8108737B2 (en) * 2009-10-05 2012-01-31 Sandforce, Inc. System, method, and computer program product for sending failure information from a serial ATA (SATA) solid state drive (SSD) to a host device
TWI436369B (zh) * 2009-11-13 2014-05-01 Silicon Motion Inc 記憶裝置之使用壽命量測方法及系統內編程碼置換方法、及其資料儲存系統
JP4912456B2 (ja) * 2009-12-17 2012-04-11 株式会社日立製作所 ストレージ装置及びその制御方法
US8856488B2 (en) * 2010-02-11 2014-10-07 Memory Technologies Llc Method for utilizing a memory interface to control partitioning of a memory module
CN102201259A (zh) * 2010-03-24 2011-09-28 建兴电子科技股份有限公司 非易失性存储器的平均抹写方法
US9104546B2 (en) * 2010-05-24 2015-08-11 Silicon Motion Inc. Method for performing block management using dynamic threshold, and associated memory device and controller thereof
CN102543177B (zh) * 2010-12-17 2016-01-06 西安奇维测控科技有限公司 一种固态盘静态磨损平衡算法
CN102592676A (zh) * 2011-01-17 2012-07-18 上海华虹集成电路有限责任公司 一种可回收使用的Nandflash存储系统
US10049040B2 (en) 2011-01-21 2018-08-14 Seagate Technology Llc Just in time garbage collection
US8874872B2 (en) 2011-01-21 2014-10-28 Seagate Technology Llc Garbage collection management in memories
CN102637145B (zh) * 2011-02-11 2015-06-17 慧荣科技股份有限公司 用来进行区块管理的方法、记忆装置及其控制器
US8947941B2 (en) * 2012-02-09 2015-02-03 Densbits Technologies Ltd. State responsive operations relating to flash memory cells
US9116792B2 (en) * 2012-05-18 2015-08-25 Silicon Motion, Inc. Data storage device and method for flash block management
US8930612B2 (en) * 2012-05-31 2015-01-06 Seagate Technology Llc Background deduplication of data sets in a memory
JP2013254357A (ja) * 2012-06-07 2013-12-19 Sony Corp 情報処理装置および方法、並びにプログラム
US8898405B2 (en) * 2012-06-12 2014-11-25 Storart Technology Co. Ltd Method for static wear leveling in non-violate storage device
US8750045B2 (en) 2012-07-27 2014-06-10 Sandisk Technologies Inc. Experience count dependent program algorithm for flash memory
CN102866863B (zh) * 2012-08-23 2016-09-21 深圳Tcl新技术有限公司 嵌入式多媒体卡数据迁移方法、系统层和嵌入式设备
CN102880556B (zh) * 2012-09-12 2015-05-20 浙江大学 一种实现Nand Flash磨损均衡的方法及其系统
US9013922B2 (en) * 2012-09-20 2015-04-21 Silicon Motion, Inc. Data storage device and flash memory control method thereof
US9430339B1 (en) 2012-12-27 2016-08-30 Marvell International Ltd. Method and apparatus for using wear-out blocks in nonvolatile memory
US9292451B2 (en) 2013-02-19 2016-03-22 Qualcomm Incorporated Methods and apparatus for intra-set wear-leveling for memories with limited write endurance
US9348743B2 (en) 2013-02-21 2016-05-24 Qualcomm Incorporated Inter-set wear-leveling for caches with limited write endurance
US9117533B2 (en) * 2013-03-13 2015-08-25 Sandisk Technologies Inc. Tracking erase operations to regions of non-volatile memory
US9153331B2 (en) * 2013-03-13 2015-10-06 Sandisk Technologies Inc. Tracking cell erase counts of non-volatile memory
US9336129B2 (en) 2013-10-02 2016-05-10 Sandisk Technologies Inc. System and method for bank logical data remapping
KR102291507B1 (ko) * 2014-05-20 2021-08-20 삼성전자주식회사 메모리 컨트롤러의 동작 방법
CN105489246B (zh) * 2014-09-16 2018-10-19 华邦电子股份有限公司 Nor闪存及其修补方法
US9728278B2 (en) 2014-10-24 2017-08-08 Micron Technology, Inc. Threshold voltage margin analysis
US9934872B2 (en) * 2014-10-30 2018-04-03 Sandisk Technologies Llc Erase stress and delta erase loop count methods for various fail modes in non-volatile memory
US9830087B2 (en) * 2014-11-13 2017-11-28 Micron Technology, Inc. Memory wear leveling
US10338817B2 (en) 2014-12-30 2019-07-02 Sandisk Technologies Llc Systems and methods for storage recovery
US9766819B2 (en) 2014-12-30 2017-09-19 Sandisk Technologies Llc Systems and methods for managing storage endurance
US9934858B2 (en) 2015-04-30 2018-04-03 Sandisk Technologies Llc Use of dummy word lines for metadata storage
US10101939B2 (en) * 2016-03-09 2018-10-16 Toshiba Memory Corporation Storage system having a host that manages physical data locations of a storage device
CN107589914A (zh) * 2017-09-25 2018-01-16 青岛海信移动通信技术股份有限公司 数据存储方法及装置
US10552145B2 (en) * 2017-12-12 2020-02-04 Cypress Semiconductor Corporation Memory devices, systems, and methods for updating firmware with single memory device
US10261692B1 (en) * 2017-12-20 2019-04-16 Winbond Electronics Corp. Non-volatile memory and erase controlling method thereof
US10884889B2 (en) 2018-06-22 2021-01-05 Seagate Technology Llc Allocating part of a raid stripe to repair a second raid stripe
US10866747B2 (en) 2019-02-10 2020-12-15 Hewlett Packard Enterprise Development Lp Securing a memory drive
KR20200114482A (ko) * 2019-03-28 2020-10-07 에스케이하이닉스 주식회사 컨트롤러, 이를 포함하는 메모리 시스템 및 메모리 시스템의 동작 방법
US11366597B2 (en) * 2020-01-27 2022-06-21 Western Digital Technologies, Inc. Storage system and method for maintaining uniform hot count distribution using smart stream block exchange
US11640259B2 (en) 2020-05-21 2023-05-02 Western Digital Technologies, Inc. Use of surplus erase block pairs in super block formation
US11494299B2 (en) 2021-02-18 2022-11-08 Silicon Motion, Inc. Garbage collection operation management with early garbage collection starting point
US20220300184A1 (en) * 2021-03-19 2022-09-22 Silicon Motion, Inc. Method of performing wear-leveling operation in flash memory and related controller and storage system
KR20230059910A (ko) * 2021-10-26 2023-05-04 삼성전자주식회사 컨트롤러, 스토리지 장치 및 스토리지 장치의 동작 방법

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH06111588A (ja) * 1992-09-22 1994-04-22 Internatl Business Mach Corp <Ibm> 一括消去型不揮発性メモリ
JPH0816482A (ja) * 1994-06-29 1996-01-19 Hitachi Ltd フラッシュメモリを用いた記憶装置およびその記憶制御方法
JPH0877074A (ja) * 1994-09-09 1996-03-22 Hitachi Ltd フラッシュメモリを用いた記憶装置システム
JP2000222887A (ja) * 1999-02-02 2000-08-11 Mitsubishi Electric Corp メモリ装置のデータ更新方法
US6230233B1 (en) * 1991-09-13 2001-05-08 Sandisk Corporation Wear leveling techniques for flash EEPROM systems
WO2001084321A1 (en) * 2000-05-04 2001-11-08 Koninklijke Philips Electronics N.V. Method, system and computer program for data management on storage medium

Family Cites Families (30)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH07109717B2 (ja) 1986-05-31 1995-11-22 キヤノン株式会社 メモリ書き込み制御方法
JP2685173B2 (ja) 1986-05-31 1997-12-03 キヤノン株式会社 メモリ書き込み制御方法
US5268870A (en) * 1988-06-08 1993-12-07 Eliyahou Harari Flash EEPROM system and intelligent programming and erasing methods therefor
EP0618535B1 (en) * 1989-04-13 1999-08-25 SanDisk Corporation EEPROM card with defective cell substitution and cache memory
US5222109A (en) * 1990-12-28 1993-06-22 Ibm Corporation Endurance management for solid state files
US5438573A (en) * 1991-09-13 1995-08-01 Sundisk Corporation Flash EEPROM array data and header file structure
JP2856621B2 (ja) * 1993-02-24 1999-02-10 インターナショナル・ビジネス・マシーンズ・コーポレイション 一括消去型不揮発性メモリおよびそれを用いる半導体ディスク装置
US5388083A (en) * 1993-03-26 1995-02-07 Cirrus Logic, Inc. Flash memory mass storage architecture
US5426893A (en) * 1994-05-26 1995-06-27 Hoffman; Robert E. Reinforced sectional storm panel
US5954828A (en) * 1995-01-05 1999-09-21 Macronix International Co., Ltd. Non-volatile memory device for fault tolerant data
US5568423A (en) * 1995-04-14 1996-10-22 Unisys Corporation Flash memory wear leveling system providing immediate direct access to microprocessor
US5845313A (en) * 1995-07-31 1998-12-01 Lexar Direct logical block addressing flash memory mass storage architecture
US5907856A (en) * 1995-07-31 1999-05-25 Lexar Media, Inc. Moving sectors within a block of information in a flash memory mass storage architecture
US6125435A (en) * 1995-09-13 2000-09-26 Lexar Media, Inc. Alignment of cluster address to block addresses within a semiconductor non-volatile mass storage memory
US5835935A (en) * 1995-09-13 1998-11-10 Lexar Media, Inc. Method of and architecture for controlling system data with automatic wear leveling in a semiconductor non-volatile mass storage memory
US5933847A (en) * 1995-09-28 1999-08-03 Canon Kabushiki Kaisha Selecting erase method based on type of power supply for flash EEPROM
US5860082A (en) * 1996-03-28 1999-01-12 Datalight, Inc. Method and apparatus for allocating storage in a flash memory
US5715193A (en) * 1996-05-23 1998-02-03 Micron Quantum Devices, Inc. Flash memory system and method for monitoring the disturb effect on memory cell blocks due to high voltage conditions of other memory cell blocks
US5956473A (en) * 1996-11-25 1999-09-21 Macronix International Co., Ltd. Method and system for managing a flash memory mass storage system
US6009496A (en) * 1997-10-30 1999-12-28 Winbond Electronics Corp. Microcontroller with programmable embedded flash memory
KR100297986B1 (ko) * 1998-03-13 2001-10-25 김영환 플래쉬 메모리 셀 어레이의 웨어 레벨링 시스템 및 웨어 레벨링 방법
CN1126037C (zh) 1998-09-04 2003-10-29 奥托·穆勒 用于具有限制删除频率的存储器的存取控制的方法
US6226759B1 (en) * 1998-09-28 2001-05-01 International Business Machines Corporation Method and apparatus for immediate data backup by duplicating pointers and freezing pointer/data counterparts
US6260156B1 (en) * 1998-12-04 2001-07-10 Datalight, Inc. Method and system for managing bad areas in flash memory
US6282605B1 (en) * 1999-04-26 2001-08-28 Moore Computer Consultants, Inc. File system for non-volatile computer memory
US6426893B1 (en) * 2000-02-17 2002-07-30 Sandisk Corporation Flash eeprom system with simultaneous multiple data sector programming and storage of physical block characteristics in other designated blocks
KR100644602B1 (ko) * 2000-10-11 2006-11-10 삼성전자주식회사 플래시메모리를 위한 재사상 제어방법 및 그에 따른플래시 메모리의 구조
JP2002251884A (ja) * 2001-02-21 2002-09-06 Toshiba Corp 半導体記憶装置及びそのシステム装置
US6732221B2 (en) * 2001-06-01 2004-05-04 M-Systems Flash Disk Pioneers Ltd Wear leveling of static areas in flash memory
US6683817B2 (en) * 2002-02-21 2004-01-27 Qualcomm, Incorporated Direct memory swapping between NAND flash and SRAM with error correction coding

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6230233B1 (en) * 1991-09-13 2001-05-08 Sandisk Corporation Wear leveling techniques for flash EEPROM systems
JPH06111588A (ja) * 1992-09-22 1994-04-22 Internatl Business Mach Corp <Ibm> 一括消去型不揮発性メモリ
JPH0816482A (ja) * 1994-06-29 1996-01-19 Hitachi Ltd フラッシュメモリを用いた記憶装置およびその記憶制御方法
JPH0877074A (ja) * 1994-09-09 1996-03-22 Hitachi Ltd フラッシュメモリを用いた記憶装置システム
JP2000222887A (ja) * 1999-02-02 2000-08-11 Mitsubishi Electric Corp メモリ装置のデータ更新方法
WO2001084321A1 (en) * 2000-05-04 2001-11-08 Koninklijke Philips Electronics N.V. Method, system and computer program for data management on storage medium

Also Published As

Publication number Publication date
US20040177212A1 (en) 2004-09-09
EP1559112A1 (en) 2005-08-03
DE60317551D1 (de) 2007-12-27
US7287118B2 (en) 2007-10-23
DE60317551T2 (de) 2008-09-18
ATE378684T1 (de) 2007-11-15
EP1559112B1 (en) 2007-11-14
CN1701389A (zh) 2005-11-23
TWI247292B (en) 2006-01-11
JP2006504220A (ja) 2006-02-02
TW200416707A (en) 2004-09-01
KR20050067203A (ko) 2005-06-30
WO2004040584A1 (en) 2004-05-13
US20060149896A1 (en) 2006-07-06
US7035967B2 (en) 2006-04-25
AU2003270449A1 (en) 2004-05-25

Similar Documents

Publication Publication Date Title
JP4758648B2 (ja) 不揮発性記憶システムにおける平均消去カウントの維持
JP4372013B2 (ja) 不揮発性記憶システムにおける消去カウントの維持
JP4445394B2 (ja) 消去カウントブロックを管理する方法および装置
JP4456486B2 (ja) 不揮発性記憶システムにおける摩耗一様化
EP1559113B1 (en) Tracking the most frequently erased blocks in non-volatile storage systems
US7096313B1 (en) Tracking the least frequently erased blocks in non-volatile memory systems
JP2006515086A (ja) ブロック内のページをグループ化する方法及び装置

Legal Events

Date Code Title Description
A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20060911

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20090311

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20090327

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20090626

A602 Written permission of extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A602

Effective date: 20090703

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20090724

A602 Written permission of extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A602

Effective date: 20090731

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20090825

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20091125

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20100224

A602 Written permission of extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A602

Effective date: 20100303

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20100324

A602 Written permission of extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A602

Effective date: 20100331

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20100423

A602 Written permission of extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A602

Effective date: 20100506

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20100525

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20100809

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20101021

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: 20110506

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20110603

R150 Certificate of patent or registration of utility model

Free format text: JAPANESE INTERMEDIATE CODE: R150

Ref document number: 4758648

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

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

Free format text: PAYMENT UNTIL: 20140610

Year of fee payment: 3

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

Free format text: PAYMENT UNTIL: 20140610

Year of fee payment: 3

S111 Request for change of ownership or part of ownership

Free format text: JAPANESE INTERMEDIATE CODE: R313113

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

Free format text: PAYMENT UNTIL: 20140610

Year of fee payment: 3

R360 Written notification for declining of transfer of rights

Free format text: JAPANESE INTERMEDIATE CODE: R360

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

Free format text: PAYMENT UNTIL: 20140610

Year of fee payment: 3

R370 Written measure of declining of transfer procedure

Free format text: JAPANESE INTERMEDIATE CODE: R370

S111 Request for change of ownership or part of ownership

Free format text: JAPANESE INTERMEDIATE CODE: R313113

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

Free format text: PAYMENT UNTIL: 20140610

Year of fee payment: 3

R350 Written notification of registration of transfer

Free format text: JAPANESE INTERMEDIATE CODE: R350

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

S533 Written request for registration of change of name

Free format text: JAPANESE INTERMEDIATE CODE: R313533

R350 Written notification of registration of transfer

Free format text: JAPANESE INTERMEDIATE CODE: R350

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

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

S111 Request for change of ownership or part of ownership

Free format text: JAPANESE INTERMEDIATE CODE: R313113

R350 Written notification of registration of transfer

Free format text: JAPANESE INTERMEDIATE CODE: R350

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

EXPY Cancellation because of completion of term