JP2014167790A - 不揮発性メモリへの書き込みの管理および領域選択 - Google Patents

不揮発性メモリへの書き込みの管理および領域選択 Download PDF

Info

Publication number
JP2014167790A
JP2014167790A JP2014008182A JP2014008182A JP2014167790A JP 2014167790 A JP2014167790 A JP 2014167790A JP 2014008182 A JP2014008182 A JP 2014008182A JP 2014008182 A JP2014008182 A JP 2014008182A JP 2014167790 A JP2014167790 A JP 2014167790A
Authority
JP
Japan
Prior art keywords
data
write
lba
host
nvm
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
JP2014008182A
Other languages
English (en)
Other versions
JP6387231B2 (ja
JP2014167790A5 (ja
Inventor
T Cohen Earl
コーエン、アール、ティー.
Lawrence Canepa Timothy
カネパ、ティモシー、ローレンス.
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.)
LSI Corp
Original Assignee
LSI 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 LSI Corp filed Critical LSI Corp
Publication of JP2014167790A publication Critical patent/JP2014167790A/ja
Publication of JP2014167790A5 publication Critical patent/JP2014167790A5/ja
Application granted granted Critical
Publication of JP6387231B2 publication Critical patent/JP6387231B2/ja
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0608Saving storage space on storage systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0614Improving the reliability of storage systems
    • G06F3/0619Improving the reliability of storage systems in relation to data integrity, e.g. data losses, bit errors
    • 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
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0614Improving the reliability of storage systems
    • G06F3/0616Improving the reliability of storage systems in relation to life time, e.g. increasing Mean Time Between Failures [MTBF]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0638Organizing or formatting or addressing of data
    • G06F3/064Management of blocks
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0653Monitoring storage devices or systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/0671In-line storage system
    • G06F3/0673Single storage device
    • G06F3/0679Non-volatile semiconductor memory device, e.g. flash memory, one time programmable memory [OTP]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/10Providing a specific technical effect
    • G06F2212/1016Performance improvement
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2212/00Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
    • G06F2212/10Providing a specific technical effect
    • G06F2212/1041Resource optimization
    • G06F2212/1044Space efficiency improvement
    • 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/7201Logical to physical mapping or translation of blocks or pages
    • 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/7202Allocation control and policies
    • 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/7208Multiple device management, e.g. distributing data over multiple flash devices
    • 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

Abstract

【課題】SSDの不揮発性メモリへの書き込みの管理および領域選択が、SSDの性能、信頼性、単価、および/または開発コストを改善する。
【解決手段】コントローラが書き込みを受け取り、(例えば、書き込みデータ、書き込みデータソースを分析することにより、かつ/またはヒントを受け取ることにより)書き込みの特性を決定し、決定した特性および不揮発性メモリの領域の特性に基づいて領域を選択する。例えば、コントローラは、読み取り専用データであると決定された書き込みを受け取り、書き込み障害を有する可能性の高いセルを含む不揮発性メモリの領域を選択する。読み取り専用データを書き込み障害が発生しやすい領域に配置することによって、誤りの可能性が低減され、よって、信頼性が改善される。別の例として、コントローラは、圧縮不能であると示唆された書き込みを受け取り、圧縮不能データを含む不揮発性メモリの領域を選択する。
【選択図】図7

Description

関連出願の相互参照
本出願の優先権利益の主張を、(それがある場合には、適宜)添付の出願データシート、請求、または送達状において行う。本出願の種類によって許容される範囲内で、本出願はこの参照によりあらゆる目的で以下の出願を組み込むものであり、以下の出願はすべて、発明がなされた時点において本出願と所有者を同じくするものである。
2011年3月11日付で出願された、Hao ZHONGを筆頭発明者とする、「LDPC ERASURE DECODING FOR FLASH MEMORIES」という名称の、国際出願(整理番号第SF−10−01PCTB号および出願番号第PCT/US11/28244号)、
2011年10月26日付で出願された、Yan LIを筆頭発明者とする、「ADAPTIVE ECC TECHNIQUES FOR FLASH MEMORY BASED DATA STORAGE」という名称の、国際出願(整理番号第SF−10−03PCT号および出願番号第PCT/US11/57914号)、
2012年1月18日付で出願された、Jeremy Isaac Nathaniel WERNERを筆頭発明者とする、「HIGHER−LEVEL REDUNDANCY INFORMATION COMPUTATION」という名称の、国際出願(整理番号第SF−10−14PCT号および出願番号第PCT/US12/21682号);ならびに
2013年1月22日付で出願された、Earl T. COHENを筆頭発明者とする、「MANAGEMENT OF AND REGION SELECTION FOR WRITES TO NON−VOLATILE MEMORY」という名称の、米国仮出願(整理番号第SF−11−01号および出願番号第61/755442号)。
分野:不揮発性記憶の技術および製造における前進が、使用のコスト、収益性、性能、効率、および有用性の改善を提供するために必要とされている。
関連技術:公知である、または周知であるものとして明記されない限り、コンテキスト、定義、または比較を目的とするものを含む本明細書における技法および概念の言及は、そのような技法または概念が以前から公知であり、あるいは先行技術の一部であることの容認と解釈すべきではない。特許、特許出願、および出版物を含む、本明細書で引用されるあらゆる参照文献は(それがある場合には)、具体的に組み込まれているか否かを問わず、あらゆる目的で、この参照によりその全体が本明細書に組み込まれるものである。
本発明は多くの方法で実施されてよく、例えば、プロセス、製造品、装置、システム、組成物、ならびに、コンピュータ可読記憶媒体(ディスクといった光学的大容量記憶装置および/または磁気的大容量記憶装置、フラッシュストレージといった不揮発性記憶を有する集積回路など)や、プログラム命令が光通信リンクまたは電子通信リンク上で送られるコンピュータネットワークといったコンピュータ可読媒体として実施されてよい。詳細な説明では、上記の分野における使用のコスト、収益性、性能、効率、および有用性の改善を可能にする本発明の1若しくはそれ以上の実施形態の説明を行う。詳細な説明は、詳細な説明の残りの部分の理解を容易にするための概説を含む。概説は、本明細書で説明する概念に従うシステム、方法、製造品、およびコンピュータ可読媒体の1若しくはそれ以上の例示的実施形態を含む。結論の項でより詳細に論じるように、本発明は、発行される特許請求の範囲内のあらゆる可能な改変形態および変形形態を包含するものである。
図1Aは、不揮発性メモリの領域への書き込みの管理および領域選択を行うソリッドステートディスク(Solid−State Disk:SSD)コントローラを含むSSDの実施形態の選択された詳細を示す図である。 図1Bは、図1AのSSDの1若しくはそれ以上のインスタンスを含むシステムの様々な実施形態の選択された詳細を示す図である。 図2は、論理ブロックアドレス(Logical Block Address:LBA)の論理ページ番号(Logical Page Number:LPN)部分のマッピングの実施形態の選択された詳細を示す図である。 図3は、読み出し単位の量として測った長さを総体として有する、様々な読み出し単位数として編成された読み出しデータを生成するための読み出し単位アドレスのところの不揮発性メモリ(Non−Volatile Memory:NVM)へのアクセスの実施形態の選択された詳細を示す図である。 図4Aは、読み出し単位の実施形態の選択された詳細を示す図である。 図4Bは、読み出し単位の別の実施形態の選択された詳細を示す図である。 図5は、いくつかのフィールドを有するヘッダの実施形態の選択された詳細を示す図である。 図6は、複数のNVMデバイスのブロック、ページ、および読み出し単位の実施形態の選択された詳細を示す図である。 図7は、SSDのNVMの特定のバンドにデータを選択的に配置するSSDの実施形態の選択された詳細を概念的に示す図である。 図8は、第1レベルマップ(First−Level Map:FLM)および1若しくはそれ以上の第2レベルマップ(Second−Level Map:SLM)ページを有する2レベルマップによるLBAのNVMに記憶された論理ブロック(Logical Blocks:LBs)へのマッピングの実施形態の選択された詳細を示す図である。 図9は、(例えばSSDの)NVMのデータバンドのバンド管理フローの実施形態の選択された詳細を示す流れ図である。
図面の参照符号の一覧
Figure 2014167790
Figure 2014167790
Figure 2014167790
Figure 2014167790
本発明の1若しくはそれ以上の実施形態の詳細な説明を、以下で、本発明の選択された詳細を図示する添付の図を併用して行う。本発明を実施形態との関連で説明する。実施形態は、本明細書では、単なる例示であると理解されるものであり、本発明は、明確に、本明細書中の実施形態のいずれか若しくは全部に、またはいずれか若しくは全部によって限定されるものではなく、本発明は、多数の代替形態、改変形態、および均等物を包含するものである。説明が単調にならないように、様々な言葉によるラベル(最初の、最後の、ある一定の、様々な、別の、他の、特定の、選択の、いくつかの、目立ったなど)が実施形態のセットを区別するために適用される場合がある。本明細書で使用する場合、そのようなラベルは、明確に、質を伝えるためのものでも、いかなる形の好みや先入観を伝えるためのものでもなく、単に、別々のセットを都合よく区別するためのものにすぎない。開示するプロセスのいくつかの動作の順序は本発明の範囲内で変更可能である。多様な実施形態がプロセス、方法、および/またはプログラム命令の各特徴の差異を説明するのに使用される場合は常に、所定の、または動的に決定される基準に従って、複数の多様な実施形態にそれぞれ対応する複数の動作モードの1つの静的選択および/または動的選択を行う他の実施形態が企図されている。以下の説明では、本発明の十分な理解を提供するために、多数の具体的詳細を示す。それらの詳細は例として示すものであり、本発明は、それらの詳細の一部または全部がなくても、特許請求の範囲に従って実施されうる。わかりやすくするために、本発明に関連した技術分野で公知の技術資料は、本発明が不必要に曖昧になることのないように詳細に説明していない。
概説
この概説は、詳細な説明のより迅速な理解を助けるために含まれるにすぎず、本発明は、(それがある場合には、明示的な例を含む)この概説で提示される概念だけに限定されるものではなく、どんな概説の段落も、必然的に、主題全体の縮約された見方であり、網羅的な、または限定的な記述であることを意味するものではない。例えば、以下の概説は、スペースおよび編成によりある一定の実施形態だけに限定される概要情報を提供するものである。特許請求の範囲が究極的にそこに導かれることになる実施形態を含む多くの他の実施形態があり、それらを本明細書の残りの部分にわたって論じる。
頭字語
以下で定義する様々な省略形(頭字語など)の少なくともいくつかは、本明細書で使用するある一定の要素を指す。
Figure 2014167790
Figure 2014167790
Figure 2014167790
様々な実施形態において、領域(データバンドなど)はSSDのNVMのブロックの被管理グループである。以下の考察では、「ブロックが1若しくはそれ以上の論理特性を有する」は、「ブロックが、1若しくはそれ以上の論理特性を有すると予測され、または有すると認められるデータに割り振られている」ことを意味するものと理解する。様々な実施形態において、ブロックは、論理特性、物理特性を有し、かつ/または1若しくはそれ以上の書き込みデータソースからのデータを含む。様々な実施形態において、バンドはもっぱら、特定の物理特性、特定の論理特性の特定の組み合わせを有するブロックだけを含み、かつ/または特定の書き込みデータソースからのデータだけを含む。
様々な実施形態において、バンドは、1若しくはそれ以上の特定の論理特性を有するブロックを含む。様々な実施形態において、特定の論理特性は、以下のうちの任意の1若しくはそれ以上である:頻繁に読み取られること、相対的により頻繁に書き込まれること(「よりホット」若しくは「ホット」であるなど)、相対的にあまり頻繁に書き込まれないこと(「よりコールド」若しくは「コールド」であるなど)、圧縮不能であること、実行可能であること、回復不能であり、電源喪失後に保存される必要があること、回復可能であり、電源喪失後に保存される必要がないこと、特定の技法若しくは鍵を使用して暗号化されること、特定の技法若しくは鍵を使用して、または特定のECC方式を用いて誤りから保護されること、再利用の対象とされること、および再利用の対象とされないこと。様々な実施形態において、第1のバンドおよび第2のバンドは、特定の第1の論理特性および特定の第2の論理特性を有すると予測され、または有すると認められるデータに割り振られたブロックを含む。
様々な実施形態において、バンドはもっぱら、特定の物理特性を有するブロックだけを含む。第1の例として、バンドはもっぱら、下位ページブロックだけを含む。第2の例として、バンドはもっぱら、上位ページブロックだけを含む。別の実施形態では、他の特定の物理特性を有するブロックを含む。
様々な実施形態において、バンドはもっぱら、特定の書き込みデータソースだけからのデータのブロックのみを含む。書き込みデータソースの例には、コンピューティングホストが提供するホストデータ、再利用によって生成されるデータ(消去されるべきブロックからの有効データなど)、SSDのコントローラなどによって行われるシステム動作によって生成されるデータ(マップデータなど)が含まれる。
様々な実施形態において、バンドを管理することは有益であり、SSDの性能、信頼性、単価および開発コストのうちの1若しくはそれ以上を改善する。例えば、書き込み障害を有する可能性の高いNVMセルを含むブロックは、コールドバンドに割り振られ、よって信頼性が改善される。別の例としては、SLCとして構成され、または代替使用されるNVMセルを含むブロックは、システムデータ(マップデータなど)に割り振られる。
例示的実施形態
詳細な説明の概説を終えるにあたり、以下に、例示的実施形態をまとめて示す。これらの例示的実施形態は、少なくとも部分的に「EC」(Example Combinations:ECs)として明示的に列挙されたものを有し、本明細書で説明する概念に従った様々な種類の実施形態の詳細な説明を提供するものである。これらの例は、相互排他的であることも、網羅的であることも、限定的であることも意図されておらず、本発明は、これらの例示的実施形態だけに限定されるものではなく、発行される特許請求の範囲およびその均等物の範囲内のすべての可能な改変形態および変形形態を包含するものである。
EC1)方法であって、
ホストから受け取った書き込みを分析して書き込みの特性を決定する工程と、
少なくとも部分的に特性に基づいて不揮発性メモリ(NVM)の複数のバンドのうちの1つを選択する工程と、
書き込みのデータを選択したバンドに書き込む工程と
を有し、
前記バンドの各々はNVMの被管理部分である方法。
EC2)EC1記載の方法において、前記特性は書き込みのデータが圧縮可能であることを有する方法。
EC3)EC1記載の方法において、前記特性は書き込みのデータが実行可能であることを有する方法。
EC4)EC1記載の方法において、前記特性は、少なくとも部分的に、前記書き込みに対応する論理ブロックアドレス(LBA)と関連付けられたカウンタに基づくものである方法。
EC5)EC4記載の方法において、さらに、
前記カウンタによって前記LBAへの書き込み回数をカウントする工程を有するものである方法。
EC6)EC4記載の方法において、さらに
前記カウンタによって前記LBAの読み取り回数と前記LBAの書き込み回数との差をカウントする工程を有するものである方法。
EC7)EC1記載の方法において、前記バンドの各々は1若しくはそれ以上のR−ブロックを有する方法。
EC8)EC1記載の方法において、前記バンドの各々はNVMの1若しくはそれ以上のブロックを有する方法。
EC9)EC1記載の方法において、前記バンドの各々は複数の論理特性のうちの少なくとも1つに対応するものであり、前記論理特性は、頻繁に読み取られること、相対的により頻繁に書き込まれること、相対的にあまり頻繁に書き込まれないこと、圧縮不能であること、実行可能であること、回復不能であり、電源喪失後に保存される必要があること、回復可能であり、電源喪失後に保存される必要がないこと、特定の技法若しくは鍵を使用して暗号化されること、特定の技法若しくは鍵を使用して、または特定の誤り訂正符号(ECC)方式を用いて誤りから保護されること、再利用の対象とされること、および再利用の対象とされないことを有する方法。
EC10)EC1記載の方法において、さらに、
前記バンドのうちの第1のバンドからのデータを前記バンドのうちの第2のバンドに再利用する工程を有するものであり、前記第2のバンドは、ホストによって直接書き込まれたデータと前記第1のバンドから再利用されたデータの両方を含む方法。
EC11)EC1記載の方法において、前記書き込みは、1若しくはそれ以上のストレージインターフェース規格と適合するストレージインターフェースを介して前記ホストから受け取られる方法。
EC12)EC1記載の方法において、前記データを書き込む工程は、少なくとも部分的に、前記NVMと通信するフラッシュ・メモリ・インターフェースを介したものである方法。
EC13)EC1記載の方法において、前記NVMは少なくとも1つのフラッシュメモリを有する方法。
EC14)EC1記載の方法において、
前記書き込みは、1若しくはそれ以上のストレージインターフェース規格と適合するストレージインターフェースを介して前記ホストから受け取られ、
前記データを書き込む工程は、少なくとも部分的に、前記NVMと通信するフラッシュ・メモリ・インターフェースを介したものであり、
前記NVMは少なくとも1つのフラッシュメモリを有し、
前記ストレージインターフェースおよび前記フラッシュ・メモリ・インターフェースは単一の集積回路に実装されたコントローラに具備される方法。
EC15)システムであって、
ホストから受け取った書き込みを分析して書き込みの特性を決定する手段と、
少なくとも部分的に特性に基づいて不揮発性メモリ(NVM)の複数のバンドのうちの1つを選択する手段と、
書き込みのデータを選択したバンドに書き込む手段と
を有し、
バンドの各々はNVMの被管理部分であるシステム。
EC16)EC15記載のシステムにおいて、前記特性は、書き込みのデータが圧縮可能であることを有するシステム。
EC17)EC15記載のシステムにおいて、前記特性は、書き込みのデータが実行可能であることを有するシステム。
EC18)EC15記載のシステムにおいて、前記特性は、少なくとも部分的に、前記書き込みに対応する論理ブロックアドレス(LBA)と関連付けられたカウンタに基づくものであるシステム。
EC19)EC18記載のシステムにおいて、さらに、
前記カウンタによって前記LBAへの書き込み回数をカウントする手段を有するものであるシステム。
EC20)EC18記載のシステムにおいて、さらに、
前記カウンタによって前記LBAの読み取り回数と前記LBAの書き込み回数との差をカウントする手段を有するものであるシステム。
EC21)EC15記載のシステムにおいて、前記バンドの各々は1若しくはそれ以上のR−ブロックを有するシステム。
EC22)EC15記載のシステムにおいて、前記バンドの各々は前記NVMの1若しくはそれ以上のブロックを有するシステム。
EC23)EC15記載のシステムにおいて、前記バンドの各々は複数の論理特性のうちの少なくとも1つに対応するものであり、前記論理特性は、頻繁に読み取られること、相対的により頻繁に書き込まれること、相対的にあまり頻繁に書き込まれないこと、圧縮不能であること、実行可能であること、回復不能であり、電源喪失後に保存される必要があること、回復可能であり、電源喪失後に保存される必要がないこと、特定の技法若しくは鍵を使用して暗号化されること、特定の技法若しくは鍵を使用して、または特定の誤り訂正符号(ECC)方式を用いて誤りから保護されること、再利用の対象とされること、および再利用の対象とされないことを有するシステム。
EC24)EC15記載のシステムにおいて、さらに、
前記バンドのうちの第1のバンドからのデータを前記バンドのうちの第2のバンドに再利用する手段を有するものであり、前記第2のバンドは、前記ホストによって直接書き込まれたデータと前記第1のバンドから再利用されたデータの両方を含むシステム。
EC25)EC15記載のシステムにおいて、前記書き込みは、1若しくはそれ以上のストレージインターフェース規格と適合するストレージインターフェースを介して前記ホストから受け取られるシステム。
EC26)EC15記載のシステムにおいて、前記データを書き込む手段は、前記NVMと通信するフラッシュ・メモリ・インターフェースを有するシステム。
EC27)EC15記載のシステムにおいて、前記NVMは少なくとも1つのフラッシュメモリを有するシステム。
EC28)EC15記載のシステムにおいて、
前記書き込みは、1若しくはそれ以上のストレージインターフェース規格と適合するストレージインターフェースを介してホストから受け取られ、
前記データを書き込む手段は、前記NVMと通信するフラッシュ・メモリ・インターフェースを有し、
前記NVMは少なくとも1つのフラッシュメモリを有し、
前記ストレージインターフェースおよび前記フラッシュ・メモリ・インターフェースは単一の集積回路に実装されたコントローラに具備されるシステム。
EC29)処理要素によって実行されると、処理要素に動作を実行させ、かつ/または制御させる命令のセットが記憶されている有形のコンピュータ可読媒体であって、動作は、
ホストから受け取った書き込みを分析して書き込みの特性を決定する動作と、
少なくとも部分的に特性に基づいて不揮発性メモリ(NVM)の複数のバンドのうちの1つを選択する動作と、
書き込みのデータを選択したバンドに書き込む動作と
を有し、
前記バンドの各々はNVMの被管理部分である有形のコンピュータ可読媒体。
EC30)EC29記載の前記有形のコンピュータ可読媒体において、前記特性は、前記書き込みのデータが圧縮可能であることを有する有形のコンピュータ可読媒体。
EC31)EC29記載の前記有形のコンピュータ可読媒体において、前記特性は、前記書き込みのデータが実行可能であることを有する有形のコンピュータ可読媒体。
EC32)EC29記載の有形のコンピュータ可読媒体において、特性は、少なくとも部分的に、書き込みに対応する論理ブロックアドレス(LBA)と関連付けられたカウンタに基づくものである有形のコンピュータ可読媒体。
EC33)EC32記載の有形のコンピュータ可読媒体において、前記動作は、前記カウンタによって前記LBAへの書き込み回数をカウントする動作をさらに有するものである有形のコンピュータ可読媒体。
EC34)EC32記載の有形のコンピュータ可読媒体において、前記動作は、前記カウンタによって前記LBAの読み取り回数と前記LBAの書き込み回数との差をカウントする動作をさらに有するものである有形のコンピュータ可読媒体。
EC35)EC29記載の有形のコンピュータ可読媒体において、前記バンドの各々は1若しくはそれ以上のR−ブロックを有する有形のコンピュータ可読媒体。
EC36)EC29記載の有形のコンピュータ可読媒体において、前記バンドの各々は前記NVMの1若しくはそれ以上のブロックを有する有形のコンピュータ可読媒体。
EC37)EC29記載の有形のコンピュータ可読媒体において、前記バンドの各々は複数の論理特性のうちの少なくとも1つに対応するものであり、前記論理特性は、頻繁に読み取られること、相対的により頻繁に書き込まれること、相対的にあまり頻繁に書き込まれないこと、圧縮不能であること、実行可能であること、回復不能であり、電源喪失後に保存される必要があること、回復可能であり、電源喪失後に保存される必要がないこと、特定の技法若しくは鍵を使用して暗号化されること、特定の技法若しくは鍵を使用して、または特定の誤り訂正符号(ECC)方式を用いて誤りから保護されること、再利用の対象とされること、および再利用の対象とされないことを有する有形のコンピュータ可読媒体。
EC38)EC29記載の有形のコンピュータ可読媒体において、前記動作は、前記バンドのうちの第1のバンドからのデータを前記バンドのうちの第2のバンドに再利用する動作をさらに有するものであり、前記第2のバンドは、前記ホストによって直接書き込まれたデータと前記第1のバンドから再利用されたデータの両方を含む有形のコンピュータ可読媒体。
EC39)EC29記載の有形のコンピュータ可読媒体において、前記書き込みは、1若しくはそれ以上のストレージインターフェース規格と適合するストレージインターフェースを介して前記ホストから受け取られる有形のコンピュータ可読媒体。
EC40)EC29記載の有形のコンピュータ可読媒体において、前記データを書き込む動作は、少なくとも部分的に、前記NVMと通信するフラッシュ・メモリ・インターフェースを介したものである有形のコンピュータ可読媒体。
EC41)EC29記載の有形のコンピュータ可読媒体において、前記NVMは少なくとも1つのフラッシュメモリを有する有形のコンピュータ可読媒体。
EC42)EC29記載の有形のコンピュータ可読媒体において、
前記書き込みは、1若しくはそれ以上のストレージインターフェース規格と適合するストレージインターフェースを介して前記ホストから受け取られ、
前記データを書き込む動作は、少なくとも部分的に、前記NVMと通信するフラッシュ・メモリ・インターフェースを介したものであり、
前記NVMは少なくとも1つのフラッシュメモリを有し、
前記処理要素、前記ストレージインターフェースおよび前記フラッシュ・メモリ・インターフェースは単一の集積回路に実装されたコントローラに具備される有形のコンピュータ可読媒体。
EC43)装置であって、
ホストから受け取った書き込みを分析して書き込みの特性を決定するこ書き込み分析ハードウェア論理回路と、
少なくとも部分的に前記特性に基づいて不揮発性メモリ(NVM)の複数のバンドのうちの1つを選択するバンド選択ハードウェア論理回路と、
前記書き込みのデータを前記選択したバンドに書き込むメモリ書き込みハードウェア論理回路と
を有し、
前記バンドの各々は前記NVMの被管理部分である装置。
EC44)EC43記載の装置において、前記特性は、書き込みのデータが圧縮可能であることを有する装置。
EC45)EC43記載の装置において、前記特性は、書き込みのデータが実行可能であることを有する装置。
EC46)EC43記載の装置において、前記バンドの各々は1若しくはそれ以上のR−ブロックを有する装置。
EC47)EC43記載の装置において、前記バンドの各々は前記NVMの1若しくはそれ以上のブロックを有する装置。
EC48)EC43記載の装置において、前記バンドの各々は複数の論理特性のうちの少なくとも1つに従うものであり、前記論理特性は、頻繁に読み取られること、相対的により頻繁に書き込まれること、相対的にあまり頻繁に書き込まれないこと、圧縮不能であること、実行可能であること、回復不能であり、電源喪失後に保存される必要があること、回復可能であり、電源喪失後に保存される必要がないこと、特定の技法若しくは鍵を使用して暗号化されること、特定の技法若しくは鍵を使用して、または特定の誤り訂正符号(ECC)方式を用いて誤りから保護されること、再利用の対象とされること、および再利用の対象とされないことを有する装置。
EC49)EC43記載の装置において、さらに、
前記バンドのうちの第1のバンドからのデータを前記バンドのうちの第2のバンドに再利用するリサイクラハードウェア論理回路を有するものであり、前記第2のバンドは、前記ホストによって直接書き込まれたデータと前記第1のバンドから再利用されたデータの両方を含む装置。
EC50)EC43記載の装置において、さらに、
前記書き込みに対応する論理ブロックアドレス(LBA)と関連付けられたカウンタを有するものであり、前記特性は、少なくとも部分的に、前記カウンタに基づくものである装置。
EC51)EC50記載の装置において、前記カウンタは前記LBAへの書き込み回数をカウントする装置。
EC52)EC50記載の装置において、カウンタは、LBAの読み取り回数とLBAの書き込み回数との差をカウントする装置。
EC53)EC43記載の装置において、さらに、
1若しくはそれ以上のストレージインターフェース規格と適合するストレージインターフェースを有するものであり、前記書き込みは前記ストレージインターフェースを介して前記ホストから受け取られる装置。
EC54)EC43記載の装置において、前記メモリ書き込みハードウェア論理回路は、前記NVMと通信するフラッシュ・メモリ・インターフェースを有する装置。
EC55)EC43記載の装置において、前記NVMは少なくとも1つのフラッシュメモリを有する装置。
EC56)EC43記載の装置において、単一の集積回路に実装されたコントローラに具備された装置。
EC57)方法であって、
書き込みデータの少なくともいくつかの特性を決定する工程と、
少なくとも部分的に前記特性に基づいて、1若しくはそれ以上の不揮発性メモリ(NVM)のブロックの複数の被管理グループのうちの1つを選択する工程と、
前記書き込みデータを選択した被管理グループに書き込む工程と
を有し、
決定する工程、選択する工程、および書き込む工程は、記憶システムのコントローラによって行われ、
前記被管理グループの各々は1若しくはそれ以上の管理動作に関して管理され、前記管理動作は、再利用動作および書き込み割り振り動作のうちの任意の1若しくはそれ以上を有し、前記被管理グループの各々は、前記NVMのうちの少なくとも2つのダイによって提供される記憶を有する方法。
EC58)EC57記載の方法において、前記被管理グループの各々は前記NVMのそれぞれの管理方式に対応する方法。
EC59)EC58記載の方法において、前記それぞれの管理方式は前記それぞれの論理特性に従うものであり、前記論理特性は、頻繁に読み取られること、相対的により頻繁に書き込まれること、相対的にあまり頻繁に書き込まれないこと、圧縮不能であること、実行可能であること、回復不能であり、電源喪失後に保存される必要があること、回復可能であり、電源喪失後に保存される必要がないこと、特定の技法若しくは鍵を使用して暗号化されること、特定の技法若しくは鍵を使用して、または特定のECC方式を用いて誤りから保護されること、再利用の対象とされること、および再利用の対象とされないことを有する方法。
EC60)EC58記載の方法において、前記それぞれの管理方式はそれぞれの物理特性に従うものであり、前記物理特性は、もっぱら下位ページブロックだけを含むこと、およびもっぱら上位ページブロックだけを含むことを有する方法。
EC61)EC58記載の方法において、前記それぞれの管理方式は前記それぞれの書き込みデータソースに従うものであり、前記書き込みデータソースは、コンピューティングホストが提供するホストデータ、再利用によって生成されるデータ、およびシステム動作によって生成されるデータを有する方法。
EC62)EC57記載の方法において、前記被管理グループの各々は1若しくはそれ以上のR−ブロックを有する方法。
EC63)EC57記載の方法において、前記被管理グループの各々は前記NVMの1若しくはそれ以上のブロックを有する方法。
EC64)EC57記載の方法において、前記被管理グループの各々は複数の論理特性のうちの少なくとも1つに従うものであり、前記論理特性は、頻繁に読み取られること、相対的により頻繁に書き込まれること、相対的にあまり頻繁に書き込まれないこと、圧縮不能であること、実行可能であること、回復不能であり、電源喪失後に保存される必要があること、回復可能であり、電源喪失後に保存される必要がないこと、特定の技法若しくは鍵を使用して暗号化されること、特定の技法若しくは鍵を使用して、または特定の誤り訂正符号(ECC)方式を用いて誤りから保護されること、再利用の対象とされること、および再利用の対象とされないことを有する方法。
EC65)EC57記載の方法において、さらに、
前記被管理グループのうちの第1の被管理グループからのデータを前記被管理グループのうちの第2の被管理グループに再利用する工程を有するものであり、前記第2の被管理グループは、前記ホストによって直接書き込まれたデータと前記第1の被管理グループから再利用されたデータの両方を含む方法。
EC66)EC57記載の方法において、さらに、
前記ホストから書き込みデータを受け取る工程を有するものである方法。
EC67)EC57記載の方法において、前記書き込みデータは前記コントローラによって生成される方法。
EC68)EC57記載の方法において、前記書き込みデータは、ユーザ書き込みデータ、書き換えデータ、システムデータ、書き換えシステムデータ、および書き換えユーザデータのうちの任意の1若しくはそれ以上を有する方法。
EC69)EC68記載の方法において、前記システムデータはチェックポイントデータを有する方法。
EC70)EC57記載の方法において、前記決定する工程はヒントに応答したものである方法。
EC71)EC70記載の方法において、前記ヒントは前記ホストから受け取られる方法。
EC72)EC70記載の方法において、前記ヒントは前記書き込みデータが読み取り専用データまたは書き込み専用データのいずれか1つであることを指示する方法。
EC73)EC57記載の方法において、前記決定する工程は前記書き込みデータを分析したことに応答したものである方法。
EC74)EC73記載の方法において、前記分析は、少なくとも部分的に、ハードウェア、ソフトウェア、およびファームウェアのうちの任意の1若しくはそれ以上で行われる方法。
EC75)EC74記載の方法において、ハードウェアは、データ整理エンジン、データ重複排除エンジン、およびデータ圧縮エンジンのうちの任意の1若しくはそれ以上を有する方法。
EC76)EC57記載の方法において、前記決定する工程は、少なくとも部分的にハードウェアによって行われる方法。
EC77)EC76記載の方法において、前記ハードウェアはデータ整理エンジンを有する方法。
EC78)EC76記載の方法において、前記特性は前記書き込みデータが実行可能であることを有する方法。
EC79)EC76記載の方法において、前記特性は前記書き込みデータが圧縮不能であることを有する方法。
EC80)EC76記載の方法において、前記特性は前記書き込みデータが整理不能であることを有する方法。
EC81)EC57記載の方法において、前記特性は、前の書き込み回数、前の読み取り回数、前の読み取り対前の書き込みの比、書き込みデータが圧縮不能であるという指示、書き込みデータが圧縮可能であるという指示、書き込みデータが実行可能であるという指示、および書き込みデータが回復不能であるという指示のうちの任意の1若しくはそれ以上を有する方法。
EC82)EC57記載の方法において、前記特性は、前記被管理グループの前に選択された被管理グループのうちの任意の1若しくはそれ以上を有する方法。
EC83)EC57記載の方法において、前記被管理グループのうちの任意の1若しくはそれ以上は、前記決定する工程によって、頻繁に読み取られる、頻繁に書き込まれる、圧縮不能である、実行可能である、および回復不能である、のうちの1若しくはそれ以上として特性付けされたデータを含むブロックのうちのブロックを有する方法。
EC84)EC57記載の方法において、前記被管理グループのうちの1若しくはそれ以上は、システムデータ、ユーザデータ、および書き換えデータのうちのいずれか1つを含むブロックのうちのブロックだけを有する方法。
EC85)EC57記載の方法において、前記被管理グループのうちの1若しくはそれ以上は、システムデータ、ユーザデータ、および/または書き換えデータのうちのいずれか1つ若しくは2つを含むブロックのうちのブロックだけを有する方法。
EC86)EC57記載の方法において、前記被管理グループのうちの1若しくはそれ以上は、ブロックのうちの下位ページブロックだけまたは上位ページブロックだけの一方を有する方法。
EC87)EC57記載の方法において、前記被管理グループのうちの第1の被管理グループと第2の被管理グループとは異なる誤り訂正を有する方法。
EC88)EC57記載の方法において、前記コントローラは、少なくとも1つのストレージインターフェース規格と適合した少なくとも1つのストレージインターフェースを介してホストにインターフェースする方法。
EC89)EC57記載の方法において、前記コントローラは、少なくとも1つのフラッシュ・メモリ・インターフェースを介してダイのうちの少なくとも1つにインターフェースする方法。
EC90)EC57記載の方法において、前記NVMは少なくとも1つのフラッシュメモリを有する方法。
EC91)システムであって、
書き込みデータの少なくともいくつかの特性を決定する手段と、
少なくとも部分的に前記特性に基づいて、1若しくはそれ以上の不揮発性メモリ(NVM)のブロックの複数の被管理グループのうちの1つを選択する手段と、
前記書き込みデータを選択した被管理グループに書き込む手段と
を有し、
決定する手段、選択する手段、および書き込む手段は、記憶システムのコントローラの要素であり、
前記被管理グループの各々は1若しくはそれ以上の管理動作に関して管理され、前記管理動作は、再利用動作および書き込み割り振り動作のうちの任意の1若しくはそれ以上を有し、前記被管理グループの各々は、前記NVMのうちの少なくとも2つのダイによって提供される記憶を有するシステム。
EC92)EC91記載のシステムにおいて、前記被管理グループの各々は前記NVMのそれぞれの管理方式に対応するシステム。
EC93)EC92記載のシステムにおいて、前記それぞれの管理方式はそれぞれの論理特性に従うものであり、前記論理特性は、頻繁に読み取られること、相対的により頻繁に書き込まれること、相対的にあまり頻繁に書き込まれないこと、圧縮不能であること、実行可能であること、回復不能であり、電源喪失後に保存される必要があること、回復可能であり、電源喪失後に保存される必要がないこと、特定の技法若しくは鍵を使用して暗号化されること、特定の技法若しくは鍵を使用して、または特定のECC方式を用いて誤りから保護されること、再利用の対象とされること、および再利用の対象とされないことを有するシステム。
EC94)EC92記載のシステムにおいて、前記それぞれの管理方式は前記それぞれの物理特性に従うものであり、前記物理特性は、もっぱら下位ページブロックだけを含むこと、およびもっぱら上位ページブロックだけを含むことを有するシステム。
EC95)EC92記載のシステムにおいて、前記それぞれの管理方式は前記それぞれの書き込みデータソースに従うものであり、前記書き込みデータソースは、コンピューティングホストが提供するホストデータ、再利用によって生成されるデータ、およびシステム動作によって生成されるデータを有するシステム。
EC96)EC91記載のシステムにおいて、前記被管理グループの各々は1若しくはそれ以上のR−ブロックを有するシステム。
EC97)EC91記載のシステムにおいて、前記被管理グループの各々はNVMの1若しくはそれ以上のブロックを有するシステム。
EC98)EC91記載のシステムにおいて、前記被管理グループの各々は複数の論理特性のうちの少なくとも1つに対応するものであり、前記論理特性は、頻繁に読み取られること、相対的により頻繁に書き込まれること、相対的にあまり頻繁に書き込まれないこと、圧縮不能であること、実行可能であること、回復不能であり、電源喪失後に保存される必要があること、回復可能であり、電源喪失後に保存される必要がないこと、特定の技法若しくは鍵を使用して暗号化されること、特定の技法若しくは鍵を使用して、または特定の誤り訂正符号(ECC)方式を用いて誤りから保護されること、再利用の対象とされること、および再利用の対象とされないことを有するシステム。
EC99)EC91記載のシステムにおいて、さらに、
前記被管理グループのうちの第1の被管理グループからのデータを前記被管理グループのうちの第2の被管理グループに再利用する手段を有するものであり、前記第2の被管理グループは、前記ホストによって直接書き込まれたデータと前記第1の被管理グループから再利用されたデータの両方を含むシステム。
EC100)EC91記載のシステムにおいて、さらに、
ホストから前記書き込みデータを受け取る手段を有するものであるシステム。
EC101)EC91記載のシステムにおいて、前記書き込みデータは前記コントローラによって生成されるシステム。
EC102)EC91記載のシステムにおいて、前記書き込みデータは、ユーザ書き込みデータ、書き換えデータ、システムデータ、書き換えシステムデータ、および書き換えユーザデータのうちの任意の1若しくはそれ以上を有するシステム。
EC103)EC102記載のシステムにおいて、前記システムデータはチェックポイントデータを有するシステム。
EC104)EC91記載のシステムにおいて、前記決定する手段はヒントに応答するものであるシステム。
EC105)EC104記載のシステムにおいて、前記ヒントは前記ホストから受け取られるシステム。
EC106)EC104記載のシステムにおいて、前記ヒントは前記書き込みデータが読み取り専用データまたは書き込み専用データのいずれか1つであることを指示するシステム。
EC107)EC91記載のシステムにおいて、前記決定する手段は前記書き込みデータの分析に応答するものであるシステム。
EC108)EC107記載のシステムにおいて、前記分析は、少なくとも部分的に、ハードウェア、ソフトウェア、およびファームウェアのうちの任意の1若しくはそれ以上で行われるシステム。
EC109)EC108記載のシステムにおいて、前記ハードウェアは、データ整理エンジン、データ重複排除エンジン、およびデータ圧縮エンジンのうちの任意の1若しくはそれ以上を有するシステム。
EC110)EC91記載のシステムにおいて、前記決定する手段はデータ整理エンジンを有するシステム。
EC111)EC110記載のシステムにおいて、前記特性は書き込みデータが実行可能であることを有するシステム。
EC112)EC110記載のシステムにおいて、前記特性は書き込みデータが圧縮不能であることを有するシステム。
EC113)EC110記載のシステムにおいて、前記特性は書き込みデータが整理不能であることを有するシステム。
EC114)EC91記載のシステムにおいて、前記特性は、前の書き込み回数、前の読み取り回数、前の読み取り対前の書き込みの比、書き込みデータが圧縮不能であるという指示、書き込みデータが圧縮可能であるという指示、書き込みデータが実行可能であるという指示、および書き込みデータが回復不能であるという指示のうちの任意の1若しくはそれ以上を有するシステム。
EC115)EC91記載のシステムにおいて、前記特性は、前記被管理グループの前に選択された被管理グループのうちの任意の1若しくはそれ以上を有するシステム。
EC116)EC91記載のシステムにおいて、前記被管理グループのうちの任意の1若しくはそれ以上は、決定する手段によって、頻繁に読み取られる、頻繁に書き込まれる、圧縮不能である、実行可能である、および回復不能である、のうちの1若しくはそれ以上として特性付けされたデータを含むブロックのうちのブロックを有するシステム。
EC117)EC91記載のシステムにおいて、前記被管理グループのうちの1若しくはそれ以上は、システムデータ、ユーザデータ、および書き換えデータのうちのいずれか1つを含むブロックのうちのブロックだけを有するシステム。
EC118)EC91記載のシステムにおいて、前記被管理グループのうちの1若しくはそれ以上は、システムデータ、ユーザデータ、および/または書き換えデータのうちのいずれか1つ若しくは2つを含むブロックのうちのブロックだけを有するシステム。
EC119)EC91記載のシステムにおいて、前記被管理グループのうちの1若しくはそれ以上は、前記ブロックのうちの下位ページブロックだけまたは上位ページブロックだけ一方を有するシステム。
EC120)EC91記載のシステムにおいて、前記被管理グループのうちの第1の被管理グループと第2の被管理グループとは異なる誤り訂正を有するシステム。
EC121)EC91記載のシステムにおいて、前記コントローラは、少なくとも1つのストレージインターフェース規格と適合した少なくとも1つのストレージインターフェースを介してホストにインターフェースするシステム。
EC122)EC91記載のシステムにおいて、前記コントローラは、少なくとも1つのフラッシュ・メモリ・インターフェースを介して前記ダイのうちの少なくとも1つにインターフェースするシステム。
EC123)EC91記載のシステムにおいて、前記NVMは少なくとも1つのフラッシュメモリを有するシステム。
EC124)処理要素によって実行されると、処理要素に動作を実行させ、かつ/または制御させる命令のセットが記憶されている有形のコンピュータ可読媒体であって、動作は、
書き込みデータの少なくともいくつかの特性を決定する動作と、
少なくとも部分的に前記特性に基づいて、1若しくはそれ以上の不揮発性メモリ(NVM)のブロックの複数の被管理グループのうちの1つを選択する動作と、
書き込みデータを選択した被管理グループに書き込む動作と
を有し、
前記処理要素は記憶システムのコントローラに具備され、
前記被管理グループの各々は1若しくはそれ以上の管理動作に関して管理され、前記管理動作は、再利用動作および書き込み割り振り動作のうちの任意の1若しくはそれ以上を有し、前記被管理グループの各々は、前記NVMのうちの少なくとも2つのダイによって提供される記憶を有する有形のコンピュータ可読媒体。
EC125)EC124記載の有形のコンピュータ可読媒体において、前記被管理グループの各々は前記NVMのそれぞれの管理方式に対応する有形のコンピュータ可読媒体。
EC126)EC125記載の有形のコンピュータ可読媒体において、前記それぞれの管理方式は前記それぞれの論理特性に従うものであり、前記論理特性は、頻繁に読み取られること、相対的により頻繁に書き込まれること、相対的にあまり頻繁に書き込まれないこと、圧縮不能であること、実行可能であること、回復不能であり、電源喪失後に保存される必要があること、回復可能であり、電源喪失後に保存される必要がないこと、特定の技法若しくは鍵を使用して暗号化されること、特定の技法若しくは鍵を使用して、または特定のECC方式を用いて誤りから保護されること、再利用の対象とされること、および再利用の対象とされないことを有する有形のコンピュータ可読媒体。
EC127)EC125記載の有形のコンピュータ可読媒体において、前記それぞれの管理方式は前記それぞれの物理特性に対応するものであり、前記物理特性は、もっぱら下位ページブロックだけを含むこと、およびもっぱら上位ページブロックだけを含むことを有する有形のコンピュータ可読媒体。
EC128)EC125記載の有形のコンピュータ可読媒体において、前記それぞれの管理方式は前記それぞれの書き込みデータソースに従うものであり、前記書き込みデータソースは、コンピューティングホストが提供するホストデータ、再利用によって生成されるデータ、およびシステム動作によって生成されるデータを有する有形のコンピュータ可読媒体。
EC129)EC124記載の有形のコンピュータ可読媒体において、前記被管理グループの各々は1若しくはそれ以上のR−ブロックを有する有形のコンピュータ可読媒体。
EC130)EC124記載の有形のコンピュータ可読媒体において、前記被管理グループの各々は前記NVMの1若しくはそれ以上のブロックを有する有形のコンピュータ可読媒体。
EC131)EC124記載の有形のコンピュータ可読媒体において、前記被管理グループの各々は複数の論理特性のうちの少なくとも1つに従うものであり、前記論理特性は、頻繁に読み取られること、相対的により頻繁に書き込まれること、相対的にあまり頻繁に書き込まれないこと、圧縮不能であること、実行可能であること、回復不能であり、電源喪失後に保存される必要があること、回復可能であり、電源喪失後に保存される必要がないこと、特定の技法若しくは鍵を使用して暗号化されること、特定の技法若しくは鍵を使用して、または特定の誤り訂正符号(ECC)方式を用いて誤りから保護されること、再利用の対象とされること、および再利用の対象とされないことを有する有形のコンピュータ可読媒体。
EC132)EC124記載の有形のコンピュータ可読媒体において、前記動作は、前記被管理グループのうちの第1の被管理グループからのデータを前記被管理グループのうちの第2の被管理グループに再利用する動作をさらに有するものであり、前記第2の被管理グループは、前記ホストによって直接書き込まれたデータと前記第1の被管理グループから再利用されたデータの両方を含む有形のコンピュータ可読媒体。
EC133)EC124記載の有形のコンピュータ可読媒体において、前記動作は、前記ホストから書き込みデータを受け取る動作をさらに有するものである有形のコンピュータ可読媒体。
EC134)EC124記載の有形のコンピュータ可読媒体において、前記書き込みデータはコントローラによって生成される有形のコンピュータ可読媒体。
EC135)EC124記載の有形のコンピュータ可読媒体において、書き込みデータは、ユーザ書き込みデータ、書き換えデータ、システムデータ、書き換えシステムデータ、および書き換えユーザデータのうちの任意の1若しくはそれ以上を有する有形のコンピュータ可読媒体。
EC136)EC135記載の有形のコンピュータ可読媒体において、前記システムデータはチェックポイントデータを有する有形のコンピュータ可読媒体。
EC137)EC124記載の有形のコンピュータ可読媒体において、前記決定する動作はヒントに応答したものである有形のコンピュータ可読媒体。
EC138)EC137記載の有形のコンピュータ可読媒体において、前記ヒントは前記ホストから受け取られる有形のコンピュータ可読媒体。
EC139)EC137記載の有形のコンピュータ可読媒体において、前記ヒントは前記書き込みデータが読み取り専用データまたは書き込み専用データのいずれか1つであることを指示する有形のコンピュータ可読媒体。
EC140)EC124記載の有形のコンピュータ可読媒体において、前記決定する動作は前記書き込みデータを分析したことに応答したものである有形のコンピュータ可読媒体。
EC141)EC140記載の有形のコンピュータ可読媒体において、前記分析は、少なくとも部分的に、データ整理エンジン、データ重複排除エンジン、およびデータ圧縮エンジンのうちの任意の1若しくはそれ以上と連携して行われる有形のコンピュータ可読媒体。
EC142)EC124記載の有形のコンピュータ可読媒体において、前記特性は、前の書き込み回数、前の読み取り回数、前の読み取り対前の書き込みの比、書き込みデータが圧縮不能であるという指示、書き込みデータが圧縮可能であるという指示、書き込みデータが実行可能であるという指示、および書き込みデータが回復不能であるという指示のうちの任意の1若しくはそれ以上を有する有形のコンピュータ可読媒体。
EC143)EC124記載の有形のコンピュータ可読媒体において、前記特性は、前記被管理グループの前に選択された被管理グループのうちの任意の1若しくはそれ以上を有する有形のコンピュータ可読媒体。
EC144)EC124記載の有形のコンピュータ可読媒体において、前記被管理グループのうちの任意の1若しくはそれ以上は、決定する動作によって、頻繁に読み取られる、頻繁に書き込まれる、圧縮不能である、実行可能である、および回復不能である、のうちの1若しくはそれ以上として特性付けされたデータを含むブロックのうちのブロックを有する有形のコンピュータ可読媒体。
EC145)EC124記載の有形のコンピュータ可読媒体において、前記被管理グループのうちの1若しくはそれ以上は、システムデータ、ユーザデータ、および書き換えデータのうちのいずれか1つを含むブロックのうちのブロックだけを有する有形のコンピュータ可読媒体。
EC146)EC124記載の有形のコンピュータ可読媒体において、前記被管理グループのうちの1若しくはそれ以上は、システムデータ、ユーザデータ、および/または書き換えデータのうちのいずれか1つ若しくは2つを含むブロックのうちのブロックだけを有する有形のコンピュータ可読媒体。
EC147)EC124記載の有形のコンピュータ可読媒体において、前記被管理グループのうちの1若しくはそれ以上は、前記ブロックのうちの下位ページブロックだけまたは上位ページブロックだけの一方を有する有形のコンピュータ可読媒体。
EC148)EC124記載の有形のコンピュータ可読媒体において、前記被管理グループのうちの第1の被管理グループと第2の被管理グループとは異なる誤り訂正を有する有形のコンピュータ可読媒体。
EC149)EC124記載の有形のコンピュータ可読媒体において、前記コントローラは、少なくとも1つのストレージインターフェース規格と適合した少なくとも1つのストレージインターフェースを介してホストにインターフェースする有形のコンピュータ可読媒体。
EC150)EC124記載の有形のコンピュータ可読媒体において、前記コントローラは、少なくとも1つのフラッシュ・メモリ・インターフェースを介して前記ダイのうちの少なくとも1つにインターフェースする有形のコンピュータ可読媒体。
EC151)EC124記載の有形のコンピュータ可読媒体において、前記NVMは少なくとも1つのフラッシュメモリを有する有形のコンピュータ可読媒体。
EC152)装置であって、
書き込みデータの少なくともいくつかの特性を決定する書き込みデータ特性付けハードウェア論理回路と、
少なくとも部分的に前記特性に基づいて、1若しくはそれ以上の不揮発性メモリ(NVM)のブロックの複数の被管理グループのうちの1つを選択する被管理グループ選択ハードウェア論理回路と、
前記書き込みのデータを選択された被管理グループに書き込むメモリ書き込みハードウェア論理回路と
を有し、
記憶システムのコントローラに具備されており、
前記被管理グループの各々は1若しくはそれ以上の管理動作に関して管理され、前記管理動作は、再利用動作および書き込み割り振り動作のうちの任意の1若しくはそれ以上を有し、前記被管理グループの各々は、前記NVMのうちの少なくとも2つのダイによって提供される記憶を有する装置。
EC153)EC152記載の装置において、前記被管理グループの各々は前記NVMのそれぞれの管理方式に対応する装置。
EC154)EC153記載の装置において、前記それぞれの管理方式は前記それぞれの論理特性に従うものであり、前記論理特性は、頻繁に読み取られること、相対的により頻繁に書き込まれること、相対的にあまり頻繁に書き込まれないこと、圧縮不能であること、実行可能であること、回復不能であり、電源喪失後に保存される必要があること、回復可能であり、電源喪失後に保存される必要がないこと、特定の技法若しくは鍵を使用して暗号化されること、特定の技法若しくは鍵を使用して、または特定のECC方式を用いて誤りから保護されること、再利用の対象とされること、および再利用の対象とされないことを有する装置。
EC155)EC153記載の装置において、前記それぞれの管理方式は前記それぞれの物理特性に従うものであり、前記物理特性は、もっぱら下位ページブロックだけを含むこと、およびもっぱら上位ページブロックだけを含むことを有する装置。
EC156)EC153記載の装置において、前記それぞれの管理方式は前記それぞれの書き込みデータソースに従うものであり、前記書き込みデータソースは、コンピューティングホストが提供するホストデータ、再利用によって生成されるデータ、およびシステム動作によって生成されるデータを有する装置。
EC157)EC152記載の装置において、前記被管理グループの各々は1若しくはそれ以上のR−ブロックを有する装置。
EC158)EC152記載の装置において、前記被管理グループの各々はNVMの1若しくはそれ以上のブロックを有する装置。
EC159)EC152記載の装置において、前記被管理グループの各々は複数の論理特性のうちの少なくとも1つに対応するものであり、前記論理特性は、頻繁に読み取られること、相対的により頻繁に書き込まれること、相対的にあまり頻繁に書き込まれないこと、圧縮不能であること、実行可能であること、回復不能であり、電源喪失後に保存される必要があること、回復可能であり、電源喪失後に保存される必要がないこと、特定の技法若しくは鍵を使用して暗号化されること、特定の技法若しくは鍵を使用して、または特定の誤り訂正符号(ECC)方式を用いて誤りから保護されること、再利用の対象とされること、および再利用の対象とされないことを有する装置。
EC160)EC152記載の装置において、さらに、
前記被管理グループのうちの第1の被管理グループからのデータを前記被管理グループのうちの第2の被管理グループに再利用するリサイクラハードウェア論理回路を有するものであり、前記第2の被管理グループは、ホストによって直接書き込まれたデータと前記第1の被管理グループから再利用されたデータの両方を含む装置。
EC161)EC152記載の装置において、前記書き込みデータは前記ホストからを受け取られる装置。
EC162)EC152記載の装置において、前記書き込みデータは前記コントローラによって生成される装置。
EC163)EC152記載の装置において、前記書き込みデータは、ユーザ書き込みデータ、書き換えデータ、システムデータ、書き換えシステムデータ、および書き換えユーザデータのうちの任意の1若しくはそれ以上を有する装置。
EC164)EC163記載の装置において、前記システムデータはチェックポイントデータを有する装置。
EC165)EC152記載の装置において、前記書き込みデータ特性付けハードウェア論理回路はヒントに応答するものである装置。
EC166)EC165記載の装置において、前記ヒントは前記ホストから受け取られる装置。
EC167)EC165記載の装置において、前記ヒントは前記書き込みデータが読み取り専用データまたは書き込み専用データのいずれか1つであることを指示する装置。
EC168)EC152記載の装置において、前記書き込みデータ特性付けハードウェア論理回路はデータ整理エンジンを有する装置。
EC169)EC168記載の装置において、前記特性は前記書き込みデータが実行可能であることを有する装置。
EC170)EC168記載の装置において、前記特性は前記書き込みデータが圧縮不能であることを有する装置。
EC171)EC168記載の装置において、前記特性は前記書き込みデータが整理不能であることを有する装置。
EC172)EC152記載の装置において、前記特性は、前の書き込み回数、前の読み取り回数、前の読み取り対前の書き込みの比、書き込みデータが圧縮不能であるという指示、書き込みデータが圧縮可能であるという指示、書き込みデータが実行可能であるという指示、および書き込みデータが回復不能であるという指示のうちの任意の1若しくはそれ以上を有する装置。
EC173)EC152記載の装置において、前記特性は、前記被管理グループの前に選択された被管理グループのうちの任意の1若しくはそれ以上を有する装置。
EC174)EC152記載の装置において、前記被管理グループのうちの任意の1若しくはそれ以上は、書き込みデータ特性付けハードウェア論理回路によって、頻繁に読み取られる、頻繁に書き込まれる、圧縮不能である、実行可能である、および回復不能である、のうちの1若しくはそれ以上として特性付けされたデータを含むブロックのうちのブロックを有する装置。
EC175)EC152記載の装置において、前記被管理グループのうちの1若しくはそれ以上は、システムデータ、ユーザデータ、および書き換えデータのうちのいずれか1つを含むブロックのうちのブロックだけを有する装置。
EC176)EC152記載の装置において、前記被管理グループのうちの1若しくはそれ以上は、システムデータ、ユーザデータ、および/または書き換えデータのうちのいずれか1つ若しくは2つを含むブロックのうちのブロックだけを有する装置。
EC177)EC152記載の装置において、前記被管理グループのうちの1若しくはそれ以上は、前記ブロックのうちの下位ページブロックだけまたは上位ページブロックだけの一方を有する装置。
EC178)EC152記載の装置において、前記被管理グループのうちの第1の被管理グループと第2の被管理グループとは異なる誤り訂正を有する装置。
EC179)EC152記載の装置において、さらに、
コントローラに具備され、前記コントローラと前記ホストとのインターフェースをとるストレージインターフェースを有するものであり、前記ストレージインターフェースは、少なくとも1つのストレージインターフェース規格と適合する装置。
EC180)EC152記載の装置において、さらに、
前記コントローラに具備され、コントローラと前記ダイのうちの少なくとも1つとのインターフェースをとるフラッシュ・メモリ・インターフェースを有するものである装置。
EC181)EC152記載の装置において、前記NVMは少なくとも1つのフラッシュメモリを有する装置。
EC182)記憶インターフェース規格を有し、または参照する前述のECのうちいずれかであって、前記記憶インターフェース規格は、
ユニバーサル・シリアル・バス(USB)インターフェース規格、
コンパクトフラッシュ(登録商標)(CF)インターフェース規格、
マルチメディアカード(MMC)インターフェース規格、
組み込みMMC(eMMC)インターフェース規格、
サンダーボルト(Thunderbolt)インターフェース規格、
UFSインターフェース規格、
セキュアディジタル(SD)インターフェース規格、
メモリ・スティック・インターフェース規格、
xDピクチャ・カード・インターフェース規格、
統合ドライブエレクトロニクス(IDE)インターフェース規格、
シリアル・アドバンスド・テクノロジ・アタッチメント(SATA)インターフェース規格、
外部SATA(eSATA)インターフェース規格、
小型コンピュータ・システム・インターフェース(SCSI)インターフェース規格、
シリアル小型コンピュータ・システム・インターフェース(SAS)インターフェース規格、
ファイバ・チャネル・インターフェース規格、
イーサネット(登録商標)(Ethernet(登録商標))インターフェース規格、および
周辺装置相互接続エクスプレス(PCIe)インターフェース規格
のうち1若しくはそれ以上を有するEC。
EC183)フラッシュ・メモリ・インターフェースを有し、または参照する前述のECのうちいずれかであって、前記フラッシュ・メモリ・インターフェースは、
オープンNANDフラッシュインターフェース(ONFI)、
トグルモードインターフェース、
ダブルデータレート(DDR)同期インターフェース、
DDR2同期インターフェース、
同期インターフェース、および
非同期インターフェース
のうち1若しくはそれ以上と適合するEC。
EC184)ホストを有し、または参照する前述のECのうちいずれかであって、ホストは、
コンピュータ、
ワークステーションコンピュータ、
サーバコンピュータ、
ストレージサーバ、
ストレージ・アタッチト・ネットワーク(SAN)、
ネットワーク・アタッチト・ストレージ(NAS)デバイス、
ダイレクト・アタッチト・ストレージ(DAS)デバイス、
ストレージアプライアンス、
パーソナルコンピュータ(PC)、
ラップトップコンピュータ、
ノートブックコンピュータ、
ネットブックコンピュータ、
タブレット機器またはタブレットコンピュータ、
ウルトラブックコンピュータ、
電子読み出し装置(e−reader)、
携帯情報端末(PDA)
ナビゲーションンシステム
(ハンドヘルド型)全地球測位システム(GPS)機器、
自動通信路制御システム、
自動車媒体制御システムまたは自動車媒体制御コンピュータ、
プリンタ、コピー機またはファックス機またはオールインワン機器、
販売時点(POS)機器、
金銭登録機、
メディアプレーヤ、
テレビ、
メディアレコーダ、
ディジタル・ビデオ・レコーダ(DVR)、
ディジタルカメラ、
セルラハンドセット、
コードレス電話機ハンドセット、および
電子ゲーム
のうち1若しくはそれ以上を有するEC。
EC185)少なくとも1つのフラッシュメモリを有し、または参照する前述のECのうちいずれかであって、前記少なくとも1つのフラッシュメモリの少なくとも一部分は、
NANDフラッシュ技術記憶セル、および
NORフラッシュ技術記憶セル
のうち1若しくはそれ以上を有するEC。
EC186)少なくとも1つのフラッシュメモリを有し、または参照する前述のECのうちいずれかであって、少なくとも1つのフラッシュメモリの少なくとも一部分は、
シングルレベルセル(SLC)フラッシュ技術記憶セル、および
マルチレベルセル(MLC)フラッシュ技術記憶セル
のうち1若しくはそれ以上を有するEC。
EC187)少なくとも1つのフラッシュメモリを有し、または参照する前述のECのうちいずれかであって、前記少なくとも1つのフラッシュメモリの少なくとも一部分は、
多結晶シリコン技術ベースの電荷蓄積セル、および
シリコン窒化膜技術ベースの電荷蓄積セル
のうち1若しくはそれ以上を有するEC。
EC188)少なくとも1つのフラッシュメモリを有し、または参照する前述のECのうちいずれかであって、少なくとも1つのフラッシュメモリの少なくとも一部分は、
2次元技術ベースのフラッシュメモリ技術、および
3次元技術ベースのフラッシュメモリ技術
のうち1若しくはそれ以上を有するEC。
システム
ある実施形態では、SSDといった入出力装置がSSDコントローラを有する。SSDコントローラはホストインターフェースとSSDのNVMとの間のブリッジとして働き、SSDのホストインターフェースを介してコンピューティングホストから送られるホストプロトコルのコマンドを実行する。コマンドの少なくとも部分的に、SSDに、コンピューティングホストから送られたデータおよびコンピューティングホストに送られるデータについて、それぞれ、NVMの書き込みおよび読み出しを行うよう指図する。別の実施形態では、SSDコントローラは、マップを使用してホストプロトコルのLBAとNVM内の物理的記憶アドレスとを変換することができるようになっている。別の実施形態では、マップの少なくとも一部分が、入出力装置の専用記憶(コンピューティングホストからは見えない)に使用される。例えば、コンピューティングホストからアクセスできないLBAの部分が、入出力装置によって、ログ、統計、または他の専用データへのアクセスを管理するのに使用される。
ある実施形態では、NVM内の様々なサイズの量の圧縮データにアクセスすることにより、ある使用シナリオでは記憶効率が改善される。例えば、SSDコントローラは、コンピューティングホストから(例えばディスク書き込みコマンドに関連した)(圧縮されていない)データを受け取り、データを圧縮し、データをフラッシュメモリへ記憶する。コンピューティングホストからの(例えばディスク読み出しコマンドに関連した)後続の要求に応答して、SSDコントローラはフラッシュメモリから圧縮データを読み出し、圧縮データを解凍し、解凍されたデータをコンピューティングホストに提供する。圧縮データは、様々なサイズの量に従ってフラッシュメモリに記憶され、各量のサイズは、例えば、圧縮アルゴリズム、動作モード、様々なデータに関する圧縮有効性により変動する。SSDコントローラは、一部は、含まれるマップ表を調べて(1つまたは複数の)ヘッダがフラッシュメモリのどこに記憶されているか確認することによってデータを解凍する。SSDコントローラは、適切な(圧縮)データがフラッシュメモリのどこに記憶されているか確認するためにフラッシュメモリから得た(1つまたは複数の)ヘッダをパースする。SSDコントローラは、コンピューティングホストに提供すべき解凍データを生成するために、フラッシュメモリからの適切なデータを解凍する。本出願では、「解凍する(uncompress)」(およびその変形)は、「伸張する(decompress)」(およびその変形)と同義である。
様々な実施形態では、SSDコントローラは、コンピューティングホストとインターフェースするためのホストインターフェースと、フラッシュメモリといったNVMとインターフェースするためのインターフェースと、各インターフェースを制御し、圧縮および解凍と共に、低レベル冗長性および/または誤り訂正、高レベル冗長性および/または誤り訂正、ならびに独立シリコン素子を用いた動的高レベル冗長性モード管理を行う(かつ/または行うことの様々な態様を制御する)ための回路とを有する。
様々な実施形態によれば、あるホストインターフェースは、USBインターフェース規格、CFインターフェース規格、MMCインターフェース規格、eMMCインターフェース規格、サンダーボルトインターフェース規格、UFSインターフェース規格、SDインターフェース規格、メモリ・スティック・インターフェース規格、xDピクチャ・カード・インターフェース規格、IDEインターフェース規格、SATAインターフェース規格、SCSIインターフェース規格、SASインターフェース規格、およびPCIeインターフェース規格のうち1若しくはそれ以上と適合する。様々な実施形態によれば、コンピューティングホストは、コンピュータ、ワークステーションコンピュータ、サーバコンピュータ、ストレージサーバ、SAN、NASデバイス、DASデバイス、ストレージアプライアンス、PC、ラップトップコンピュータ、ノートブックコンピュータ、ネットブックコンピュータ、タブレット機器またはタブレットコンピュータ、ウルトラブックコンピュータ、電子読み出し装置(e−readerなど)、PDA、ナビゲーションンシステム、(ハンドヘルド型)GPS機器、自動通信路制御システム、自動車媒体制御システムまたはコンピュータ、プリンタ、コピー機またはファックス機またはオールインワン機器、POS機器、金銭登録機、メディアプレーヤ、テレビ、メディアレコーダ、DVR、ディジタルカメラ、セルラハンドセット、コードレス電話機ハンドセット、および電子ゲームのうち全部または任意の部分である。ある実施形態では、インターフェースホスト(SAS/SATAブリッジなど)は、コンピューティングホストおよび/またはコンピューティングホストへのブリッジとして動作する。
様々な実施形態では、SSDコントローラは、1若しくはそれ以上のプロセッサを有する。プロセッサは、SSDコントローラの動作を制御し、かつ/または行うためにファームウェアを実行する。SSDコントローラは、コマンドおよび/または状況ならびにデータを送り、受け取るためにコンピューティングホストと通信する。コンピューティングホストは、オペレーティングシステム、ドライバ、およびアプリケーションのうち1若しくはそれ以上を実行する。コンピューティングホストによるSSDコントローラとの通信は、任意選択で、かつ/または選択的に、ドライバおよび/またはアプリケーションによるものである。第1の例では、SSDコントローラへのすべての通信がドライバによるものであり、アプリケーションは、ドライバに高レベルコマンドを提供し、ドライバがそれをSSDコントローラのための特定のコマンドに変換する。第2の例では、ドライバはバイパスモードを実施し、アプリケーションは、ドライバを介してSSDコントローラに特定のコマンドを送ることができるようになっている。第3の例では、PCIe SSDコントローラが1若しくはそれ以上の仮想機能(Virtual Functions:VFs)をサポートし、アプリケーションが、一度構成されると、ドライバをバイパスしてSSDコントローラを直接通信することを可能にする。
様々な実施形態によれば、あるSSDは、HDD、CDドライブ、DVDドライブといった磁気的不揮発性記憶および/または光学的不揮発性記憶によって使用されるフォームファクタ、電気的インターフェース、および/またはプロトコルと適合する。様々な実施形態では、SSDは、0以上のパリティ符号、0以上のRS符号、0以上のBCH符号、0以上のビタビ符号または他のトレリス符号、および0以上のLDPC符号の様々な組み合わせを使用する。
図1Aに、不揮発性メモリの領域への書き込みの管理および領域選択を行うSSDコントローラを含むSSDの実施形態の選択された詳細を図示する。SSDコントローラは、例えばNVM素子(フラッシュメモリなど)によって実装される不揮発性記憶を管理するためのものである。SSDコントローラ100は、1若しくはそれ以上の外部インターフェース110を介してホスト(図示せず)に通信可能に結合されている。様々な実施形態によれば、外部インターフェース110は、SATAインターフェース、SASインターフェース、PCIeインターフェース、ファイバ・チャネル・インターフェース、イーサネット(登録商標)(Ethernet(登録商標))インターフェース(登録商標)(Ethernet(登録商標))(10ギガビットイーサネット(登録商標)(Ethernet(登録商標))など)、前述のインターフェースのいずれかの非標準バージョン、カスタムインターフェース、または記憶装置および/若しくは通信装置および/若しくはコンピューティング機器を相互接続するのに使用される任意の他の種類のインターフェースのうちの1若しくはそれ以上である。例えば、ある実施形態では、SSDコントローラ100は、SATAインターフェースおよびPCIeインターフェースを含む。
SSDコントローラ100は、さらに、1若しくはそれ以上のデバイスインターフェース190を介して、フラッシュデバイス192の1若しくはそれ以上のインスタンスといった、1若しくはそれ以上の記憶デバイスを有するNVM199に通信可能に結合されている。様々な実施形態によれば、デバイスインターフェース190は、非同期インターフェース、同期インターフェース、シングルデータレート(SDR)インターフェース、ダブルデータレート(DDR)インターフェース、DRAM互換DDR若しくはDDR2同期インターフェース、ONFI2.2やONFI3.0互換インターフェースといったONFI互換インターフェース、トグルモード互換フラッシュインターフェース、上記のインターフェースのいずれかの非標準バージョン、カスタムインターフェース、または記憶デバイスに接続するのに使用される任意の他の種類のインターフェースのうち1若しくはそれ以上である。
フラッシュデバイス192の各々は、ある実施形態では、1若しくはそれ以上の個々のフラッシュダイ194を有する。フラッシュデバイス192のうち特定のフラッシュデバイスの種類に従って、特定のフラッシュデバイス192内の複数のフラッシュダイ194に、並列に、任意選択で、かつ/または選択的にアクセスすることができる。フラッシュデバイス192は、単に、SSDコントローラ100に通信可能に結合することが可能な記憶デバイスの一種を表しているにすぎない。様々な実施形態では、SLC NANDフラッシュメモリ、MLC NANDフラッシュメモリ、NORフラッシュメモリ、多結晶シリコン若しくはシリコン窒化膜技術ベースの電荷蓄積セルを使用したフラッシュメモリ、2次元若しくは3次元技術ベースのフラッシュメモリ、読み出し専用メモリ、スタティック・ランダム・アクセス・メモリ、ダイナミック・ランダム・アクセス・メモリ、強磁性メモリ、相変化メモリ、レーストラックメモリ、ReRAM、または任意の他の種類のメモリデバイス若しくは記憶媒体といった、任意の種類の記憶デバイスを使用することができる。
様々な実施形態によれば、デバイスインターフェース190は、1つのバスにつきフラッシュデバイス192の1若しくはそれ以上のインスタンスを有する1若しくはそれ以上のバス;グループ内のバスにおおむね並列にアクセスさせる、1つのバスにつきフラッシュデバイス192の1若しくはそれ以上のインスタンスを有する1若しくはそれ以上のバスグループ;またはデバイスインターフェース190上へのフラッシュデバイス192の1若しくはそれ以上のインスタンスの任意の他の編成として編成される。
引き続き図1Aにおいて、SSDコントローラ100は、ホストインターフェース111、データ処理121、バッファ131、マップ141、リサイクラ151、ECC161、デバイスインターフェース論理191、CPU171といった1若しくはそれ以上のモジュールを有する。図1Aに図示する具体的なモジュールおよび相互接続は、単に、一実施形態を表すにすぎず、これらのモジュールの一部または全部、および図示されていないさらに別のモジュールの多くの配置および相互接続が考えられる。第1の例として、ある実施形態では、デュアルポーティングを提供するための2つ以上のホストインターフェース111がある。第2の例として、ある実施形態では、データ処理121および/またはECC161がバッファ131と組み合わされている。第3の例として、ある実施形態では、ホストインターフェース111がバッファ131に直接結合されており、データ処理121が、バッファ131に記憶されたデータに任意選択で、かつ/または選択的に作用する。第4の例として、ある実施形態では、デバイスインターフェース論理191がバッファ131に直接結合されており、ECC161が、バッファ131に記憶されたデータに任意選択で、かつ/または選択的に作用する。
ホストインターフェース111は、外部インターフェース110を介してコマンドおよび/またはデータを送受信し、ある実施形態では、タグ追跡113によって個々のコマンドの進捗を追跡する。例えば、コマンドは、読み出すべきアドレス(LBAなど)およびデータの量(LBA量、例えばセクタの数など)を指定する読み出しコマンドを有し、これに応答してSSDは、読み出し状況および/または読み出しデータを提供する。別の例として、コマンドは、書き込むべきアドレス(LBAなど)およびデータの量(LBA量、例えばセクタの数など)を指定する書き込みコマンドを有し、これに応答してSSDは、書き込み状況を提供し、かつ/または書き込みデータを要求し、任意選択でその後に書き込み状況を提供する。さらに別の例として、コマンドは、もはや割り振られる必要のなくなった1若しくはそれ以上のアドレス(1若しくはそれ以上のLBAなど)を指定する割り振り解除コマンド(trimコマンドなど)を有し、これに応答してSSDは、マップをしかるべく変更し、任意選択で割り振り解除状況を提供する。あるコンテキストでは、ATA互換TRIMコマンドが割り振り解除コマンドの例である。さらに別の例として、コマンドは、超コンデンサ・テスト・コマンドまたはデータハーデニング成功問い合わせを有し、これに応答してSSDは、適切な状況を提供する。ある実施形態では、ホストインターフェース111は、SATAプロトコルと適合し、NCQコマンドを使用して、最高32までの未処理のコマンドを有することができるようになっており、各コマンドは0から31までの数として表された一意のタグを有する。ある実施形態では、タグ追跡113は、外部インターフェース110を介して受け取ったコマンドのための外部タグを、SSDコントローラ100による処理の間にコマンドを追跡するのに使用される内部タグと関連付けることができるようになっている。
様々な実施形態によれば、データ処理121は、任意選択で、かつ/または選択的に、バッファ131と外部インターフェース110との間で送られる一部または全部のデータを処理する、およびデータ処理121は、任意選択で、かつ/または選択的に、バッファ131に記憶されたデータを処理する、以下のうち1若しくはそれ以上が行われる。ある実施形態では、データ処理121は、1若しくはそれ以上のエンジン123を使用して、書式設定、書式設定の変更、符号変換、ならびに他のデータ処理および/または操作タスクのうち1若しくはそれ以上を行う。
バッファ131は、外部インターフェース110からデバイスインターフェース190へ/デバイスインターフェース190から外部インターフェース110へ送られたデータを記憶する。ある実施形態では、バッファ131は、さらに、SSDコントローラ100によってフラッシュデバイス192の1若しくはそれ以上のインスタンスを管理するのに使用される、一部または全部のマップ表といったシステムデータも記憶する。様々な実施形態では、バッファ131は、データの一時記憶に使用されるメモリ137、バッファ131への、かつ/またはバッファ131からのデータの移動を制御するのに使用されるDMA133、ならびに高レベル誤り訂正および/または冗長性機能と、他のデータ移動および/または操作機能とを提供するのに使用されるECC−X135のうち1若しくはそれ以上を有する。高レベル冗長性機能の一例がRAID様の能力(RASIEなど)であり、ディスクレベルではなく、フラッシュ・デバイス・レベル(フラッシュデバイス192のうち複数のものなど)および/またはフラッシュダイ・レベル(フラッシュダイ194など)の冗長性を備える。
様々な実施形態によれば、以下のうち1若しくはそれ以上である。ECC161は、任意選択で、かつ/または選択的に、バッファ131とデバイスインターフェース190との間で送られる一部または全部のデータを処理する;およびECC161は、任意選択で、かつ/または選択的に、バッファ131に記憶されたデータを処理する。ある実施形態では、ECC161は、例えば1若しくはそれ以上のECC技法に従った低レベル誤り訂正および/または冗長性機能を提供するのに使用される。ある実施形態では、ECC161は、CRC符号、ハミング符号、RS符号、BCH符号、LDPC符号、ビタビ符号、トレリス符号、硬判定符号、軟判定符号、消去ベースの符号、任意の誤り検出および/または訂正符号、ならびに上記の任意の組み合わせのうち1若しくはそれ以上を実施する。ある実施形態では、ECC161は、1若しくはそれ以上の復号器(LDPC復号器など)を有する。
デバイスインターフェース論理191は、デバイスインターフェース190を介してフラッシュデバイス192のインスタンスを制御する。デバイスインターフェース論理191は、フラッシュデバイス192のプロトコルに従ってフラッシュデバイス192のインスタンスへ/からデータを送ることができるようになっている。デバイスインターフェース論理191は、デバイスインターフェース190を介したフラッシュデバイス192のインスタンスの制御を選択的に配列するスケジューリング193を有する。例えば、ある実施形態では、スケジューリング193は、フラッシュデバイス192のインスタンスへの操作を待ち行列に入れ、フラッシュデバイス192(またはフラッシュダイ194)のインスタンスの個々のインスタンスへの操作を、フラッシュデバイス192(またはフラッシュダイ194)のインスタンスの個々のインスタンスが利用可能になるに従って選択的に送ることができるようになっている。
マップ141は、外部インターフェース110上で使用されるデータアドレス指定と、デバイスインターフェース190上で使用されるデータアドレス指定との間の変換を行い、表143を使用して外部データアドレスからNVM199内の位置へマップする。例えば、ある実施形態では、マップ141は、外部インターフェース110上で使用されるLBAを、表143によって提供されるマッピングにより、1若しくはそれ以上のフラッシュダイ194を対象とするブロックおよび/またはページアドレスに変換する。ドライブ製造または割り振り解除以来一度も書き込まれていないLBAでは、マップは、LBAが読み出された場合に返すべきデフォルト値を指し示す。例えば、割り振り解除コマンドを処理するときに、マップは、割り振り解除されたLBAに対応するエントリがデフォルト値のうち1つを指し示すように変更される。様々な実施形態では、様々なデフォルト値があり、各々が対応するポインタを有する。複数のデフォルト値は、ある(例えば第1の範囲内の)割り振り解除されたLBAを1つのデフォルト値として読み出し、ある(例えば第2の範囲内の)割り振り解除されたLBAを別のデフォルト値として読み出すことを可能にする。デフォルト値は、様々な実施形態では、フラッシュメモリ、ハードウェア、ファームウェア、コマンドおよび/若しくはプリミティブ引数および/若しくはパラメータ、プログラマブルレジスタ、またはそれらの様々な組み合わせによって定義される。
ある実施形態では、マップ141は、表143を使用して、外部インターフェース110上で使用されるアドレスと、デバイスインターフェース190上で使用されるデータアドレス指定との間の変換を行い、かつ/またはルックアップする。様々な実施形態によれば、表143は、1レベルマップ、2レベルマップ、マルチレベルマップ、マップキャッシュ、圧縮マップ、あるアドレス空間から別のアドレス空間への任意の種類のマッピング、および上記の任意の組み合わせのうち1若しくはそれ以上である。様々な実施形態によれば、表143は、スタティック・ランダム・アクセス・メモリ、ダイナミック・ランダム・アクセス・メモリ、NVM(フラッシュメモリなど)、キャッシュメモリ、オンチップメモリ、オフチップメモリ、および上記の任意の組み合わせのうち1若しくはそれ以上を有する。
ある実施形態では、リサイクラ151は、不要部分の整理を行う。例えば、ある実施形態では、フラッシュデバイス192のインスタンスは、ブロックが書き換え可能になる前に消去されなければならないブロックを有する。リサイクラ151は、例えば、マップ141によって維持されるマップをスキャンすることによって、フラッシュデバイス192のインスタンスのどの部分が実際に使用されているか(例えば、割り振り解除されているのではなく割り振られていること)を決定し、フラッシュデバイス192のインスタンスの未使用の(例えば割り振り解除された)部分を、未使用の部分を消去することによって書き込みに利用できるようにすることができるようになっている。別の実施形態では、リサイクラ151は、フラッシュデバイス192のインスタンスのより大きい連続した部分を書き込みに利用できるようにするために、フラッシュデバイス192のインスタンス内に記憶されたデータを移動することができるようになっている。
ある実施形態では、フラッシュデバイス192のインスタンスは、異なる種類および/または属性のデータを記憶するための1若しくはそれ以上のバンドを保持するように、選択的に、かつ/または動的に構成され、管理され、かつ/または使用される。バンドの数、配置、サイズ、および種類は、動的に変更可能である。例えば、コンピューティングホストからのデータはホット(アクティブな)バンドに書き込まれ、リサイクラ151からのデータはコールド(あまりアクティブではない)バンドに書き込まれる。ある使用シナリオでは、コンピューティングホストが長い順次のストリームを書き込む場合には、ホットバンドのサイズが増大し、コンピューティングホストがランダムな書き込みを行い、またはわずかな書き込みしか行わない場合には、コールドバンドのサイズが増大する。
CPU171は、SSDコントローラ100の様々な部分を制御する。CPU171は、CPUコア172を有する。CPUコア172は、様々な実施形態によれば、1若しくはそれ以上のシングルコアプロセッサまたはマルチコアプロセッサである。CPUコア172内の個々のプロセッサコアは、ある実施形態では、マルチスレッド化されている。CPUコア172は、命令および/またはデータのキャッシュおよび/またはメモリを有する。例えば、命令メモリは、CPUコア172が、SSDコントローラ100を制御するためのプログラム(ファームウェアとも呼ばれるソフトウェアなど)を実行することを可能にする命令を有する。ある実施形態では、CPUコア172によって実行されるファームウェアの一部または全部が、(例えば、図1BのNVM199のファームウェア106として図示されている)フラッシュデバイス192のインスタンス上に記憶される。
様々な実施形態では、CPU171は、外部インターフェース110を介して受け取られるコマンドを、コマンドが進行している間に追跡し、制御するコマンド管理173、バッファ131の割り振りおよび使用を制御するバッファ管理175、マップ141を制御する変換管理177、データアドレス指定の整合性を制御し、例えば、外部データアクセスと再利用データアクセスとの間の矛盾を回避するコヒーレンシ管理179、デバイスインターフェース論理191を制御するデバイス管理181、識別情報の変更および通信を制御する識別情報管理182、ならびに、任意選択で、他の管理部をさらに有する。CPU171によって果たされる管理機能は、そのいずれか、若しくは全部が、ハードウェア、ソフトウェア(CPUコア172上や、外部インターフェース110を介して接続されたホスト上で実行されるファームウェアなど)、またはそれらの任意の実施形態によって制御され、かつ/または管理され、あるいは、そのどれも、制御も管理もされないものである。
ある実施形態では、CPU171は、性能統計の収集および/または報告、SMARTの実施、電源逐次開閉機構の制御、電力消費の制御および/または調整、電源障害への応答、クロック速度の制御および/またはモニタリングおよび/または調整、ならびに他の管理タスクのうち1若しくはそれ以上といった、他の管理タスクを行うことができるようになっている。
様々な実施形態は、SSDコントローラ100と同様の、例えば、ホストインターフェース111および/または外部インターフェース110の適応による、様々なコンピューティングホストを用いた動作と適合するコンピューティングホスト・フラッシュ・メモリ・コントローラを有する。様々なコンピューティングホストは、コンピュータ、ワークステーションコンピュータ、サーバコンピュータ、ストレージサーバ、SAN、NASデバイス、DASデバイス、ストレージアプライアンス、PC、ラップトップコンピュータ、ノートブックコンピュータ、ネットブックコンピュータ、タブレット機器またはタブレットコンピュータ、ウルトラブックコンピュータ、電子読み出し装置(e−readerなど)、PDA、ナビゲーションンシステム、(ハンドヘルド型)GPS機器、自動通信路制御システム、自動車媒体制御システムまたはコンピュータ、プリンタ、コピー機またはファックス機またはオールインワン機器、POS機器、金銭登録機、メディアプレーヤ、テレビ、メディアレコーダ、DVR、ディジタルカメラ、セルラハンドセット、コードレス電話機ハンドセット、および電子ゲームのうち1つまたはそれらの任意の組み合わせを有する。
様々な実施形態では、SSDコントローラ(またはコンピューティングホスト・フラッシュ・メモリ・コントローラ)の全部または任意の部分が、単一のIC、マルチダイICの単一のダイ、マルチダイICの複数のダイ、または複数のIC上で実施される。例えば、バッファ131は、SSDコントローラ100の他の要素と同じダイ上に実施される。別の例では、バッファ131は、SSDコントローラ100の他の要素と異なるダイ上に実施される。
図1Bに、図1AのSSDの1若しくはそれ以上のインスタンスを有するシステムの様々な実施形態の選択された詳細を図示する。SSD101は、デバイスインターフェース190を介してNVM199に結合されたSSDコントローラ100を有する。図には、様々な種別の実施形態、すなわち、ホストに直接結合された単一のSSD、各々がそれぞれの外部インターフェースを介してホストに直接それぞれ結合されている複数のSSD、および様々な相互接続要素を介してホストに間接的に結合された1若しくはそれ以上のSSDが示されている。
ホストに直接結合された単一のSSDの例示的実施形態としては、SSD101の1つのインスタンスが、外部インターフェース110を介してホスト102に直接結合される(例えば、スイッチ/ファブリック/中間コントローラ103が省かれ、バイパスされ、またはパススルーされる)。各々がそれぞれの外部インターフェースを介してホストに直接結合されている複数のSSDの例示的実施形態としては、SSD101の複数のインスタンスの各々が、外部インターフェース110のそれぞれのインスタンスを介してホスト102に直接それぞれ結合される(例えば、スイッチ/ファブリック/中間コントローラ103が省かれ、バイパスされ、またはパススルーされる)。様々な相互接続要素を介してホストに間接的に結合された1若しくはそれ以上のSSDの例示的実施形態としては、SSD101の1若しくはそれ以上のインスタンスの各々が、ホスト102に間接的にそれぞれ結合される。各間接結合は、スイッチ/ファブリック/中間コントローラ103に結合された外部インターフェース110のそれぞれのインスタンス、およびホスト102に結合する中間インターフェース104を介したものである。
スイッチ/ファブリック/中間コントローラ103を有する実施形態の一部は、メモリインターフェース180を介して結合された、SSDによってアクセス可能なカードメモリ112Cも有する。様々な実施形態では、SSD、スイッチ/ファブリック/中間コントローラ、および/またはカードメモリのうち1若しくはそれ以上が、物理的に識別可能なモジュール、カード、または差し込み可能な要素(入出力カード116など)上に含まれる。ある実施形態では、SSD101(またはその変形)は、ホスト102として動作するイニシエータ(開始プログラム)に結合されたSASドライブまたはSATAドライブに対応する。
ホスト102は、OS105、ドライバ107、アプリケーション109、マルチデバイス管理ソフトウェア114の様々な組み合わせといった、ホストソフトウェア115の様々な要素を実行することができるようになっている。点線矢印107Dは、ホストソフトウェア←→入出力装置通信、例えば、SSD101のインスタンスのうち1若しくはそれ以上から/へ、ドライバ107を介したOS105、ドライバ107、および、ドライバ107を介して、またはVFとして直接アプリケーション109のうち任意の1若しくはそれ以上へ/から送られ/受け取られるデータを表す。
OS105は、SSDとインターフェースするための(概念的にはドライバ107によって図示されている)ドライバを有し、かつ/またはそのようなドライバを用いて動作することができるようになっている。Windows(登録商標)の様々なバージョン(95、98、ME、NT、XP、2000、サーバ、Vista、および7など)、Linux(登録商標)の様々なバージョン(Red Hat、Debian、およびUbuntuなど)、ならびにMacOSの様々なバージョン(8、9およびXなど)がOS105の例である。様々な実施形態では、ドライバは、SATA、AHCI、NVM Expressといった標準のインターフェースおよび/またはプロトコルを用いて動作する標準のドライバおよび/または汎用のドライバ(「シュリンクラップされた(市販の)」または「プリインストールされた」ともいう)であり、あるいは、任意選択で、SSD101に特有のコマンドの使用を可能にするようにカスタマイズされており、かつ/またはベンダ特有のものである。あるドライブおよび/またはドライバは、アプリケーションレベルのプログラム、例えば最適化NANDアクセス(Optimized NAND Access)(ONAともいう)または直接NANDアクセス(Direct NAND Access)(DNAともいう)の各技法によるアプリケーション109などが、コマンドをSSD101に直接伝えることを可能にするパススルーモードを有し、カスタマイズされたアプリケーションが、汎用ドライバとでさえもSSD101に特有のコマンドを使用することを可能にする。ONAの技法は、非標準変更子(hints)の使用、ベンダ特有のコマンドの使用、非標準の統計の通信、例えば圧縮可能性に従った実際のNVMの使用、および他の技法のうち1若しくはそれ以上を有する。DNAの技法は、NVMへのマップされていない読み出し、書き込み、および/または消去アクセスを提供する非標準のコマンドまたはベンダ特有の(コマンド)の使用、例えば、入出力装置が通常は行うはずのデータの書式設定をバイパスすることによる、NVMへのより直接的なアクセスを提供する非標準の、またはベンダ特有のコマンドの使用、および他の技法のうち1若しくはそれ以上を有する。ドライバの例は、ONAまたはDNAサポートなしのドライバ、ONA使用可能ドライバ、DNA使用可能ドライバ、ONA/DNA使用可能ドライバである。ドライバの別の例は、ベンダ提供ドライバ、ベンダ開発ドライバ、および/またはベンダ拡張ドライバ、ならびにクライアント提供ドライバ、クライアント開発ドライバ、および/またはクライアント拡張ドライバである。
アプリケーションレベルのプログラムの例は、ONAまたはDNAサポートなしのアプリケーション、ONA使用可能アプリケーション、DNA使用可能アプリケーション、およびONA/DNA使用可能アプリケーションである。点線矢印109Dは、アプリケーション←→入出力装置通信(ドライバによるバイパスや、アプリケーションのためのVFによるバイパスなど)、例えば、OSを仲介として使用するアプリケーションなしでSSDと通信するONA使用可能アプリケーションおよびONA使用可能ドライバなどを表す。点線矢印109Vは、アプリケーション←→入出力装置通信(アプリケーションのためのVFによるバイパスなど)、例えば、OSまたはドライバを仲介として使用するアプリケーションなしでSSDと通信するDNA使用可能アプリケーションおよびDNA使用可能ドライバなどを表す。
NVM199の1若しくはそれ以上の部分が、ある実施形態では、ファームウェア記憶、例えばファームウェア106に使用される。ファームウェア記憶は、1若しくはそれ以上のファームウェアイメージ(またはその部分)を有する。ファームウェアイメージは、例えばSSDコントローラ100のCPUコア172によって実行される、例えばファームウェアの1若しくはそれ以上のイメージを有する。ファームウェアイメージは、別の例では、例えばファームウェア実行時にCPUコアによって参照される、定数、パラメータ値、NVMデバイス情報の1若しくはそれ以上のイメージを有する。ファームウェアのイメージは、例えば、現在のファームウェアイメージおよび0以上の(ファームウェア更新に対して)前のファームウェアイメージに対応する。様々な実施形態では、ファームウェアは、汎用動作モード、標準動作モード、ONA動作モード、および/またはDNA動作モードを提供する。ある実施形態では、ファームウェア動作モードのうち1若しくはそれ以上が、ドライバによって任意選択で伝えられ、かつ/または提供される、鍵または様々なソフトウェア技法によって使用可能とされる(例えば、1若しくはそれ以上のAPIが「ロック解除」される)。
スイッチ/ファブリック/中間コントローラを欠くある実施形態では、SSDは、外部インターフェース110を介して直接ホストに結合される。様々な実施形態では、SSDコントローラ100は、RAIDコントローラといった他のコントローラの1若しくはそれ以上の中間レベルを介してホストに結合される。ある実施形態では、SSD101(またはその変形)は、SASドライブまたはSATAドライブに対応し、スイッチ/ファブリック/中間コントローラ103は、イニシエータにさらに結合されたエキスパンダに対応し、あるいは、スイッチ/ファブリック/中間コントローラ103は、エキスパンダを介してイニシエータに間接的に結合されたブリッジに対応する。ある実施形態では、スイッチ/ファブリック/中間コントローラ103は、1若しくはそれ以上のPCIeスイッチおよび/またはファブリックを有する。
様々な実施形態、例えば、コンピューティングホストとしてのホスト102(コンピュータ、ワークステーションコンピュータ、サーバコンピュータ、ストレージサーバ、SAN、NASデバイス、DASデバイス、ストレージアプライアンス、PC、ラップトップコンピュータ、ノートブックコンピュータ、および/またはネットブックコンピュータなど)を有する実施形態のあるものでは、コンピューティングホストは、任意選択で、1若しくはそれ以上のローカルサーバおよび/またはリモートサーバ(例えば、任意選択のサーバ118)と(例えば、任意選択の入出力装置/リソースおよび記憶装置/リソース117および任意選択のLAN/WAN119を介して)通信することができるようになっている。通信は、例えば、SSD101要素のうち任意の1若しくはそれ以上のローカルおよび/またはリモートのアクセス、管理、および/または使用を可能にする。ある実施形態では、通信は、全部または一部がイーサネット(登録商標)(Ethernet(登録商標))によるものである。ある実施形態では、通信は、全部または一部がファイバチャネルによるものである。LAN/WAN119は、様々な実施形態では、1若しくはそれ以上のローカル・エリア・ネットワークおよび/または広域ネットワーク、例えば、サーバファーム内のネットワーク、サーバファームを結合するネットワーク、メトロエリアネットワーク、およびインターネットのうち任意の1若しくはそれ以上を表す。
様々な実施形態では、1若しくはそれ以上のNVMと組み合わされたSSDコントローラおよび/またはコンピューティングホスト・フラッシュ・メモリ・コントローラが、USB記憶コンポーネント、CF記憶コンポーネント、MMC記憶コンポーネント、eMMC記憶コンポーネント、サンダーボルト記憶コンポーネント、UFS記憶コンポーネント、SD記憶コンポーネント、メモリスティック記憶コンポーネント、xDピクチャカード記憶コンポーネントといった不揮発性記憶コンポーネントとして実施される。
様々な実施形態では、SSDコントローラ(またはコンピューティングホスト・フラッシュ・メモリ・コントローラ)の全部またはいずれかの部分、またはその機能が、コントローラが結合されるべきホスト(図1Bのホスト102など)において実施される。様々な実施形態では、SSDコントローラ(若しくはコンピューティングホスト・フラッシュ・メモリ・コントローラ)の全部またはいずれかの部分、またはその機能が、ハードウェア(論理回路など)、ソフトウェアおよび/若しくはファームウェア(ドライバソフトウェアおよび/若しくはSSD制御ファームウェアなど)、またはそれらの任意の組み合わせによって実施される。例えば、(例えば図1AのECC161および/またはECC−X135と同様の)ECC部の、またはECC部と関連付けられた機能が、一部はホスト上のソフトウェアによって、一部はSSDコントローラ内のファームウェアとハードウェアとの組み合わせによって実施される。別の例として、(例えば図1Aのリサイクラ151と同様の)リサイクラ部の、またはリサイクラ部と関連付けられた機能が、一部はホスト上のソフトウェアによって、一部はコンピューティングホスト・フラッシュ・メモリ・コントローラ内のハードウェアによって実施される。
マッピング操作
図2に、LBAのLPN部分のマッピングの実施形態の選択された詳細を図示する。ある実施形態では、読み出し単位は、NVMのページの部分といった、独立に読み出すことのできるNVMの最も細かい粒度である。別の実施形態では、読み出し単位は、検査ビットによって保護されるすべてのデータに(低レベル)誤り訂正符号の検査ビット(冗長性ともいう)を加えたものに対応する。例えば、図1AのECC161は、検査ビットによる、例えばLDPC符号による誤り訂正を実施し、読み出し単位は、LDPC符号化ビットによって保護されるデータビットにLDPC符号を加えたものを実施する符号化ビットに対応する。
ある実施形態では、マップ141は、LBA211のLPN213部分を、例えば(図1Aに図示される)表143によって、LPNのためのマップ情報221にマップする。LPNのためのマップ情報(例えばLPNのためのマップ情報221)をマップエントリともいう。マップ141は、LPNを対応するマップエントリと関連付けるといわれる。様々な実施形態では、マッピングは、1若しくはそれ以上の連想ルックアップ、1若しくはそれ以上の非連想ルックアップ、および/または1若しくはそれ以上の他の技法によるものである。
ある実施形態では、SSDコントローラ100は、潜在的に、かつ/またはアクティブに使用されているLPNごとに1つのマップエントリを維持する。
ある実施形態では、LPNのためのマップ情報221は、それぞれの読み出し単位アドレス223および読み出し単位での長さ225を有する。ある実施形態では、長さおよび/または範囲は、例えば、読み出し単位での長さ225の全部またはいずれかの部分において、例えば、長さを範囲からのオフセットとして記憶することによって、符号化して記憶される。別の実施形態では、第1のLPNは第1のマップエントリと関連付けられており、(第1のLPNと異なるが、第1のLPNによって参照される論理ページと同サイズの論理ページを参照する)第2のLPNは第2のマップエントリと関連付けられており、第1のマップエントリのそれぞれの読み出し単位での長さは、第2のマップエントリのそれぞれの読み出し単位での長さと異なる。
様々な実施形態では、同じ時点において、第1のLPNは第1のマップエントリと関連付けられており、(第1のLPNと異なる)第2のLPNは第2のマップエントリと関連付けられており、第1のマップエントリのそれぞれの読み出し単位アドレスは、第2のマップエントリのそれぞれの読み出し単位アドレスと同じである。別の実施形態では、第1のLPNと関連付けられたデータおよび第2のLPNと関連付けられたデータは、どちらも、NVM199内の同じデバイスの同じ物理ページに記憶されている。
様々な実施形態によれば、読み出し単位アドレス223は、NVM内の開始アドレス、NVM内の終了アドレス、上記のいずれかのオフセット、およびLPN213と関連付けられたNVMの部分を特定するための任意の他の技法のうち1若しくはそれ以上と関連付けられている。
図3に、読み出し単位の量で測った長さを総体として有する、様々な読み出し単位として編成された読み出しデータを生成するための、読み出し単位アドレスのところのNVMへのアクセスの実施形態の選択された詳細を図示する。様々な実施形態によれば、最初の読み出し単位313は、NVMのアドレス空間における最低のアドレスを有する読み出しデータ311内の読み出し単位のうち1つ、読み出し単位のうち固定された1つ、読み出し単位のうち任意の1つ、読み出し単位のうち可変の1つ、および任意の他の技法によって選択される読み出し単位のうち1つのうち1若しくはそれ以上である。様々な実施形態では、SSDコントローラ100は、NVM199にアクセスし、読み出し単位での長さ225によって指定される数以下の数の読み出し単位を読み出すことによって読み出しデータ311を生成することができるようになっている。
図4Aに、(図3の読み出し単位313や読み出し単位315といった)読み出し単位の実施形態の選択された詳細を読み出し単位401Aとして図示する。様々な実施形態および/または使用シナリオにおいて、ヘッダ1 411AからヘッダN 419Aは連続しており、ヘッダの各々によって(例えばそれぞれのオフセットにより)特定されるそれぞれのデータ領域は、ヘッダの最後のものに後に続いて連続している。各データ領域は総体としてデータバイト421Aを形成している。各データ領域は、各ヘッダが記憶される位置順と一致した位置順で記憶される。例えば、読み出し単位の先頭のところの第1のヘッダを考えると、第2のヘッダおよび第3のヘッダは、第1のヘッダのすぐ後に続く。(第1のヘッダ内の第1のオフセットによって特定される)第1のデータ領域は第3のヘッダのすぐ後に続く。(第2のヘッダ内の第2のオフセットによって特定される)第2のデータ領域は第1のデータ領域のすぐ後に続く。同様に、(第3のヘッダ内によって特定される)第3データ領域も第2のデータ領域のすぐ後に続く。
図4Bに、(図3の読み出し単位313や読み出し単位315といった)読み出し単位の別の実施形態の選択された詳細を読み出し単位401Bとして図示する。様々な実施形態および/または使用シナリオにおいて、ヘッダマーカ(HM)410Bは、後に続く連続したヘッダ(ヘッダ1 411B、ヘッダ2 412B...ヘッダN 419B)の数を指示する任意選択の最初のフィールド(例えば1バイトのフィールド)である。データ領域(データバイト421B、データバイト422B...データバイト429B)は、それぞれ、ヘッダ(ヘッダ1 411B、ヘッダ2 412B...ヘッダN 419B)によって特定され、ヘッダが記憶される位置順とは逆の位置順で記憶される。ヘッダは読み出し単位の先頭から開始し、対応するデータ領域は読み出し単位の末尾から開始する。ある実施形態では、データ領域内のデータバイト(例えば、データバイト421B、データバイト422B...データバイト429B)は、前方順(位置順と一致するバイト順)に配置され、別の実施形態では、データバイトは、逆順(位置順に対して反転されたバイト順)に配置される。ある実施形態では、ヘッダマーカが、(例えば図4Aに示すように)ヘッダおよびデータバイトが同じ位置順で記憶されている読み出し単位で使用される。
ある実施形態では、任意選択のパディングバイト431A(または431B)は、特定のLPNと関連付けられたデータの粒度に従ったものである。例えば、ある実施形態では、データバイト421A(またはデータバイト421B、データバイト422B...データバイト429Bの総体)が、ヘッダ1 411AからヘッダN 419Aまで(またはヘッダ1 411B、ヘッダ2 412B...ヘッダN 419B)の最後のヘッダを除くすべてのヘッダと関連付けられたデータを記憶した後で、決まった量、例えば8バイトより少ない残りのスペースを有する場合には、最後のヘッダと関連付けられたLPNのデータは後続の読み出し単位において開始する。別の実施形態では、最後のヘッダ内の特定のオフセット値(例えばすべて1)が、最後のヘッダと関連付けられたLPNのデータが後続の読み出し単位において開始することを指示する。
図5に、いくつかのフィールドを有するヘッダ(例えば、図4Aのヘッダ1 411AからヘッダN 419Aまでや、図4Bのヘッダ1 411Bからヘッダ 419Bまでのいずれか)の実施形態の選択された詳細を図示する。一部の実施形態では、ヘッダは固定長である(例えば、各ヘッダは同じバイト数の長さである)。ヘッダ501は、種類511、最終標識513、フラグ515、LPN517、長さ519、およびオフセット521の各フィールドを含む。種類フィールドは、データバイトのカテゴリを識別する。例えば、種類フィールドは、データバイトのカテゴリが、ホストデータ(論理ページデータなど)またはシステムデータ(マップ情報やチェックポイント情報など)の1つであることを指示する。最終フィールドは、ヘッダがデータバイトの前の最終ヘッダであることを指示する。ヘッダマーカを用いる一部の実施形態では、最終フィールドは任意選択で割愛される。LPNフィールドは、ヘッダが関連付けられているLPNである。LPNフィールドは、特定のLPNと関連付けられたヘッダのうちの特定のヘッダを、例えば、特定のLPNと一致するLPNフィールドを有するヘッダを求めてヘッダをサーチすることによって決定するためのヘッダのパーシングを可能にする。長さフィールドは、データバイトのバイト単位の長さ(例えば、ヘッダ501と関連付けられたデータバイト421Aに何バイトのデータがあるか)である。一部の実施形態では、オフセットフィールド内のオフセットは、特定の粒度(8バイトの粒度など)に従って丸められる。
様々な実施形態では、特定のLPNと関連付けられた一部または全部の情報が、特定のLPNと関連付けられたマップエントリ、特定のLPNと関連付けられたヘッダ、またはその両方に記憶される。例えば、一部の実施形態では、長さ519の一部または全部が、ヘッダではなくマップエントリに記憶される。
図6に、論理スライスおよび/またはセクションとして管理される複数のNVMデバイス(1若しくはそれ以上のフラッシュダイおよび/またはフラッシュチップなど)のブロック、ページ、および読み出し単位の実施形態の選択された詳細を示す。管理機能は、読み出し機能、再利用機能、消去機能、プログラミング/書き込み機能、および他の管理機能のうちの任意の1若しくはそれ以上を含む。論理スライスおよび/またはセクションはR−ブロックと呼ばれることもある。図には、66個のフラッシュダイを有する実施形態が示されている。フラッシュダイのうちの3つは明示的に図示されており(フラッシュダイ610.65、610.1、および610.0)、フラッシュダイのうちの63個は暗黙的に図示されている(610.64...610.2)。
フラッシュダイの各々(フラッシュダイ610.65...610.1、および610.0のうちの任意の1つなど)は、ブロック(フラッシュダイ610.65のブロック610.65BB...610.65B1、および610.65B0;フラッシュダイ610.0のブロック610.0BB...610.0B1、および610.0B0;以下同様など)として編成された記憶を提供する。各ブロックはさらに、ページ(ブロック610.65B0のページ610.65PP...610.65P1、および610.65P0;ブロック610.0B0のページ610.0PP...610.0P1、および610.0P0;以下同様など)を含む。各ページはさらに、読み出し単位(ページ610.65P0の読み出し単位610.65RR...610.65R1、610.65R0;ページ610.0P0読み出し単位610.0RR...610.0R1、610.0R0;以下同様など)を含む。
ある実施形態では、各フラッシュダイは整数個のブロック(N個のブロックなど)を含み、1ブロックは消去の最小量である。ある実施形態では、各ブロックは整数個のページを含み、1ページは書き込みの最小量である。様々な実施形態によれば、以下のうちの1若しくはそれ以上が該当する:読み出し単位は読み出しおよび誤り訂正の最小量である;各ページは整数個の読み出し単位を含む;関連付けられた2若しくはそれ以上のページのグループは整数個の読み出し単位を含む;ならびに読み出し単位は、任意選択で、かつ/または選択的にページ境界にまたがる。
様々な実施形態において、様々なNVM管理機能(読み取り、再利用、消去、および/またはプログラミング/書き込みなど)はR−ブロック単位で行われる。R−ブロックは、フラッシュメモリなどの様々なダイ(例えば、すべてのダイ、全部若しくは一部に障害のあるダイを除くすべてのダイ、および/またはダイのうちの1若しくはそれ以上の選択サブセットなど)にまたがる論理スライスまたはセクションとして例示される。例えば、R個のフラッシュダイを有し、各フラッシュダイがN個のブロックを有するフラッシュメモリにおいて、各R−ブロックは、合計でN個のR−ブロックについて、フラッシュダイの各々からの第iのブロックを合わせたものである。別の例では、R個のフラッシュダイを有し、各フラッシュダイがN個のブロックを有するフラッシュメモリにおいて、各R−ブロックは、合計でN/2個のR−ブロックについて、フラッシュダイの各々からの第iおよび第(i+1)のブロックである。さらに別の例では、複数のデュアル・プレーン・デバイスを有するフラッシュメモリにおいて、各R−ブロックは、デュアル・プレーン・デバイスの各々からの第iの偶数ブロックおよび第iの奇数ブロックである。最後の例では、R個のフラッシュダイを有し、各フラッシュダイがN個のブロックを有するフラッシュメモリにおいて、各R−ブロックは、合計でN/k個のR−ブロックについて、フラッシュダイの各々からの第iから第(i+k−1)までのブロックである。
R−ブロック形成の一部としてブロックが対または他の関連付けられたグループとして処理される様々な実施形態において、ブロックの関連付けられたグループの各ブロックからのそれぞれのページは、より大きいマルチブロックページを形成する、少なくとも書き込みのための単位としても扱われる。例えば、前述のデュアルプレーンの例を続けると、偶数ブロックのうちの特定の1つの第1ページおよび奇数ブロックの関連付けられた1つの第1ページは、書き込みの単位として扱われ、任意選択で、かつ/または選択的に、読み出しの単位としても扱われる。同様に、特定の偶数ブロックの第2ページおよび関連付けられた奇数ブロックの第2ページも単位として扱われる。様々な実施形態によれば、本明細書で使用するNVMのページは、NVMの単一のページ、NVMのマルチブロックページ、任意選択で、かつ/または選択的に読み出しのための1若しくはそれ以上の個別ページとして扱われる書き込みのためのNVMのマルチブロックページ、およびNVMのページの任意の他のグループ化または関連付けのうちの1若しくはそれ以上を指す。
図には、複数の例示的R−ブロックが示されており、そのうちの3つ(660.0、660.1、および660.R)が明示されている。各例示的R−ブロックは、フラッシュダイの各々からの第iのブロックを合わせたものである。例えば、R−ブロック660.0は、フラッシュダイ610.65からのブロック610.65B0、フラッシュダイ610.64からのブロック0(明示的に図示されていない)、以下同様にフラッシュダイ610.1のブロック610.1B0、およびラッシュダイ610.0のブロック610.0B0までである。1フラッシュダイ当たりN個のブロックがあるため、合計でN個のR−ブロック(R−ブロック660.R...R−ブロック660.1、およびR−ブロック660.0)がある。
R−ブロックの別の例が、フラッシュダイの各々からの第iブロックおよび第(i+1)のブロックを合わせたものである(例えば、フラッシュダイ610.65からのブロック610.65B0および610.65B1、フラッシュダイ610.64からのブロック0および1(明示的に図示されていない)、以下同様にフラッシュダイ610.1からのブロック610.1B0および610.1B1、ならびにフラッシュダイ610.0からのブロック610.0B0および610.0B1まで)。よって、各フラッシュダイにN個のブロックがある場合には、N/2個のR−ブロックがある。R−ブロックのさらに別の例は、複数のデュアルプレーンデバイスの各々からの第iの偶数ブロックおよび第iの奇数ブロックである。R−ブロックとしての管理のためのフラッシュ・ダイ・ブロックの他の構成も企図されており、これは、たとえいくつかのブロックが動作不能であってもR−ブロックが各ダイからの1ブロックを有するようにするための仮想ブロックアドレスと物理ブロックアドレスとの間のマッピングを含む。様々な実施形態において、各フラッシュダイ内のN個のブロックのうちのあるものは、仮想ブロックアドレスと物理ブロックアドレスとの間のマッピングが、R−ブロック内のブロックのうちの欠陥のあるブロックを置き換えるための予備の(通常は使用されない)ブロックを有するように予備として使用される。
様々な実施形態において、フラッシュダイ内の情報の読み出しおよび/または書き込みは、「読み出し単位優先」順や「ページ優先」順といった順序に従って行われる。図に示す読み出し単位についての読み出し単位優先順の一例は、読み出し単位610.0R0から開始し、その後に、610.1R0...610.65R0、610.0R1、610.1R1...610.65R1が続き、以下同様に続いて610.65RRで終了する。図に示す読み出し単位についてのページ優先順の一例は、読み出し単位610.0R0から開始し、その後に、610.0R1...610.0RR、610.1R0、610.1R1...610.1RR...610.65R0、610.65R1が続き、以下同様に続いて610.65RRで終了する。
様々な実施形態において、R−ブロック内のデータの書き込みおよび/またはストライピングの順序は(例えば最低から最高への)ページ優先で、すべてのデバイスに及び(例えば、ストライピング方向600で概念的に示唆するように、最低番号のデバイスから最高番号のデバイスへ)、次いで、次に高いページへ進み(すべてのデバイスに及び)、以下同様に、R−ブロックの最後のページまで続く。具体的には、R−ブロック660.0に関して、順序の一例は、ページ610.0P0(フラッシュダイ610.0の第1ブロック内の第1ページ)から開始し、その後に、ページ610.1P0(フラッシュダイ610.1の第1ブロック内の第1ページ)が続き、以下同様に、ページ610.65P0(フラッシュダイ610.65の第1ブロック、およびR−ブロック660.0の最後のブロック内の第1ページ)まで続く。この順序の例は続いてページ610.0P1(フラッシュダイ610.0の第1ブロック内の第2ページ)に進み、その後に、ページ610.1P1(フラッシュダイ610.1の第1ブロック内の第2ページ)が続き、以下同様に、ページ610.65P1(フラッシュダイ610.65の第1ブロック内の第2ページ)まで続く。例は同一の順で続く。この順序の例は、ページ610.0PP(フラッシュダイ610.0の第1ブロック内の最後のページ)に進み、その後に、ページ610.1PP(フラッシュダイ610.1の第1ブロック内の最後のページ)が続き、以下同様に、ページ610.65PP(フラッシュダイ610.65の第1ブロック内の最後のページ、およびR−ブロック660.0の最後のブロック内の最後のページ)で終了して完了する。
様々な実施形態において、フラッシュダイ610.65...610.1、および610.0は、図1Aの1若しくはそれ以上の個別フラッシュダイ194のそれぞれのものに対応する。ある実施形態では、フラッシュダイ610.65...610.1、および610.0は、NVM199の全部ではない部分である。例えば、様々な実施形態において、データはフラッシュダイの複数のグループに亘って独立的にストライピングされ、フラッシュダイのグループの各々は独立にアクセス可能である。
バンド選択
図7に、SSDのNVMの特定のバンドにデータを選択的に配置するSSDの実施形態の選択された詳細を概念的に図示する。概念的には、SSDのNVMへの書き込みは書き込みデータソース700の1若しくはそれ以上の要素から発生し、バンド管理710によって分析され、データ変換717によって変換され、SSDのNVMの特定のデータバンド730に配置される。
ある実施形態では、書き込みデータソース700の要素がNVMに書き込みデータ708を提供する。書き込みデータソース700の要素の例には、ホストデータ701、再利用データ702、システムデータ703、および他のデータ704が含まれる。ある実施形態では、バンド管理710は書き込みデータソースのいくつかまたはすべての要素を全く同様に処理する。例えば、ある実施形態はシステムデータとホストデータとを全く同様に扱う。様々な実施形態において、書き込みデータソースは上記以外の要素を含む。ホストデータ701の一例は、(例えばホストインターフェース111を介して、またはホスト102から)ホストによって書き込まれたデータである。再利用データ702の一例は、(例えばリサイクラ151によって)書き換えられたデータである。システムデータ703の一例は、マップ711に関するデータである。ある実施形態では、システムデータ703はSSDコントローラ100によって生成される。他のデータ704は、ホストデータでも、再利用データでも、システムデータでもないデータを含む。
ソースID706は、書き込みデータソースの要素間のマルチプレクサを制御し、どの要素が書き込みデータ708および関連付けられたソース情報707を提供するか指示する。ソース情報はバンド管理710に伝えられる。ソース情報の例には、書き込みデータのLBA、書き込みデータのLBA範囲、R−ブロックアドレス、および/または(例えば再利用データについて)以前に再利用データがどのバンドに配置されたかが含まれる。書き込みデータはデータ分析713に送られる。
バンド管理710は、書き込みデータおよびソース情報の特性を決定し、適切なバンドを選択する。図示の実施形態では、バンド管理710は、複数のモジュール、すなわちマップ711、LBAカウンタアレイ712、データ分析713およびバンドセレクタ714を含む。
図示の実施形態では、LBAカウンタアレイは、LBAへのアクセスの特性を追跡する(例えば、各々が、LBAまたは、例えば、隣接したLBAのグループへの読み取り/書き込み動作の数をそれぞれ追跡する複数のカウンタなど)。マップ711はLBAをNVMのブロックアドレスおよび/またはページアドレスに変換し、各マップエントリはLBAカウンタアレイ712の要素と関連付けられる。LBAカウンタアレイの要素は、各々が、関連付けられたLBAまたは、例えば、隣接したLBAのグループに関する情報をそれぞれ追跡する1若しくはそれ以上のカウンタを含む。様々な実施形態において、LBAカウンタアレイの各要素は、関連付けられたLBAへの読み取り、関連付けられたLBAへの書き込み、関連付けられたLBAへの読み取り対関連付けられたLBAへの書き込みの比、関連付けられたLBAへの連続した読み取り、関連付けられたLBAへの連続した書き込み、および関連付けられたLBAへの書き込みによって増分され、関連付けられたLBAへの読み取りによって減分されるカウンタのうちの1つ若しくは複数を含む。いくつかの実施形態では、ソース情報(LBAなど)を使用してLBAカウンタアレイがアクセスされ、LBAカウンタアレイの特定の要素から書き込みデータに関する情報が取り出される。
図示の実施形態では、データ分析713は、書き込みデータ708の特性を決定する。一例として、データ分析は、書き込みデータのウィンドウがx86相対分岐命令であるように見える閾値数のデータバイトを含むかどうか調べ、よって、書き込みデータが実行可能データであると判定する。いくつかの実施形態では、実行可能データは、例えば、相対アドレスを絶対アドレスに変換することによってさらに変換される。別の例として、データ分析は、書き込みデータが圧縮不能であるかどうか調べる(例えば、データは、JPEG、MP3、PDF、MPEG、ZIPなどといった圧縮形式、または暗号化データである)。ある使用シナリオでは、実行可能データおよび圧縮不能データが特定の時間間隔にわたって書き込まれるよりも相対的により頻繁に読み取られ、ある実施形態では、特定のバンドに選択的に配置される。データ分析の様々な実施形態は、ソフトウェア、ファームウェア、および/またはハードウェアの任意の組み合わせを含む。
ある実施形態では、任意選択のヒント部705が書き込みデータと関連付けられたソース情報707を受け取り、任意選択のヒント709をバンドセレクタ714に伝える。第1の例として、ヒントは、書き込みデータが読み取り専用またはほとんど読み取り専用(例えば、マルチメディアデータや、データベース内の読み取り専用表など)であり、したがって、書き込まれる可能性が低いと指示する。第2の例として、ヒントは、書き込みデータが書き込み専用またはほとんど書き込み専用(例えば、ログファイルやファイル・システム・ジャーナルなど)であり、したがって、読み取られる可能性が低いと指示する。ヒント部の様々な実施形態は、ソフトウェア、ファームウェア、および/またはハードウェアの任意の組み合わせを含む。様々な実施形態において、ヒント部のソフトウェアおよび/またはファームウェアはCPU171上で実行される。様々な実施形態において、ヒント部は、ソース情報(例えば、LBA、LBA範囲など)をヒントと関連付ける表を含む。ある実施形態では、ヒント部は、少なくとも部分的に、(例えば、ホストデータ701を提供する)ホストから受け取られるヒント情報に基づいて動作する。
図示の実施形態では、LBAカウンタアレイ712、データ分析713によって決定された特性のある組み合わせ、および/または任意選択のヒント709に基づき、ソースID706と組み合わせて、バンドセレクタ714は、データバンド730の中から書き込みデータ708のバンドを選択する。ある実施形態では、バンドセレクタは、SSDの性能、ウェアレベリング、電力消費および/または信頼性を改善するようにバンドを選択する。ある実施形態では、バンドセレクタは、相対的により頻繁に書き込まれると判定される書き込みデータ(例えば、新しく書き込まれたホストデータや、LBAカウンタが特定の時間間隔にわたる相対的に多くの書き込みを指示する場合など)にはよりホットなバンドを選択する。バンドセレクタは、あまり頻繁に書き込まれないと判定される書き込みデータ(例えば、実行可能データまたは圧縮データや、LBAカウンタが特定の時間間隔にわたる相対的に少ない書き込みを指示する場合や、再利用データなど)にはよりコールドなバンドを選択する。ある使用シナリオでは、再利用は、ホットなデータとコールドなデータとを異なるバンドに分離することになる。というのは、バンドセレクタは再利用データにはよりコールドなバンドを選択するが、頻繁に書き込まれるデータにはよりホットなバンドを選択するからである。ある実施形態では、ヒントは、ホットなデータとコールドなデータの分離を促進し、(例えばホストデータ701からの)書き込みデータがコールドであると指示することによって、バンドセレクタがコールドバンドを選択するようにする。ある実施形態では、書き込み障害を有する可能性の高いNVMセルを含むブロックは、コールドバンドに割り振られ、よって信頼性が改善される。ある実施形態では、書き込み障害を有する可能性の低いNVMセルを含むブロックはホットバンドに割り振られて、ウェアレベリングおよび信頼性が改善される。ある使用シナリオでは、ホットバンドはより多くの空き領域のあるブロックを有し、よって、より効率のよい再利用を可能にする。
ある実施形態では、バンドセレクタは、圧縮不能な書き込みデータに圧縮不能バンドを選択する。ある実施形態では、バンドセレクタは、圧縮可能な書き込みデータに圧縮可能バンドを選択する。ある実施形態では、バンドセレクタは、実行可能な書き込みデータに実行可能バンドを選択する。ある実施形態では、バンドセレクタは、(例えばLBAカウンタアレイ若しくはヒントによって)書き込み専用であると判定される書き込みデータにはホットバンドを選択し、他の要因を無効にする。ある実施形態では、バンドセレクタは、書き込み専用であると判定される書き込みデータには再利用の対象とされないバンドを選択する。
図示の実施形態では、書き込みデータ716はデータ変換717に送られる。様々な使用シナリオにおいて、データ変換は、書き込みデータを暗号化し、かつ/または圧縮し、変換データ718を出力する。データ変換の様々な実施形態は、ソフトウェア、ファームウェア、および/またはハードウェアの任意の組み合わせとして実装される。様々な実施形態において、データ変換は、概念的には、データ分析の前に、データ分析と並列に、データ分析の後で、またはデータ分析と組み合わせて行われる。例えば、ある実施形態では、データ変換によって行われる処理は、データ分析によって使用される書き込みデータの特性を決定する。様々な実施形態において、データ変換は書き込みデータを変換せず、変換データは、書き込みデータと全く同一、すなわち同じものである。
バンドセレクタは、選択したバンドのバンドID715をデータバンド730に伝える。バンドIDは、バンド731、732、...73Nのうちのどれが選択されたか指示する。各バンドは、書き込みデータを受け取るのに利用可能なR−ブロックを含む。変換データ718は、選択されたバンド内の利用可能なR−ブロックに送られ、NVMに書き込まれる。
様々な実施形態において、図示のデータバンド730は概念的なものであり、基礎をなす記憶および関連付けられた制御機能を表している。一例として、データバンド730は、NVMと、バンドID715によって識別されるNVMの特定の領域に変換データ718を宛先指定するためのハードウェア、ソフトウェア、および/またはファームウェアの任意の組み合わせとを含む。図1Aのコンテキストでは、例えば、基礎をなす記憶はNVM199の任意の部分に対応し、関連付けられた制御機能は、CPUコア172、バッファ管理175、およびスケジューリング193のうちの任意の1若しくはそれ以上に対応する。
様々な実施形態において、データバンド730のバンドのうちの1若しくはそれ以上はNVM(NVM199など)のブロックの被管理グループである。例えば、図示の実施形態では、R−ブロック731.1...731.MはNVMのブロックであり、バンド1 731はR−ブロック731.1...731.Mの被管理グループである。様々な実施形態において、R−ブロック660.0はR−ブロック731.1...73N.Kの一実装例である。
様々な実施形態において、バンドはもっぱら、書き込みデータソース700の要素のうちの特定の1つだけからのブロックのみを含む。様々な実施形態において、書き込みデータソースの要素の特定の1つは、ホストデータ701、再利用データ702、システムデータ703、および他のデータ704のうちのいずれか1つである。それぞれの実施形態において、バンドは、それぞれ、もっぱら再利用ホストデータだけ、再利用システムデータだけ、および再利用ホストデータと再利用システムデータの組み合わせだけを含むブロックを含む。
別の例として、バンドはもっぱら、システム703データの下位ページブロックだけを含む。別の例として、バンドはもっぱら、頻繁に読み取られる上位ページブロックだけを含む。別の例として、バンドはもっぱら、頻繁に読み取られるシステム703データを有するブロックだけを含む。別の例として、バンドはもっぱら、頻繁に書き込まれるシステム703データを有する上位ページブロックだけを含む。
図8に、LBAからNVMへの位置マッピング800として、FLMと1若しくはそれ以上のSLMページとを有する2レベルマップによる、LBAからNVMに記憶されたLBへのマッピングの実施形態の選択された詳細を図示する。2レベルマップは、(概念的には単一の要素SLMページ820として図示されている)1若しくはそれ以上の第2レベル要素に結合された第1レベル要素(FLM810)によって実施される。FLMは複数のエントリ(SLMページ/長さ810.1...SLMページ/長さ810.M)を有する。FLMのエントリの各々はSLMページのうちの1つ(例えばSLMページ820)を指し示す。SLMページは複数のエントリ(LBページ/長さ820.1...LBページ/長さ820.N)を有する。SLMページのエントリの各々は、データが開始するNVM内の位置(例えば、少なくとも、LBAについてのホスト書き込みデータの先頭を記憶している読み出し単位など)を指し示す。
様々な実施形態では、図は、図1Aのマップ141および/若しくは表143の、またはそれらに関連した選択された詳細を示す。例えば、ある実施形態では、マップ141および/または表143は、例えば、FLMの1若しくはそれ以上のエントリおよび/またはSLMの1若しくはそれ以上のエントリといったマッピング情報の1若しくはそれ以上のキャッシュを実施する。FLMおよび/またはSLMの全体イメージは、NVM(図1AのNVM199など)の一部分に維持され、例えば、キャッシュが前にキャッシュされたFLMおよび/またはSLMエントリを置き換えるときに更新される。ある実施形態では、FLMおよび/またはSLMの全体イメージは、ローリングチェックポイントまたはピンポンチェックポイントによって実施され、チェックポイントの各々はそれぞれの全体マップイメージの一部分である。
様々な実施形態においてSLMページのエントリの各々は、LBAカウンタと関連付けられ、これにより、各LBA821は、LBA対NVM位置マッピング800によってLBAカウンタと関連付けられる。例えば、図示の実施形態では、LBページ/長さ820.1はLBAカウンタ822.1と関連付けられており、LBページ/長さ820.2はLBAカウンタ822.2と関連付けられており、LBページ/長さ820.NはLBAカウンタ822.Nと関連付けられている。ある実施形態では、LBAカウンタはSLMページ820に記憶され、別の実施形態では、LBAカウンタは、SLMページ820とは別個のデータ構造に記憶される。ある実施形態では、LBAカウンタは隣接したLBAの範囲と関連付けられ、別の実施形態では、LBAカウンタは単一のLBAと関連付けられ、別の実施形態では、あるLBAカウンタは隣接したLBAの範囲と関連付けられ、別のLBAカウンタは単一のLBAと関連付けられる。ある実施形態では、LBAカウンタは関連付けられたLBAに関する1若しくはそれ以上の統計を含む。統計のいくつかの例としては、連続した読み取り回数、連続した書き込み回数、読み取り回数、書き込み回数、読み取り回数対書き込み回数の比、および読み取り回数と書き込み回数との差である。ある実施形態では、LBAへの一部または全部のアクセスがそれぞれのLBAカウンタを更新する。ある実施形態では、LBAへの第1のアクセスが関連付けられたLBAカウンタを初期設定する。
除算器(整数除算器822)は、入ってくるLBAを除算するための、例えばプログラマブル・ハードウェア・レジスタなどからのパラメータ(SLMエントリ/SLMページ(CSR)823)を受け取って、どのFLMエントリを選択すべきか、および(選択したFLMエントリによって指し示されるSLMページ内の)どのSLMエントリを選択すべきか判定する。除算器はFLMページとSLMページとに結合されている。
動作に際して、LBA821が整数除算器822に提示される。除算器はLBAを、SLMエントリ/SLMページ(CSR)823によって提供される、1SLMページ当たりのSLMエントリ数で除算し、結果として商(FLMインデックス822Q)および余り(SLMページインデックス822R)を得る。商はFLMエントリのうちの1つを選択するのに使用され、選択されたFLMエントリのページフィールドが読み取られる(SLMポインタ810S)。ページフィールドはSLMページのうちの1つ(SLMページ820など)を選択するのに使用され、余りは選択されたSLMページのエントリを選択するのに(オフセットなどとして)使用される。選択されたSLMページエントリのページフィールドは、提示されたLBAに対応するLBの少なくとも始まりが記憶されている(LBポインタ820L)、特定の読み取り単位といったNVM内の特定の位置を選択するのに使用される。様々な実施形態において、LBポインタは、NVMの読み取り単位のアドレス(図2の読み取り単位アドレス223など)を含む。ある実施形態では、個々のSLMエントリの各々は、例えば、個々のSLMエントリの個々のLBのデータと関連付けられた長さおよび/または範囲などを符号化したフィールドを含む。例えば、範囲は、個々のLBの(誤り訂正)データを決定するためのすべての情報(未訂正データおよび関連付けられた誤り訂正検査ビット)を得るのにいくつの(連続した)読み取り単位がアクセスされるかを記述する。引き続きこの例では、長さは、(例えば、図2の読み取り単位での長さ225によって例示されるような、読み取り単位での)読み取られた情報のうちのどれほどの情報が個々のLBのデータに対応するかを記述する。ある実施形態では、個々のFLMエントリの各々は、例えば、FLMエントリのページフィールドによって指定される個々のSLMページ全体の読み取りと関連付けられた長さおよび/または範囲などを符号化したフィールドを含む。例えば、範囲は、個々のSLMページの(誤り訂正)データを決定するためのすべての情報(未訂正データおよび関連付けられた誤り訂正検査ビット)を得るのにいくつの(連続した)読み取り単位がアクセスされるかを記述する。引き続きこの例では、長さは、(例えば、図2の読み取り単位での長さ225によって例示されるような、読み取り単位での)読み取られた情報のうちのどれほどの情報が個々のSLMページのデータに対応するかを記述する。
様々な実施形態では、商は、キャッシュ、例えば、SLMページのフル・アソシアティブ・キャッシュにアクセスするためのキーとして使用される。キャッシュに特定のSLMページについてのヒットがある場合には、特定のSLMページの最も遅いコピーがNVMにアクセスせずにキャッシュ内で見つかる。複数のSLMページへの高速アクセスを提供することにより、一部の実施形態および/または使用シナリオでは、NVMへのランダムアクセスおよび/または複数の独立ストリームのより効率的な処理(例えば、LBAの第1の領域への順次データアクセスの第1のストリームに、LBA第2の領域への順次データアクセスの第2のストリームを割り込ませるなど)が可能になる。
図9に、(SSD内などの)NVMのデータバンドのバンド管理フロー900の実施形態の選択された詳細の流れ図を示す。バンド管理フロー900は、バンド管理フローの様々な態様(例えば、図7のバンド管理710によって行われる処理など)の一動作例である。バンド管理フローは、複数の書き込みデータソース(図7の書き込みデータソース700など)の要素から書き込みデータ(図7の書き込みデータ708など)およびソース情報(図7のソース情報707など)を受け取る工程を含む。バンド管理フローは、書き込みデータをデータバンド(図7のデータバンド730など)に選択的に配置する工程をさらに含む。
書き込みデータソースが書き込みデータを提供したことに応答して、フローが開始する(開始901)。バンド管理フローは、書き込みデータソースから書き込みデータおよび書き込みデータソースを識別するソース情報を受け取る(書き込みデータ、ソース情報を受け取る902)。バンド管理フローは、書き込みデータおよびソース情報を分析して書き込みデータの特性および書き込みデータへのアクセスの特性を決定する(書き込みデータ、ソース情報を分析する903)。決定した特性に基づき、バンド管理フローは書き込みデータのためのバンドを選択する(データバンドを選択する904)。バンド管理フローは、選択したバンドの標識をバンド標識(図7のバンドID715など)として、複数のデータバンド(図7のデータバンド730など)を有し、管理し、かつ/または制御する要素に送る。バンド管理フローは書き込みデータをデータ変換要素(図7のデータ変換717など)に送り、データ変換要素はデータを変換し、変換データを書き込みのために選択されたデータバンドに送る(データをバンドに割り当てる905)。フローは次いで完了する(終了906)。
様々な実施形態において、図7は、図1Aおよび図1Bの、またはこれらの図に関連した選択された詳細を示すものである。例えば、マップ711および/またはLBAカウンタアレイ712の全部または任意の部分は、マップ141および/または表143の全部または任意の部分に対応する。ある実施形態では、LBAカウンタアレイ712はマップ141および/または表143の一部分であり、別の実施形態では、LBAカウンタアレイ712はマップ141とは別個のデータ構造である。
ある実施形態では、バンド管理710の部分がSSDコントローラ100の部分によって実装される。例えば、データ分析713および/またはデータ変換717は、その全部または一部が、CPU171上で実行されるソフトウェアおよび/またはファームウェアとして実装される。別の例では、SSDコントローラ100は、データ分析713および/またはデータ変換717に使用されるハードウェアを含む。
様々な実施形態において、図8は、図1Aのマップ141および/若しくは表143、ならびに/または図7のマップ711および/若しくはLBAカウンタアレイ712の、またはこれらに関連した選択された詳細を図示するものである。様々な実施形態において、LBA対NVMマッピング800は、マップ141および/またはマップ711の任意の部分の実装形態である。様々な実施形態において、表143は複数のFLMページ810および/またはLSMページ820を含む。
実施技法の例
ある実施形態では、(例えばフラッシュメモリを有する)不揮発性記憶、コンピューティングホスト・フラッシュ・メモリ・コントローラ、および/またはSSDコントローラ(例えば図1AのSSDコントローラ100)、ならびにプロセッサ、マイクロプロセッサ、システム・オン・チップ、特定用途向け集積回路、ハードウェアアクセラレータ、または前述の動作の全部または部分を提供する他の回路を管理するための自己ジャーナリングおよび階層的整合性を実施するシステムによって行われる動作の全部またはいずれかの部分の様々な組み合わせが、コンピュータシステムによる処理と適合する仕様によって指定される。仕様は、様々な記述、例えば、ハードウェア記述言語、回路記述、ネットリスト記述、マスク記述、またはレイアウト記述に従ったものである。記述の例には、Verilog、VHDL、SPICE、SPICEの変形、例えば、PSpice、IBIS、LEF、DEF、GDS−II、OASIS、または他の記述が含まれる。様々な実施形態では、処理は、1若しくはそれ以上の集積回路上に含めるのに適する論理および/または回路を生成し、検証し、または指定するための解釈、コンパイル、シミュレーション、および合成の任意の組み合わせを含む。各集積回路は、様々な実施形態によれば、様々な技法に従って設計することができ、かつ/または製造することができる。技法には、プログラマブルな技法(例えば、フィールド若しくはマスク・プログラマブル・ゲート・アレイ集積回路)、セミカスタムの技法(例えば、全部若しくは一部がセルベースの集積回路)、およびフルカスタムの技法(例えば、実質的に専門化された集積回路)、それらの任意の組み合わせ、または集積回路の設計および/若しくは製造と適合する任意の他の技法が含まれる。
ある実施形態では、命令のセットを記憶しているコンピュータ可読媒体によって記述される動作の全部または部分の様々な組み合わせが、1若しくはそれ以上のプログラム命令の実行および/若しくは解釈によって、1若しくはそれ以上のソースおよび/若しくはスクリプト言語命令文の解釈および/若しくはコンパイルによって、または、プログラミングおよび/若しくはスクリプティング言語命令文で表現された情報をコンパイルし、変換し、かつ/または解釈することによって生成されるバイナリ命令の実行によって実行される。命令文は任意の標準のプログラミングまたはスクリプティング言語(例えば、C、C++、Fortran、Pascal、Ada、Java(登録商標)、VBscript、Shell)と適合する。プログラム命令、言語命令文、またはバイナリ命令のうち1若しくはそれ以上が、任意選択で、1若しくはそれ以上のコンピュータ可読記憶媒体要素上に記憶される。様々な実施形態では、プログラム命令の一部、全部、または様々な部分が、1若しくはそれ以上の関数、ルーチン、サブルーチン、インラインルーチン、プロシージャ、マクロ、またはそれらの部分として実現される。
結論
ある特定の選択が、説明において、テキストおよび図面を作成するに際の単なる便宜のためになされており、別の指示がない限り、それらの選択は、それ自体で、前述の実施形態の構造または動作に関する追加情報を伝えるものと解釈すべきではない。選択の例には、図の符番に使用される呼称の特定の編成または割り当て、および実施形態の特徴および要素を識別し、参照するのに使用される要素識別子(コールアウトや数値識別子など)の特定の編成または割り当てが含まれる。
「includes」または「including」という語は、開放型範囲の論理集合を記述する抽象概念として解釈されるべきことが明確に意図されており、後に続けて「within」という語が明示されない限り物理的包含を伝えるためのものではない。
前述の実施形態は、説明および理解の明確さのためにある程度詳細に説明されているが、本発明は提示した詳細だけに限定されるものではない。本発明の多くの実施形態がある。開示の実施形態は例示であり、限定ではない。
説明と整合性を有する、構成、配置、および使用における多くの変形が可能であり、それらの変形は、発行される特許の特許請求の範囲内にあることが理解されるであろう。例えば、相互接続および機能ユニットのビット幅、クロック速度、および使用される技術の種類は、各構成要素ブロックにおける様々な実施形態に従って変わりうる。相互接続および論理に与えられた名称は、単なる例であり、説明した概念を限定するものと解釈すべきではない。フローチャートおよび流れ図のプロセス、動作、および機能要素の順序および配置は、様々な実施形態に従って変わりうる。また、特に別に指定しない限り、指定される値範囲、使用される最大値および最小値、または他の特定の仕様(例えば、フラッシュメモリ技術の種類、レジスタおよびバッファ内のエントリまたは段の数)は、単に前述の実施形態のものにすぎず、実施技術の改善および変更を追跡することが見込まれるものであり、限定として解釈すべきではない。
当分野で公知の機能的に等価の技法を、様々なコンポーネント、サブシステム、動作、関数、ルーチン、サブルーチン、インラインルーチン、プロシージャ、マクロ、またはそれらの部分を実施するのに、前述の技法の代わりに用いることができる。また、実施形態の多くの機能的態様を、より高速な処理(以前にハードウェアにあった機能のソフトウェアへの移行を円滑化する)およびより高い集積密度(以前にソフトウェアにあった機能のハードウェアへの移行を円滑化する)の実施形態に依存する設計制約条件および技術傾向に応じて、選択的に、ハードウェア(おおむね専用の回路など)で、またはソフトウェアで(例えば、プログラムされたコントローラ若しくはプロセッサのある方式によって)実現できることも理解される。様々な実施形態の具体的な変形は、これに限定されるものではないが、分割の違い、フォームファクタおよび構成の違い、異なるオペレーティングシステムおよび他のシステムソフトウェアの使用、異なるインターフェース規格、ネットワークプロトコル、または通信リンクの使用、本明細書で説明した概念を、特定の用途の固有の技術的業務的制約条件に従って実施するときに予期されるべき他の変形を含む。
各実施形態は、前述の各実施形態の多くの態様の最小限の実施に必要とされるものを大きく超えた詳細および環境的コンテキストと共に説明されている。ある実施形態は、残りの要素間での基本的協働を変更せずに開示の構成要素または機能を割愛することを当業者は理解するであろう。よって、開示の詳細の多くが前述の実施形態の様々な態様を実施するのに必要ではないことが理解される。残りの要素が先行技術と区別できる範囲内で、割愛される構成要素および特徴は本明細書で説明した概念を限定するものではない。
設計におけるすべてのそのような変形は、前述の実施形態によって伝えられる教示に対する実質的な変更ではない。また、本明細書で説明した実施形態は、他のコンピューティング用途およびネットワーキング用途に幅広い適用性を有し、前述の実施形態の特定の用途または産業だけに限定されるものではないことも理解される。よって本発明は、発行される特許の特許請求の範囲内に包含されるあらゆる可能な改変形態および変形形態を含むものと解釈すべきである。

Claims (25)

  1. 方法であって、
    ホストから受け取った書き込みを分析して前記書き込みの特性を決定する工程と、
    少なくとも部分的に前記特性に基づいて不揮発性メモリ(NVM)の複数のバンドのうちの1つを選択する工程と、
    前記書き込みのデータを前記選択したバンドに書き込む工程と
    を有し、
    前記バンドの各々は前記不揮発性メモリの被管理部分である方法。
  2. 請求項1記載の方法において、前記特性は前記書き込みのデータが圧縮可能であることを有する方法。
  3. 請求項1記載の方法において、前記特性は前記書き込みのデータが実行可能であることを有する方法。
  4. 請求項1記載の方法において、前記特性は、少なくとも部分的に、前記書き込みに対応する論理ブロックアドレス(LBA)と関連付けられたカウンタに基づくものである方法。
  5. 請求項4記載の方法において、さらに、
    前記カウンタによって前記LBAへの書き込み回数をカウントする工程を有するものである方法。
  6. 請求項4記載の方法において、さらに、
    前記カウンタによって前記LBAの読み取り回数と前記LBAの書き込み回数との差をカウントする工程を有するものである方法。
  7. 請求項1記載の方法において、
    前記書き込みは、1若しくはそれ以上のストレージインターフェース規格と適合するストレージインターフェースを介して前記ホストから受け取られ、
    前記データを書き込む工程は、少なくとも部分的に、前記不揮発性メモリと通信する
    フラッシュ・メモリ・インターフェースを介したものであり、
    前記不揮発性メモリは少なくとも1つのフラッシュメモリを有し、
    前記ストレージインターフェースおよび前記フラッシュ・メモリ・インターフェースは単一の集積回路に実装されたコントローラに具備される方法。
  8. 請求項1記載の方法において、前記バンドの各々は複数の論理特性のうちの少なくとも1つに対応すものであり、前記論理特性は、頻繁に読み取られること、相対的により頻繁に書き込まれること、相対的にあまり頻繁に書き込まれないこと、圧縮不能であること、実行可能であること、回復不能であり、電源喪失後に保存される必要があること、回復可能であり、電源喪失後に保存される必要がないこと、特定の技法若しくは鍵を使用して暗号化されること、特定の技法若しくは鍵を使用して、または特定の誤り訂正符号(ECC)方式を用いて誤りから保護されること、再利用の対象とされること、および再利用の対象とされないことを有する方法。
  9. システムであって、
    ホストから受け取った書き込みを分析して前記書き込みの特性を決定する手段と、
    少なくとも部分的に前記特性に基づいて不揮発性メモリ(NVM)の複数のバンドのうちの1つを選択する手段と、
    前記書き込みのデータを前記選択したバンドに書き込む手段と
    を有し、
    前記バンドの各々は前記不揮発性メモリの被管理部分であるシステム。
  10. 請求項9記載のシステムにおいて、前記特性は、前記書き込みのデータが圧縮可能であることを有するシステム。
  11. 請求項9記載のシステムにおいて、前記特性は、前記書き込みのデータが実行可能であることを有するシステム。
  12. 請求項9記載のシステムにおいて、前記特性は、少なくとも部分的に、前記書き込みに対応する論理ブロックアドレス(LBA)と関連付けられたカウンタに基づくものであるシステム。
  13. 請求項12記載のシステムにおいて、さらに、
    前記カウンタによって前記LBAへの書き込み回数をカウントする手段を有するものであるシステム。
  14. 請求項12記載のシステムにおいて、さらに、
    前記カウンタによって前記LBAの読み取り回数と前記LBAの書き込み回数との差をカウントする手段を有するものであるシステム。
  15. 処理要素によって実行されると、前記処理要素に動作を実行させ、かつ/または制御させる命令のセットが記憶されている有形の非一時的なコンピュータ可読媒体であって、前記動作は、
    ホストから受け取った書き込みを分析して前記書き込みの特性を決定する動作と、
    少なくとも部分的に前記特性に基づいて不揮発性メモリ(NVM)の複数のバンドのうちの1つを選択する動作と、
    前記書き込みのデータを前記選択したバンドに書き込む動作と
    を有し、
    前記バンドの各々は前記不揮発性メモリの被管理部分である有形の非一時的なコンピュータ可読媒体。
  16. 請求項15記載の有形の非一時的なコンピュータ可読媒体において、前記特性は、前記書き込みのデータが圧縮可能であることを有する有形の非一時的なコンピュータ可読媒体。
  17. 請求項15記載の有形の非一時的なコンピュータ可読媒体において、前記特性は、前記書き込みのデータが実行可能であることを有する有形の非一時的なコンピュータ可読媒体。
  18. 請求項15記載の有形の非一時的なコンピュータ可読媒体において、前記特性は、少なくとも部分的に、前記書き込みに対応する論理ブロックアドレス(LBA)と関連付けられたカウンタに基づくものである有形の非一時的なコンピュータ可読媒体。
  19. 請求項18記載の有形の非一時的なコンピュータ可読媒体において、前記動作は、前記カウンタによって前記LBAへの書き込み回数をカウントする動作をさらに有するものである有形の非一時的なコンピュータ可読媒体。
  20. 請求項18記載の有形の非一時的なコンピュータ可読媒体において、前記動作は、前記カウンタによって前記LBAの読み取り回数と前記LBAの書き込み回数との差をカウントする動作をさらに有するものである有形の非一時的なコンピュータ可読媒体。
  21. 請求項15記載の有形の非一時的なコンピュータ可読媒体において、
    前記書き込みは、1若しくはそれ以上のストレージインターフェース規格と適合するストレージインターフェースを介して前記ホストから受け取られ、
    前記データを書き込む動作は、少なくとも部分的に、前記不揮発性メモリと通信するフラッシュ・メモリ・インターフェースを介したものであり、
    前記不揮発性メモリは少なくとも1つのフラッシュメモリを有し、
    前記処理要素、前記ストレージインターフェースおよび前記フラッシュ・メモリ・インターフェースは単一の集積回路に実装されたコントローラに具備される有形の非一時的なコンピュータ可読媒体。
  22. 請求項15記載の有形の非一時的なコンピュータ可読媒体において、前記バンドの各々は複数の論理特性のうちの少なくとも1つに対応すものであり、前記論理特性は、頻繁に読み取られること、相対的により頻繁に書き込まれること、相対的にあまり頻繁に書き込まれないこと、圧縮不能であること、実行可能であること、回復不能であり、電源喪失後に保存される必要があること、回復可能であり、電源喪失後に保存される必要がないこと、特定の技法若しくは鍵を使用して暗号化されること、特定の技法若しくは鍵を使用して、または特定の誤り訂正符号(ECC)方式を用いて誤りから保護されること、再利用の対象とされること、および再利用の対象とされないことを有する有形の非一時的なコンピュータ可読媒体。
  23. 装置であって、
    ホストから受け取った書き込みを分析して前記書き込みの特性を決定する書き込み分析ハードウェア論理回路と、
    少なくとも部分的に前記特性に基づいて不揮発性メモリ(NVM)の複数のバンドのうちの1つを選択するバンド選択ハードウェア論理回路と、
    前記書き込みのデータを前記選択されたバンドに書き込むメモリ書き込みハードウェア論理回路と
    を有し、
    前記バンドの各々は前記不揮発性メモリの被管理部分である装置。
  24. 請求項23記載の装置において、前記特性は前記書き込みのデータが圧縮可能であることを有する装置。
  25. 請求項23記載の装置において、前記特性は前記書き込みのデータが実行可能であることを有する装置。
JP2014008182A 2013-01-22 2014-01-21 不揮発性メモリへの書き込みの管理および領域選択 Expired - Fee Related JP6387231B2 (ja)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US201361755442P 2013-01-22 2013-01-22
US61/755,442 2013-01-22

Publications (3)

Publication Number Publication Date
JP2014167790A true JP2014167790A (ja) 2014-09-11
JP2014167790A5 JP2014167790A5 (ja) 2017-02-02
JP6387231B2 JP6387231B2 (ja) 2018-09-05

Family

ID=49949587

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2014008182A Expired - Fee Related JP6387231B2 (ja) 2013-01-22 2014-01-21 不揮発性メモリへの書き込みの管理および領域選択

Country Status (6)

Country Link
US (1) US9395924B2 (ja)
EP (1) EP2757479A1 (ja)
JP (1) JP6387231B2 (ja)
KR (1) KR102155191B1 (ja)
CN (1) CN103942010B (ja)
TW (1) TWI537724B (ja)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106354745A (zh) * 2015-07-13 2017-01-25 三星电子株式会社 用于提供计算机装置的接口的方法和计算机装置
US10275165B2 (en) 2016-09-12 2019-04-30 Toshiba Memory Corporation Memory controller
US11461010B2 (en) 2015-07-13 2022-10-04 Samsung Electronics Co., Ltd. Data property-based data placement in a nonvolatile memory device

Families Citing this family (62)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101438716B1 (ko) 2011-08-09 2014-09-11 엘에스아이 코포레이션 I/o 디바이스 및 컴퓨팅 호스팅 상호동작
US9395924B2 (en) 2013-01-22 2016-07-19 Seagate Technology Llc Management of and region selection for writes to non-volatile memory
WO2016003481A1 (en) * 2014-07-04 2016-01-07 Hewlett-Packard Development Company, L.P. Data deduplication
TWI540582B (zh) * 2014-07-10 2016-07-01 群聯電子股份有限公司 資料管理方法、記憶體控制電路單元以及記憶體儲存裝置
US20160092118A1 (en) * 2014-09-26 2016-03-31 Intel Corporation Memory write management in a computer system
US9858008B2 (en) * 2014-10-30 2018-01-02 ScaleFlux Method to reduce flash memory IOs with host maintained address mapping table
WO2016086411A1 (zh) * 2014-12-05 2016-06-09 华为技术有限公司 一种控制器、闪存装置、识别数据块稳定性的方法以及在闪存装置中存储数据的方法
US9471448B2 (en) * 2014-12-10 2016-10-18 Intel Corporation Performing an atomic write operation across multiple storage devices
CN105900082B (zh) 2014-12-16 2019-05-24 华为技术有限公司 存储空间管理方法及装置
CN105917303B (zh) * 2014-12-23 2019-12-06 华为技术有限公司 一种控制器、识别数据块稳定性的方法和存储系统
US9678665B2 (en) 2015-03-06 2017-06-13 Western Digital Technologies, Inc. Methods and systems for memory page allocation
CN106155812A (zh) 2015-04-28 2016-11-23 阿里巴巴集团控股有限公司 一种对虚拟主机的资源管理的方法、装置、系统及电子设备
US20180225201A1 (en) * 2015-07-23 2018-08-09 Hewlett Packard Enterprise Development Lp Preserving volatile memory across a computer system disruption
KR102491624B1 (ko) 2015-07-27 2023-01-25 삼성전자주식회사 데이터 저장 장치의 작동 방법과 상기 데이터 저장 장치를 포함하는 시스템의 작동 방법
US9927984B2 (en) * 2015-10-14 2018-03-27 Samsung Electronics Co., Ltd. Electronic system with interface control mechanism and method of operation thereof
US9886398B2 (en) * 2015-12-01 2018-02-06 International Business Machines Corporation Implicit sharing in storage management
KR20170075855A (ko) * 2015-12-23 2017-07-04 에스케이하이닉스 주식회사 메모리 시스템 및 메모리 시스템의 동작 방법
US10481799B2 (en) * 2016-03-25 2019-11-19 Samsung Electronics Co., Ltd. Data storage device and method including receiving an external multi-access command and generating first and second access commands for first and second nonvolatile memories
KR102615593B1 (ko) * 2016-05-04 2023-12-21 에스케이하이닉스 주식회사 메모리 시스템 및 메모리 시스템의 동작 방법
TWI635746B (zh) * 2016-05-10 2018-09-11 晨星半導體股份有限公司 扭曲畫面校正裝置及方法
KR102567224B1 (ko) 2016-07-25 2023-08-16 삼성전자주식회사 데이터 저장 장치 및 이를 포함하는 컴퓨팅 시스템
US10229047B2 (en) * 2016-08-06 2019-03-12 Wolley Inc. Apparatus and method of wear leveling for storage class memory using cache filtering
KR20180021284A (ko) * 2016-08-18 2018-03-02 에스케이하이닉스 주식회사 메모리 시스템 및 메모리 시스템의 동작방법
US10216417B2 (en) * 2016-10-26 2019-02-26 Samsung Electronics Co., Ltd. Method of consolidate data streams for multi-stream enabled SSDs
CN106527987B (zh) * 2016-11-04 2019-06-04 湖南国科微电子股份有限公司 一种不带dram的ssd主控可靠性提升系统及方法
GB2559119B (en) * 2017-01-20 2020-12-30 Advanced Risc Mach Ltd Apparatus and methods to prolong lifetime of memories
US11188456B2 (en) * 2017-03-21 2021-11-30 Western Digital Technologies Inc. Storage system and method for predictive block allocation for efficient garbage collection
TWI625620B (zh) * 2017-05-12 2018-06-01 威盛電子股份有限公司 非揮發性記憶體裝置及其讀取方法
US10068663B1 (en) * 2017-05-30 2018-09-04 Seagate Technology Llc Data storage device with rewriteable in-place memory
US10275162B2 (en) 2017-06-23 2019-04-30 Dell Products L.P. Methods and systems for managing data migration in solid state non-volatile memory
FR3070081B1 (fr) * 2017-08-10 2021-04-09 Safran Identity & Security Procede d'ecriture d'un programme dans une memoire non-volatile tenant compte de l'usure de ladite memoire
KR20190052366A (ko) * 2017-11-08 2019-05-16 에스케이하이닉스 주식회사 컨트롤러 및 컨트롤러의 동작방법
CN109857330B (zh) * 2017-11-30 2022-02-15 宜鼎国际股份有限公司 数据存取效率的预估方法
CN108153487B (zh) * 2017-11-30 2021-04-13 西安空间无线电技术研究所 一种基于nand flash的星载固存多源数据文件系统
US10878859B2 (en) 2017-12-20 2020-12-29 Micron Technology, Inc. Utilizing write stream attributes in storage write commands
KR20190078133A (ko) * 2017-12-26 2019-07-04 에스케이하이닉스 주식회사 컨트롤러 및 그것의 동작방법
US11099831B2 (en) * 2018-02-08 2021-08-24 Micron Technology, Inc. Firmware update in a storage backed memory system
US11803325B2 (en) 2018-03-27 2023-10-31 Micron Technology, Inc. Specifying media type in write commands
WO2020028812A1 (en) * 2018-08-03 2020-02-06 Burlywood, Inc. Power loss protection and recovery
US11347653B2 (en) * 2018-08-31 2022-05-31 Nyriad, Inc. Persistent storage device management
CN109144424B (zh) * 2018-09-04 2021-10-15 浪潮电子信息产业股份有限公司 一种固态硬盘的读写方法、装置、设备及存储介质
US11169726B2 (en) 2018-09-13 2021-11-09 Toshiba Memory Corporation Pool-level storage management
CN112771493B (zh) * 2018-09-28 2022-06-24 波利伍德股份有限公司 将写入流分离到多个分区中
US10922178B2 (en) * 2018-10-31 2021-02-16 Hewlett Packard Enterprise Development Lp Masterless raid for byte-addressable non-volatile memory
CN109802684B (zh) * 2018-12-26 2022-03-25 华为技术有限公司 进行数据压缩的方法和装置
TWI740187B (zh) * 2019-02-20 2021-09-21 慧榮科技股份有限公司 存取方法
CN109918317A (zh) * 2019-03-01 2019-06-21 重庆大学 一种基于磨损感知的nvm条间磨损均衡方法
US11327809B2 (en) 2019-06-19 2022-05-10 International Business Machines Corporation Virtual machine memory removal increment selection
CN110716699A (zh) * 2019-10-17 2020-01-21 北京百度网讯科技有限公司 用于写入数据的方法和装置
CN111104066B (zh) * 2019-12-17 2021-07-27 华中科技大学 数据写入方法、装置及存储服务器和计算机可读存储介质
US11544185B2 (en) 2020-07-16 2023-01-03 Silicon Motion, Inc. Method and apparatus for data reads in host performance acceleration mode
US11429545B2 (en) 2020-07-16 2022-08-30 Silicon Motion, Inc. Method and apparatus for data reads in host performance acceleration mode
CN113946278A (zh) * 2020-07-16 2022-01-18 慧荣科技股份有限公司 主机效能加速模式的数据读取方法及装置
US11544186B2 (en) 2020-07-16 2023-01-03 Silicon Motion, Inc. Method and apparatus for data reads in host performance acceleration mode
KR20220067795A (ko) 2020-11-18 2022-05-25 삼성전자주식회사 스토리지 장치 및 이를 포함하는 스토리지 시스템
TWI821152B (zh) * 2021-02-23 2023-11-01 慧榮科技股份有限公司 儲存裝置、快閃記憶體控制器及其控制方法
TWI808384B (zh) * 2021-02-23 2023-07-11 慧榮科技股份有限公司 儲存裝置、快閃記憶體控制器及其控制方法
US11942111B2 (en) * 2021-06-15 2024-03-26 Western Digital Technologies, Inc. Data storage device and method for auto-peeling of surveillance video content to increase archival storage
TWI771079B (zh) * 2021-06-24 2022-07-11 群聯電子股份有限公司 記憶體存取方法、記憶體儲存裝置及記憶體控制電路單元
US20230015697A1 (en) * 2021-07-13 2023-01-19 Citrix Systems, Inc. Application programming interface (api) authorization
CN113590502B (zh) * 2021-07-23 2024-03-22 合肥康芯威存储技术有限公司 一种非挥发性记忆体存储设备的垃圾回收方法与垃圾回收系统
TWI814590B (zh) * 2022-09-26 2023-09-01 慧榮科技股份有限公司 資料處理方法及對應之資料儲存裝置

Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6269413B1 (en) * 1998-10-30 2001-07-31 Hewlett Packard Company System with multiple dynamically-sized logical FIFOs sharing single memory and with read/write pointers independently selectable and simultaneously responsive to respective read/write FIFO selections
US7017004B1 (en) * 2002-03-29 2006-03-21 Microsoft Corporation System and method for updating contents of a flash ROM
JP2009230407A (ja) * 2008-03-21 2009-10-08 Toshiba Corp データの更新方法、メモリシステムおよびメモリデバイス
US20090319721A1 (en) * 2008-06-19 2009-12-24 Silicon Motion, Inc. Flash memory apparatus and method for operating the same
US20110010489A1 (en) * 2009-07-09 2011-01-13 Phison Electronics Corp. Logical block management method for a flash memory and control circuit storage system using the same
JP2011128792A (ja) * 2009-12-16 2011-06-30 Toshiba Corp メモリ管理装置
US20110238890A1 (en) * 2010-03-25 2011-09-29 Kabushiki Kaisha Toshiba Memory controller, memory system, personal computer, and method of controlling memory system
GB2479235A (en) * 2010-04-01 2011-10-05 Intel Corp Wear leveling in a solid state drive
WO2012099937A2 (en) * 2011-01-18 2012-07-26 Lsi Corporation Higher-level redundancy information computation

Family Cites Families (60)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4942552A (en) 1986-11-20 1990-07-17 Allen-Bradley Company, Inc. Method and apparatus for saving and performing industrial control commands
JPH03250499A (ja) * 1990-02-27 1991-11-08 Nec Corp データ記憶回路
JP3212787B2 (ja) 1993-12-02 2001-09-25 日本電気株式会社 転送データ管理方式およびホスト・端末間データ転送方式
US5553261A (en) * 1994-04-01 1996-09-03 Intel Corporation Method of performing clean-up of a solid state disk while executing a read command
JPH1153235A (ja) 1997-08-08 1999-02-26 Toshiba Corp ディスク記憶装置のデータ更新方法、ならびにディスク記憶制御システム
DE19882822T1 (de) * 1997-11-17 2001-03-22 Seagate Technology Verfahren und Dedizierter Frame-Puffer zur Schleifeninitialisierung und für Antworten
US6427198B1 (en) 2000-02-15 2002-07-30 International Business Machines Corporation Method, system, and program for determining system configuration
US6763424B2 (en) 2001-01-19 2004-07-13 Sandisk Corporation Partial block data programming and reading operations in a non-volatile memory
JP2002342164A (ja) * 2001-05-22 2002-11-29 Hitachi Ltd 記憶装置及びデータ処理装置並びに記憶部制御方法
WO2003019391A2 (en) 2001-08-24 2003-03-06 Intel Corporation A general input/output architecture protocol and related methods to manage data integrity
JP2003087348A (ja) 2001-09-14 2003-03-20 Matsushita Graphic Communication Systems Inc 通信制御方法及び通信制御装置並びにadsl通信装置
KR100445134B1 (ko) 2002-01-31 2004-08-21 삼성전자주식회사 플래시 메모리 안정화기능을 구비한 호스트 기기 및 그 방법
US6968439B2 (en) 2002-08-29 2005-11-22 Micron Technology, Inc. Single segment data object management
KR100498233B1 (ko) * 2002-10-31 2005-07-01 한국전자통신연구원 선입선출 메모리 회로 및 그 구현 방법
JP4175185B2 (ja) 2003-06-06 2008-11-05 日本電気株式会社 ネットワーク情報記録装置
CN1670701A (zh) 2004-03-17 2005-09-21 德鑫科技股份有限公司 压缩数据存储方法
US20060174067A1 (en) 2005-02-03 2006-08-03 Craig Soules Method of caching data
CN101390043A (zh) 2005-07-01 2009-03-18 美国日本电气实验室公司 嵌入式系统用的存储器体系结构
CN100361094C (zh) 2005-07-01 2008-01-09 华为技术有限公司 一种节省全局变量内存空间的方法
US7159082B1 (en) 2005-10-03 2007-01-02 Hewlett-Packard Development Company, L.P. System and method for throttling memory accesses
JP4357473B2 (ja) * 2005-11-04 2009-11-04 株式会社ソニー・コンピュータエンタテインメント データ処理システムおよびプログラム
US7719983B2 (en) 2006-01-06 2010-05-18 International Business Machines Corporation Method for autonomic system management using adaptive allocation of resources
JP4855102B2 (ja) 2006-02-23 2012-01-18 株式会社日立製作所 計算機システム及び管理計算機とストレージシステム並びに記憶領域割当量制御方法
US7594073B2 (en) 2006-09-29 2009-09-22 Intel Corporation Method and apparatus for caching memory content on a computing system to facilitate instant-on resuming from a hibernation state
KR100857761B1 (ko) * 2007-06-14 2008-09-10 삼성전자주식회사 웨어 레벨링을 수행하는 메모리 시스템 및 그것의 쓰기방법
JP2009026296A (ja) 2007-06-21 2009-02-05 Toshiba Corp 電子デバイス、メモリデバイス、ホスト装置
US8078787B2 (en) 2007-06-22 2011-12-13 Apple Inc. Communication between a host device and an accessory via an intermediate device
US8429358B2 (en) 2007-08-14 2013-04-23 Samsung Electronics Co., Ltd. Method and data storage device for processing commands
US8239612B2 (en) * 2007-09-27 2012-08-07 Tdk Corporation Memory controller, flash memory system with memory controller, and control method of flash memory
US8473707B2 (en) 2008-03-27 2013-06-25 Open Invention Network, Llc Method for achieving sequential I/O performance from a random workload
US7769919B2 (en) 2008-05-15 2010-08-03 International Business Machines Corporation Protecting computer memory from simultaneous direct memory access operations using active and inactive translation tables
US8959280B2 (en) * 2008-06-18 2015-02-17 Super Talent Technology, Corp. Super-endurance solid-state drive with endurance translation layer (ETL) and diversion of temp files for reduced flash wear
TWI398770B (zh) * 2008-07-08 2013-06-11 Phison Electronics Corp 用於快閃記憶體的資料存取方法、儲存系統與控制器
TW201007734A (en) 2008-08-06 2010-02-16 Genesys Logic Inc Flash memory control apparatus having signal-converting module
US8140739B2 (en) * 2008-08-08 2012-03-20 Imation Corp. Flash memory based storage devices utilizing magnetoresistive random access memory (MRAM) to store files having logical block addresses stored in a write frequency file buffer table
US7925925B2 (en) 2008-12-30 2011-04-12 Intel Corporation Delta checkpoints for a non-volatile memory indirection table
CN101576834B (zh) 2009-05-08 2012-05-30 西安蓝海本立信息科技有限公司 基于时间戳建立数据视图的连续数据保护系统及方法
US8479080B1 (en) 2009-07-12 2013-07-02 Apple Inc. Adaptive over-provisioning in memory systems
US8560765B2 (en) * 2009-09-08 2013-10-15 Lsi Corporation Systems and methods for variable level use of a multi-level flash memory
US9753847B2 (en) 2009-10-27 2017-09-05 Western Digital Technologies, Inc. Non-volatile semiconductor memory segregating sequential, random, and system data to reduce garbage collection for page based mapping
US8677054B1 (en) 2009-12-16 2014-03-18 Apple Inc. Memory management schemes for non-volatile memory devices
US8327226B2 (en) 2010-02-03 2012-12-04 Seagate Technology Llc Adjustable error correction code length in an electrical storage device
US8700841B2 (en) * 2010-04-19 2014-04-15 International Business Machines Corporation Sub-LUN input/output profiling for SSD devices
US9183134B2 (en) 2010-04-22 2015-11-10 Seagate Technology Llc Data segregation in a storage device
US8489855B2 (en) 2010-05-07 2013-07-16 Ocz Technology Group Inc. NAND flash-based solid state drive and method of operation
CN101930404B (zh) 2010-08-27 2012-11-21 威盛电子股份有限公司 存储装置及其操作方法
US20120059976A1 (en) 2010-09-07 2012-03-08 Daniel L. Rosenband Storage array controller for solid-state storage devices
CN102023818A (zh) 2010-12-06 2011-04-20 成都市华为赛门铁克科技有限公司 一种存储设备容量调整方法、装置及存储设备
WO2012148828A2 (en) 2011-04-26 2012-11-01 Lsi Corporation Variable over-provisioning for non-volatile storage
US9514838B2 (en) * 2011-05-31 2016-12-06 Micron Technology, Inc. Apparatus including memory system controllers and related methods for memory management using block tables
KR101438716B1 (ko) 2011-08-09 2014-09-11 엘에스아이 코포레이션 I/o 디바이스 및 컴퓨팅 호스팅 상호동작
US9021319B2 (en) * 2011-09-02 2015-04-28 SMART Storage Systems, Inc. Non-volatile memory management system with load leveling and method of operation thereof
CN103392207B (zh) 2011-10-05 2017-08-04 希捷科技有限公司 非易失性存储的自身日志记录和层级一致性
JP5583227B1 (ja) * 2012-09-21 2014-09-03 株式会社東芝 物理ブロック間でデータをコピーするディスクアレイ装置、ディスクアレイコントローラ及び方法
US20140122774A1 (en) * 2012-10-31 2014-05-01 Hong Kong Applied Science and Technology Research Institute Company Limited Method for Managing Data of Solid State Storage with Data Attributes
JP2014098978A (ja) * 2012-11-13 2014-05-29 Sony Corp メモリ制御装置、メモリシステム、情報処理システムおよびメモリ制御方法
US9395924B2 (en) 2013-01-22 2016-07-19 Seagate Technology Llc Management of and region selection for writes to non-volatile memory
US9292228B2 (en) * 2013-02-06 2016-03-22 Avago Technologies General Ip (Singapore) Pte. Ltd. Selective raid protection for cache memory
US8990614B2 (en) * 2013-03-14 2015-03-24 Apple Inc. Performance of a system having non-volatile memory
CN104794063A (zh) * 2014-01-17 2015-07-22 光宝科技股份有限公司 一种具备电阻式存储器的固态储存装置的控制方法

Patent Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6269413B1 (en) * 1998-10-30 2001-07-31 Hewlett Packard Company System with multiple dynamically-sized logical FIFOs sharing single memory and with read/write pointers independently selectable and simultaneously responsive to respective read/write FIFO selections
US7017004B1 (en) * 2002-03-29 2006-03-21 Microsoft Corporation System and method for updating contents of a flash ROM
JP2009230407A (ja) * 2008-03-21 2009-10-08 Toshiba Corp データの更新方法、メモリシステムおよびメモリデバイス
US20090319721A1 (en) * 2008-06-19 2009-12-24 Silicon Motion, Inc. Flash memory apparatus and method for operating the same
US20110010489A1 (en) * 2009-07-09 2011-01-13 Phison Electronics Corp. Logical block management method for a flash memory and control circuit storage system using the same
JP2011128792A (ja) * 2009-12-16 2011-06-30 Toshiba Corp メモリ管理装置
US20110238890A1 (en) * 2010-03-25 2011-09-29 Kabushiki Kaisha Toshiba Memory controller, memory system, personal computer, and method of controlling memory system
GB2479235A (en) * 2010-04-01 2011-10-05 Intel Corp Wear leveling in a solid state drive
WO2012099937A2 (en) * 2011-01-18 2012-07-26 Lsi Corporation Higher-level redundancy information computation

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106354745A (zh) * 2015-07-13 2017-01-25 三星电子株式会社 用于提供计算机装置的接口的方法和计算机装置
US11249951B2 (en) 2015-07-13 2022-02-15 Samsung Electronics Co., Ltd. Heuristic interface for enabling a computer device to utilize data property-based data placement inside a nonvolatile memory device
US11461010B2 (en) 2015-07-13 2022-10-04 Samsung Electronics Co., Ltd. Data property-based data placement in a nonvolatile memory device
US10275165B2 (en) 2016-09-12 2019-04-30 Toshiba Memory Corporation Memory controller

Also Published As

Publication number Publication date
TW201443641A (zh) 2014-11-16
TWI537724B (zh) 2016-06-11
CN103942010A (zh) 2014-07-23
EP2757479A1 (en) 2014-07-23
CN103942010B (zh) 2019-05-10
US9395924B2 (en) 2016-07-19
US20140208007A1 (en) 2014-07-24
JP6387231B2 (ja) 2018-09-05
KR20140094468A (ko) 2014-07-30
KR102155191B1 (ko) 2020-09-11

Similar Documents

Publication Publication Date Title
JP6387231B2 (ja) 不揮発性メモリへの書き込みの管理および領域選択
US11449252B2 (en) Method of writing and reading data in an NVM using Lpage identification headers
US9851910B2 (en) Scalable data structures for control and management of non-volatile storage
JP6045567B2 (ja) 不揮発性記憶のための可変オーバープロビジョニング
US9183140B2 (en) Higher-level redundancy information computation
JP6285709B2 (ja) 冗長アレイによる不揮発性メモリのプログラム障害回復
JP5980798B2 (ja) 独立したシリコン素子の動的な上位レベルの冗長モード管理

Legal Events

Date Code Title Description
A711 Notification of change in applicant

Free format text: JAPANESE INTERMEDIATE CODE: A711

Effective date: 20160427

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20160610

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20161216

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20161216

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20171117

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20171128

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20180227

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20180327

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20180625

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

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20180813

R150 Certificate of patent or registration of utility model

Ref document number: 6387231

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

LAPS Cancellation because of no payment of annual fees