JP5657641B2 - データストレージデバイスのコマンド及び割り込みのグループ化 - Google Patents

データストレージデバイスのコマンド及び割り込みのグループ化 Download PDF

Info

Publication number
JP5657641B2
JP5657641B2 JP2012504717A JP2012504717A JP5657641B2 JP 5657641 B2 JP5657641 B2 JP 5657641B2 JP 2012504717 A JP2012504717 A JP 2012504717A JP 2012504717 A JP2012504717 A JP 2012504717A JP 5657641 B2 JP5657641 B2 JP 5657641B2
Authority
JP
Japan
Prior art keywords
group
command
commands
interrupt
host
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
JP2012504717A
Other languages
English (en)
Other versions
JP2012523619A (ja
Inventor
ティー.スウイング アンドレウ
ティー.スウイング アンドレウ
ティー.ボルクヘルス アルベルト
ティー.ボルクヘルス アルベルト
グルンドレル グラント
グルンドレル グラント
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Google LLC
Original Assignee
Google LLC
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 Google LLC filed Critical Google LLC
Publication of JP2012523619A publication Critical patent/JP2012523619A/ja
Application granted granted Critical
Publication of JP5657641B2 publication Critical patent/JP5657641B2/ja
Active 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/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
    • 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/061Improving I/O performance
    • G06F3/0613Improving I/O performance in relation to throughput
    • 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
    • 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/0644Management of space entities, e.g. partitions, extents, pools
    • 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/0655Vertical data movement, i.e. input-output transfer; data movement between one or more hosts and one or more storage devices
    • G06F3/0659Command handling arrangements, e.g. command buffers, queues, command scheduling

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Human Computer Interaction (AREA)
  • Computer Security & Cryptography (AREA)
  • Techniques For Improving Reliability Of Storages (AREA)
  • Bus Control (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Information Transfer Systems (AREA)
  • Image Processing (AREA)
  • Memory System Of A Hierarchy Structure (AREA)

Description

(関連出願の相互参照)
本出願は、引用により全体として本明細書中に組み込まれている、2009年4月8日に出願された「データストレージデバイス(DATA STORAGE DEVICE)」と題する米国仮出願第61/167,709号、及び2009年6月17日に出願された「フラッシュメモリデータストレージデバイスにおけるパーティショニング及びストライピング(PARTITIONING AND STRIPING IN A FLASH MEMORY DATA STORAGE DEVICE)」と題する米国仮出願第61/187,835号の利益を主張するものである。
(技術分野)
この説明は、データストレージデバイスのコマンド及び割り込みグループ化に関する。
(背景)
データストレージデバイスは、データを格納するために使用することができる。データストレージデバイスは、コンピューティングデバイスのデータストレージの必要性に備えるためにコンピューティングデバイスと共に使用することができる。場合によっては、膨大量のデータをデータストレージデバイスに格納することが望ましいこともある。また、データストレージデバイスとの間でデータの迅速な読み取り及び書き込みを行うためのコマンドを実行することが望ましい場合もある。
データストレージデバイスでのコマンド実行のスループットは、データストレージデバイスによって処理されうるコマンドの数に関連することもある。データストレージデバイスによって処理されうるコマンドの数を増大させることにより、データストレージデバイスの高いスループットを達成することが望ましいと考えられる。コマンドを迅速に実行することに加えて、データエラーが最小化されるように、及び/又は少なくともデータスループットに及ぼす影響を最小限に抑えてデータが訂正可能であるように、コマンドを正確に実行することが望ましいと考えられる。
さらに、ホストへの影響及びオーバーヘッドを最小化しながら、データストレージデバイスでホストから受信されたコマンドを実行することが望ましいと考えられる。
(要旨)
本文書は、コマンドをデータストレージデバイスにより処理するためのグループの一部として指定するドライバを有するホストを説明する。データストレージデバイスがグループ内のすべてのコマンドの処理を完了すると、データストレージデバイスは、単一割り込みをホストに返信して、コマンドのグループの処理が完了したことを指示する。たとえば、コマンドの1つ以上のスレッドは、ドライバによってグループとして指定されてもよい。データストレージデバイスがコマンドの1つ以上のスレッドを完了すると、データストレージデバイスは、単一割り込みを生成してホストに送信し、それらのグループ化されたコマンドの処理が完了したことを指示する。
コマンドをグループの一部として指定し、コマンドの処理が完了したときに、ホストに単一割り込みを送信することにより、ホストへの影響は最小化することができる。このように、ホストは、割り込みの処理に要する時間を短縮することができ、他のタスクを実行することにより多くの時間を振り向けることができる。さらに、場合によっては、ホストは、グループ内のコマンドがすべて処理されるまで、データを使用することができないこともある。そのような場合、グループ内のコマンドがすべて処理されているのでなければ、通知を受けることがホストにとって有益ではないこともある。
1つの例示的な実施態様において、ホストにおいてドライバは、コマンドをグループ化する方法を決定することができる。ドライバは、特定の基準に基づいてコマンドをグループ化することができる。たとえば、ドライバは、ドライバとインターフェイスをとるアプリケーションからの望ましいアクションのサイズに基づいて、コマンドをグループ化することができる。このように、ドライバは、インターフェイスをとるアプリケーションからの大容量の入出力要求の一部であるコマンドをグループ化してまとめることができる。したがって、オペレーティングシステムが、要求を実行するために大容量の入出力要求を複数のコマンドに分割する場合であっても、ドライバはコマンドをグループ化する。もう1つの例において、ドライバは、コマンドが同じ1つ以上のスレッドの一部であることに基づいて、コマンドをグループ化することができる。
データストレージデバイスは、複数のメモリデバイス及びコントローラを含むことができる。コントローラは、ホストからコマンドを受信し、複数のメモリデバイスを使用してコマンドを処理するように構成されてもよい。コントローラが、グループの一部であると識別されるコマンドをホストから受信すると、コントローラは、メモリデバイスを使用してそれらのコマンドを処理することができ、グループ内のすべてのコマンドが処理された場合に限り、単一割り込みを生成してホストに返信することができる。このように、割り込みは、グループ内のコマンドごと、又はグループ内のコマンドのサブセットごとに生成されることはない。代わりに、単一割り込みが、コマンドのグループ全体に対して生成される。
コントローラは、グループ化されたコマンドを追跡するように配置され構成される割り込みプロセッサを含むことができる。複数のグループからのコマンドが、メモリデバイスを使用してコントローラによって処理されているので、割り込みプロセッサは、コマンドの複数のグループを追跡するように構成されてもよい。1つの例示的な実施態様において、コマンドはコマンドヘッダを含み、グループ番号は、コマンドが割り込みプロセッサによって追跡されうるように、ドライバによってコマンドヘッダに挿入される。コマンドヘッダはフラグも含み、フラグは、コマンドがグループ内の最後のコマンドであることを指示するためにドライバによって設定されてもよい。割り込みプロセッサは、最後のコマンドフラグを認識するように構成されてもよく、このフラグは、コマンドが処理を完了したときに単一割り込みを生成するインジケータとしての機能を果たすことができる。
1つの例示的な実施態様において、コントローラは、データストレージデバイスで実行できるよう、ホストからのコマンドを追跡、順序付け、キューイング、及び処理するためのコマンドプロセッサを含むことができる。コマンドプロセッサは、グローバルスロット識別子を各々のコマンドに割り当てることによりホストからの着信コマンドを追跡し、コマンドの経過時間に基づく番号付きリストを使用してコマンドをキューに入れて順序付けるように配置され構成されてもよい。コマンドプロセッサは、同じストレージ位置に指定されているコマンドについてホストから受信されたコマンドの順序を保持するように構成されてもよい。コマンドプロセッサはまた、異なるストレージ位置に指定されているコマンドに対して、コマンドを順不同に扱うように構成されてもよい。このように、順序を保持することが重要である場合、コマンドの順序は、ホストから受信されたとおりに保持される。同時に、コマンドプロセッサは、異なるストレージ位置に指定されているコマンドについて順不同に扱うことにより、すべてのストレージ位置を実質的にビジー状態にする。コマンドプロセッサは、実質的にすべてのストレージ位置がコマンドキューに指定されているコマンドを有することにより、コマンドの並列処理を可能にする。
コマンドプロセッサが、個々のコマンドのすべてを、処理中に追跡する間、割り込みプロセッサは、コマンドのグループの一部であるコマンドを追跡することができる。このように、コントローラは、コマンドのグループの一部であるコマンドを含むコマンドを不連続の方式で処理することができる。割り込みプロセッサは、グループ内のすべてのコマンドが処理されるまで待機し、その後単一割り込みを生成してホストに送信する。これは、コマンドプロセッサがコマンドの並列処理を続行できるようにし、同時に、データストレージデバイスから送信されていた可能性もある不必要な割り込みの処理にホストが費やすオーバーヘッド及び時間を軽減する。
1つの例示的な実施態様において、データストレージデバイスは、1つ以上のメモリチップに関連付けられている操作を制御するように配置され構成される複数のチャネルコントローラを含むことができる。メモリチップは、フラッシュメモリチップを含むことができる。
1つの例示的な実施態様において、コマンドプロセッサ、割り込みプロセッサ、及びチャネルコントローラは、フィールドプログラマブルゲートアレイ(field programmable gate array)(FPGA)コントローラの一部として実施されてもよく、FPGAコントローラはデータストレージデバイスの一部であってもよい。
データストレージデバイスは、1つ以上のメモリボードを含むことができ、各々のメモリボードは複数のメモリデバイスを含む。1つの例示的な実施態様において、各々のメモリボードは複数のフラッシュメモリチップを含むことができる。メモリボードは、複数のチャネルを含むことができ、1つ以上のフラッシュメモリチップは各々のチャネルに割り当てられてもよい。データストレージデバイスは、メモリボードが機能的に接続するコントローラボードを含むことができる。データストレージデバイスは、インターフェイスを使用してホストと通信し、ホストからコマンドを受信して、それらのコマンドをフラッシュメモリチップを使用して処理するように構成されてもよい。たとえば、フラッシュメモリチップを使用してデータのブロックの読み取り、書き込み、コピー、及び削除を行うコマンドを、ホストは送信することができ、コントローラボードは受信することができる。
1つの例示的な実施態様において、コントローラは、フィールドプログラマブルゲートアレイ(field-programmable gate array) (FPGA)コントローラを含み、ホストとコントローラボードとの間のインターフェイスは、たとえばピーシーアイエクスプレス(Peripheral Component Interconnect Express) (PCIe)インターフェイスのような高速インターフェイスであってもよい。このように、データストレージデバイスは、高ストレージボリュームを含むことができ、ホストとフラッシュメモリチップ間の高パフォーマンス及び高速のデータ転送を達成するように構成されてもよい。
1つの例示的な実施態様において、データストレージデバイスは、メモリボードが各々複数のフラッシュメモリチップを含む2つのメモリボードで構成されてもよい。コントローラボード及び2つのメモリボードを含むデータストレージデバイスは、データストレージデバイスがコンピューティングデバイスの内蔵ドライブスロットに適合するように、ディスクドライブの形態で構成されてもよい。たとえば、データストレージデバイスは、サーバのデータストレージ容量をもたらすためにサーバの内蔵ドライブスロットに適合するように構成されてもよい。データストレージデバイスは、コンピューティングデバイスから容易に取り外すことができ、別のコンピューティングデバイスの内蔵ドライブスロットに挿入できるように、取り外し可能に構成されてもよい。
その他の例示的な実施態様において、各々のメモリボードは、フラッシュメモリチップ以外のメモリデバイスを含むことができる。たとえば、各々のメモリボードは、複数のダイナミックランダムアクセスメモリ(dynamic random access memory)(DRAM)チップを含むことができる。フラッシュメモリチップに関する上記の説明と同様に、コマンドプロセッサ及び割り込みプロセッサは、ホストから受信されたコマンドをグループとして処理し、コマンドがDRAMチップを使用して処理されると、単一割り込みを生成してホストに返信するように構成されてもよい。その他の例示的な実施態様において、メモリボードは、たとえば相変化メモリ(phase change memory)(PCM)チップ及びその他のタイプのメモリデバイスを含む、その他のタイプのメモリデバイスを含むことができる。
1つの一般的な態様によれば、データストレージデバイスは、複数のメモリチップと、メモリチップに機能的に結合されるコントローラとを含むことができ、コントローラは、ホストからコマンドのグループを受信することであって、グループ内の各々のコマンドがグループの一部としてコマンドを識別するために同じグループ番号を含むことと、メモリチップを使用してコマンドのグループを処理することと、コマンドのグループが処理を完了すると、単一割り込みを生成してホストに送信することとを行うように配置され構成される。
実施態様は、1つ以上の以下の特徴を含むことができる。たとえば、コントローラは、ホストからコマンドの複数のグループを受信することであって、各々のコマンドがグループの1つの一部としてコマンドを識別するためにグループ番号を含むことと、メモリチップを使用してコマンドのグループを処理することと、コマンドの各々のグループが処理を完了すると、単一割り込みを生成して各々のグループのホストに送信することとを行うように構成されてもよい。コントローラは、メモリチップを使用して不連続の順序でコマンドのグループを処理するように構成されてもよい。
各々のコマンドはコマンドヘッダを含むことができ、コマンドヘッダはグループ番号を含む。コマンドのグループ内の最後のコマンドは、コントローラに最後のコマンドを指示するためのフラグをコマンドヘッダに含むことができる。グループ番号は、グループ内の次のコマンドを指し示すためにコマンドのポインタを使用することなく、各々のコマンドをグループの一部として識別することができる。
コントローラは、コマンドがコントローラによって処理されるときにコマンドのグループを追跡し、コマンドのグループが処理を完了すると、単一割り込みを生成してホストに送信するように配置され構成される割り込みプロセッサを含むことができる。割り込みプロセッサは、複数のカウンタを含むことができ、各々のカウンタはコントローラによって受信されるコマンドの異なるグループに割り当てられる。割り込みプロセッサは、複数の異なる割り込み機構を含むことができる。同時に2つ以上の割り込み機構が有効にされてもよい。割り込み機構は、電子透かし割り込み機構、タイムアウト割り込み機構、及びグループ割り込み機構を含むことができる。
1つの例示的な実施態様において、メモリチップはフラッシュメモリチップであってもよく、コントローラはフィールドプログラマブルゲートアレイ(field programmable gate array)(FPGA)コントローラであってもよい。データストレージデバイスは、メモリボードであって、その上でフラッシュメモリチップが複数のチャネルに配置され構成されてもよく、各々のチャネルが1つ以上のフラッシュメモリチップに関連付けられている、メモリボードと、メモリボードに機能的に接続されるコントローラボードとを備える。コントローラボードは、高速インターフェイスと、高速インターフェイスを使用してホストからコマンドを受信するように配置され構成されるコントローラとを含むことができる。
もう1つの一般的な態様において、複数のメモリチップを有するデータストレージデバイスでコマンドのグループを処理するための方法は、ホストからコマンドのグループを受信することであって、グループ内の各々のコマンドがグループの一部としてコマンドを識別するために同じグループ番号を含むことと、複数のメモリチップを使用してコマンドのグループを処理することと、コマンドのグループが処理を完了すると、単一割り込みを生成してホストに送信することとを含むことができる。
実施態様は、1つ以上の以下の特徴を含むことができる。たとえば、ホストからコマンドのグループを受信することは、ホストからコマンドの複数のグループを受信することを含むことができ、各々のコマンドはグループの1つの一部としてコマンドを識別するためにグループ番号を含み、コマンドのグループを処理することは、メモリチップを使用してコマンドのグループを処理することを含むことができ、単一割り込みを生成して送信することは、各々のグループが処理を完了すると、単一割り込みを生成して各々のグループのホストに送信することを含むことができる。コマンドのグループを処理することは、メモリチップを使用してコマンドのグループを不連続の順序で処理することを含むことができる。
もう1つの一般的な態様において、コントローラにおいてコマンドを追跡するための装置は、複数のグループカウンタであって、各々のグループカウンタは、コントローラによりグループ内のコマンドが処理を開始するとインクリメントし、グループ内のコマンドが処理を終了するとデクリメントすることによって、コントローラにより処理されているコマンドのグループを追跡するように構成される、グループカウンタと、グループカウンタに機能的に結合され、グループ内のすべてのコマンドが処理を完了すると、各々のグループカウンタの単一割り込みを生成して送信するように配置され構成される割り込み送信論理とを含むことができる。
実施態様は、1つ以上の以下の特徴を含むことができる。たとえば、同じグループ内の各々のコマンドは、同じグループ番号により識別されてもよい。複数のグループカウンタは、グループカウンタによって追跡されているコマンドが処理を開始すると、グループカウンタの1つをインクリメントする信号を受信するように構成されてもよい。複数のグループカウンタは、グループカウンタによって追跡されているコマンドが処理を完了すると、グループカウンタの1つをデクリメントする信号を受信するように構成されてもよい。割り込み送信論理は、グループ内の最後のコマンドが処理を開始して、最終コマンドに関連付けられているグループカウンタがゼロにデクリメントされると、単一割り込みを生成して送信するように構成されてもよい。
もう1つの一般的な態様において、コントローラにおいてコマンドを追跡するための方法は、コマンドのグループ内のコマンドが処理を開始すると、グループカウンタをインクリメントすることと、コマンドのグループ内のコマンドが処理を完了すると、グループカウンタをデクリメントすることと、グループ内のすべてのコマンドが処理を完了すると、コマンドのグループの単一割り込みを生成して送信することとを含むことができる。
実施態様は、1つ以上の以下の特徴を含むことができる。たとえば、単一割り込みを生成して送信することは、グループ内の最後のコマンドが処理を開始し、グループカウンタがゼロにデクリメントされると、単一割り込みを生成して送信することを含むことができる。
もう1つの一般的な態様において、システムは、複数のメモリチップと、ホストと複数のメモリチップ間のデータの通信のための複数の物理チャネルとを含むデータストレージデバイスであって、各チャネルが異なる複数のメモリチップに機能的に接続される、データストレージデバイスと、インターフェイスを使用してデータストレージデバイスに機能的に結合されたホストとを含むことができる。ホストは、複数のメモリチップを使用してデータストレージデバイスにより処理するためにコマンドをデータストレージデバイスに送信し、コマンドを1つ以上の異なるグループにグループ化して、グループ内の各々のコマンドにグループ番号を割り当て、グループ内の最後のコマンドにマークを付けるように構成されるドライバを含むことができる。
実施態様は、1つ以上の以下の特徴を含むことができる。たとえば、データストレージデバイスは、グループ内のコマンドを処理した後、単一割り込みを生成してホストに送信するように構成されてもよい。複数のメモリチップは、フラッシュメモリチップを含むことができる。ドライバは、グループ番号の使用を追跡するように構成されてもよい。データストレージデバイスは、複数のメモリチップを使用して不連続の順序でコマンドのグループを処理するように構成されてもよい。
ホストは、データストレージデバイスで1つ以上の割り込み機構を有効にするように構成されてもよい。割り込み機構は、電子透かし割り込み機構、タイムアウト割り込み機構、及びグループ割り込み機構を含むことができる。
1つ以上の実施態様の詳細は、添付の図面及び以下の説明において示される。その他の特徴は、説明及び図面、並びに特許請求の範囲から明らかとなろう。
ホスト及びデータストレージデバイスを示す例示的なブロック図である。
割り込みプロセッサを示す例示的なブロック図である。
データストレージデバイスのコマンドプロセッサを示す例示的なブロック図である。
処理中のコマンドモジュールを示す例示的なブロック図である。
データストレージデバイスのプリント基板を示す例示的な透視ブロック図である。
図1のデータストレージデバイスと共に使用する例示的なコンピューティングデバイスを示す例示的なブロック図である。
データストレージデバイスでコマンドのグループを処理するためのプロセスを示す例示的な流れ図である。
コントローラにおいてコマンドを追跡するためのプロセスを示す例示的な流れ図である。
(詳細な説明)
本文書は、ホストにおいてコマンドをグループ化し、データストレージでコマンドを処理するための装置、システム、及び技法を説明する。ホストは、どのコマンドをグループにまとめるかを決定することができ、どのコマンドが同じグループにあるかを指示することができる。たとえば、ホストは、グループの一部である各コマンドのコマンドヘッダに、グループ番号を割り当てて挿入することができる。データストレージデバイスは、ホストによってグループにまとめられているコマンドの処理を追跡するように構成される割り込みプロセッサを有するコントローラを含むことができる。データストレージデバイスがグループ内のすべてのコマンドの処理を完了すると、割り込みプロセッサは、単一割り込みを生成してホストに返信し、コマンドのグループの処理が完了したことを指示する。
図1を参照すると、グループ内のコマンドを処理して追跡するためのシステムを示すブロック図が示される。図1は、データストレージデバイス100及びホスト106を示すブロック図である。データストレージデバイス100は、コントローラボード102及び1つ以上のメモリボード104a及び104bを含むことができる。データストレージデバイス100は、インターフェイス108を介してホスト106と通信することができる。インターフェイス108は、ホスト106とコントローラボード102の間にあってもよい。
コントローラボード102は、コントローラ110、DRAM111、複数のチャネル112、電源モジュール114、及びメモリモジュール116を含むことができる。コントローラ110は、コマンドプロセッサ122、及び割り込みプロセッサ124、並びに図示されていないその他のコンポーネントを含むことができる。メモリボード104a及び104bは、各メモリボード上に複数のフラッシュメモリチップ118a及び118bを含むことができる。メモリボード104a及び104bはまた、それぞれメモリデバイス120a及び120bを含むことができる。
ホスト106は、ドライバ107、オペレーティングシステム109、及び1つ以上のアプリケーション113を含むことができる。一般に、ホスト106は、データストレージデバイス100で実行されるコマンドを生成することができる。たとえば、アプリケーション113は、データストレージデバイス100で実行するためのコマンドを生成するように構成されてもよい。アプリケーション113は、オペレーティングシステム109及び/又はドライバ107に機能的に結合されてもよい。アプリケーション113は、コマンドを生成して、オペレーティングシステム109にコマンドを伝達することができる。オペレーティングシステム109は、ドライバ107に機能的に接続されてもよく、ドライバ107は、ホスト106とデータストレージデバイス100との間のインターフェイスとして機能することができる。
一般に、データストレージデバイス100は、フラッシュメモリチップ118a及び118b上にデータを格納するように構成されてもよい。ホスト106は、フラッシュメモリチップ118a及び118bとの間でデータの書き込み及び読み取りを行うことができ、さらにフラッシュメモリチップ118a及び118bに関してその他の操作を実行させるようにすることができる。ホスト106とフラッシュメモリチップ118a及び118bとの間のデータの読み取り及び書き込み、並びにその他の操作は、コントローラボード102上のコントローラ110を通じて処理され、制御されてもよい。コントローラ110は、ホスト106からコマンドを受信して、コマンドプロセッサ122並びにメモリボード104a及び104b上のフラッシュメモリチップ118a及び118bを使用してそれらのコマンドを実行させることができる。ホスト106とコントローラ110との間の通信は、インターフェイス108を通じて行われてもよい。コントローラ110は、チャネル112を使用して、フラッシュメモリチップ118a及び118bと通信することができる。
コントローラボード102は、DRAM 111を含むことができる。DRAM 111は、コントローラ110に機能的に結合されてもよく、情報を格納するために使用されてもよい。たとえば、DRAM 111は、論理アドレスから物理アドレスへのマップ及び不良ブロックの情報を格納するために使用されてもよい。DRAM 111はまた、ホスト106とフラッシュメモリチップ118a及び118bとの間のバッファとして機能するように構成されてもよい。
1つの例示的な実施態様において、コントローラボード102及び各々のメモリボード104a及び104bは、物理的に別個のプリント基板(PCB)である。メモリボード104aは、コントローラボード102のPCBに機能的に接続されている1つのPCB上にあってもよい。たとえば、メモリボード104aは、コントローラボード102に物理的及び/又は電気的に接続されてもよい。同様に、メモリボード104bは、メモリボード104aから分離されたPCBでもよく、コントローラボード102のPCBに機能的に接続されてもよい。たとえば、メモリボード104bは、コントローラボード102に物理的及び/又は電気的に接続されてもよい。メモリボード104a及び104bは各々、コントローラボード102から別個に切断されて取り外し可能であってもよい。たとえば、メモリボード104aは、コントローラボード102から切断されて、別のメモリボード(図示せず)に置き換えられてもよく、その別のメモリボードはコントローラボード102に機能的に接続される。この例において、メモリボード104a及び104bのいずれか又は両方は、他のメモリボードが同じコントローラボード102及びコントローラ110で動作できるように、他のメモリボードでスワップアウトされてもよい。
1つの例示的な実施態様において、コントローラボード102及び各々のメモリボード104a及び104bは、ディスクドライブフォームファクタで物理的に接続されてもよい。ディスクドライブフォームファクタは、たとえば3.5”ディスクドライブフォームファクタ及び2.5”ディスクドライブフォームファクタのような、さまざまなサイズを含むことができる。
1つの例示的な実施態様において、コントローラボード102及び各々のメモリボード104a及び104bは、高密度ボールグリッドアレイ(ball grid array)(BGA)コネクタを使用して電気的に接続されてもよい。たとえば、ファインボールグリッドアレイ(fine ball grid array)(FBGA)コネクタ、ウルトラファインボールグリッドアレイ(ultra fine ball grid array)(UBGA)コネクタ、及びマイクロボールグリッドアレイ(micro ball grid array)(MBGA) コネクタを含むその他のBGAコネクタの変種が使用されてもよい。その他のタイプの電気接続手段が使用されてもよい。
1つの例示的な実施態様において、メモリチップ118a〜118nは、フラッシュメモリチップを含むことができる。もう1つの例示的な実施態様において、メモリチップ118a〜118nは、DRAMチップ、又はフラッシュメモリチップとDRAMチップの組み合わせを含むことができる。メモリチップ118a〜118nは、その他のタイプのメモリチップを含むこともできる。
1つの例示的な実施態様において、ドライバ107及びデータストレージデバイス100を使用するホスト106は、ホストメモリ内のバッファのペアを使用してコマンド及び応答を伝達することができる。「バッファ」及び「キュー」という用語は、本文書全体を通じて同義的に使用される。たとえば、コマンドバッファ119は、コマンドに対して使用されてもよく、応答バッファ123はコマンドの応答又は結果に対して使用されてもよい。1つの例示的な実施態様において、コマンド及び結果は、比較的小さい、固定サイズのブロックであってもよい。たとえば、コマンドは32バイトであってもよく、結果又は応答は8バイトであってもよい。その他の例示的な実施態様において、可変サイズのブロックを含むその他のサイズのブロックが使用されてもよい。タグは、結果をコマンドと適合させるために使用されてもよい。このように、データストレージデバイス100は、順不同でコマンドを完了することができる。
図1では1つのコマンドバッファ119及び1つの応答バッファ123を示しているが、複数ペアのバッファが使用されてもよい。たとえば、最大32個までのバッファペアが使用されてもよい。1つの例示的な実施態様において、データストレージデバイス100は、ラウンドロビン形式でコマンドバッファ119にサービスを提供し、データストレージデバイス100は一度に固定数のコマンドをコマンドバッファ119から取り出すことができる。応答バッファ123は、各自の割り込み及び割り込みパラメータを含むことができる。
1つの例示的な実施態様において、各コマンドは、コマンドに応じて1つのメモリページ(たとえば、1つのフラッシュページ)、1つの消去ブロック、又は1つのメモリチップを参照することができる。データを転送する各コマンドは、1つの4Kのダイレクトメモリアクセス(direct memory access)(DMA)バッファを含むことができる。さらに大容量の操作は、複数のコマンドを送信することによって実施されてもよい。ドライバ107は、複数のグループ化されたコマンドが処理された場合、データストレージデバイス100がフラッシュメモリチップ118a及び118bを使用してコマンドを処理して単一割り込みを生成してホスト106に返信するように、複数コマンドの単一操作をグループ化するように配置され構成されてもよい。
1つの例示的な実施態様において、コマンドバッファ119及び応答バッファ123は各々、ヘッドポインタ及びテールポインタを含む。コマンド及び応答は、テールポインタにおいて挿入され、ヘッドポインタにおいて除去されてもよい。ホスト106は、コマンドバッファ119の製造者であり、応答バッファ123の消費者であってもよい。データストレージデバイス100は、コマンドバッファ119の消費者であり、応答バッファ123の製造者であってもよい。ホスト106は、コマンドテールポインタ及び応答ヘッドポインタを書き込むことができ、コマンドヘッドポインタ及び応答テールポインタを読み取ることができる。データストレージデバイス100は、コマンドヘッドポインタ及び応答テールポインタを書き込むことができ、コマンドテールポインタ及び応答ヘッドポインタを読み取ることができる。データストレージデバイス100において、コントローラ110は読み取り及び書き込みアクションを実行することができる。さらに具体的には、コマンドプロセッサ122は、データストレージデバイス100に対して読み取り及び書き込みアクションを実行するように構成されてもよい。ヘッド及びテールポインタ以外の他の同期化が、ホスト106とデータストレージデバイス100との間で必要になることはない。
1つの例示的な実施態様において、パフォーマンス上の理由から、コマンドヘッドポインタ及び応答テールポインタは、ホスト106(たとえば、ホストRAM)に格納されてもよい。コマンドテールポインタ及び応答ヘッドポインタは、コントローラ110内のメモリマップI/Oスペースのデータストレージデバイス100に格納されてもよい。
コマンドバッファ119及び応答バッファ123は、コマンド又は応答サイズの任意の倍数であってもよく、ドライバ107及びデータストレージデバイス100は、コマンドバッファ119及び応答バッファ123をオーバーランしないことを前提として、必要に応じてコマンド及び結果を自由に記入して処理することができる。1つの実施態様において、コマンドバッファ119及び応答バッファ123は循環バッファであり、ホスト106とデータストレージデバイス100との間のフロー制御を可能にする。
1つの例示的な実施態様において、ホスト106は、コマンドバッファ119及び応答バッファ123のサイズを決定することができる。バッファは、データストレージデバイス100が内部的にキューに入れることのできるコマンドの数よりも大きくてもよい。
ホスト106は、コマンドバッファ119にコマンドを書き込み、コマンドテールポインタを更新して、新しいコマンドが存在することをデータストレージデバイス100、及びデータストレージデバイス100内のコマンドプロセッサ122に指示することができる。コマンドテールポインタの書き込みは、新しいコマンドが存在することをコマンドプロセッサ122に信号伝達する。コマンドプロセッサ122は、DMA操作を使用してコマンドバッファ119からコマンドを読み取るように構成され、コマンドプロセッサ122がコマンドを受信したことをホスト106に指示するために別のDMA操作を使用してヘッドポインタを更新するように構成される。
コマンドプロセッサ122がコマンドを完了すると、コマンドプロセッサ122は、DMA操作を使用して応答を書き込み、コマンドが終了したことを指示するために別のDMA操作により応答テールポインタを更新する。割り込みプロセッサ124は、新しい応答が応答バッファ123で使用可能になると、割り込みでホスト106に信号伝達するように構成される。ホスト106は、応答バッファ123からの応答を読み取り、応答を受信したことを指示するためにヘッドポインタを更新する。1つの例示的な実施態様において、割り込みプロセッサ124は、以前の割り込みが応答ヘッドポインタに書き込んでいるホスト106によって確認されるまで、別の割り込みをホスト106に送信することはない。
1つの例示的な実施態様において、ホスト106は、そのドライバ107を通じて、割り込みプロセッサ124がいつ割り込みを生成すべきかを制御することができる。ホスト106は、さまざまな割り込み機構の組み合わせを含む、1つ以上の異なる割り込み機構を使用して、割り込み処理に関する情報を割り込みプロセッサ124に提供することができる。たとえば、ホスト106は、ドライバ107を通じて、電子透かし割り込み機構、タイムアウト割り込み機構、グループ割り込み機構、又はそれらの割り込み機構の組み合わせを使用するように割り込みプロセッサ124を構成することができる。
1つの例示的な実施態様において、ホスト106は、電子透かしを決定するResponseMarkパラメータを設定することができ、タイムアウトを決定するResponseDelayパラメータを設定することができる。ホスト106は、それらのパラメータを割り込みプロセッサ124に伝達することができる。応答バッファ123内の新しい応答のカウントがResponseMarkと等しいか又はそれよりも大きい場合、割り込みプロセッサ124によって割り込みが生成され、カウントがゼロにされる。前回の割り込み以降の時間(たとえば、マイクロ秒単位の時間)がResponseDelayと等しいか又はそれよりも大きく、応答バッファ123に新しい応答がある場合、割り込みプロセッサ124は割り込みを生成し、タイムアウトがゼロにされる。ホスト106が新しい応答を応答バッファ123から除去する場合、新しい応答のカウントが更新され、タイムアウトが再始動される。このように、ホスト106は、あらかじめポーリングを行って、割り込みプロセッサ124からの割り込みを回避することができる。
もう1つの例示的な実施態様において、ホスト106は、割り込みプロセッサ124がいつ割り込みを生成してホスト106に送信すべきかを決定するために、グループ割り込み機構を使用することができる。コマンドは、同じグループの一部としてコマンドを識別する共通値を共有することができる。たとえば、ドライバ107は、コマンドをグループ化して、コマンドのグループに同じグループ番号を割り当てることができる。ドライバ107は、コマンドヘッダの割り込みグループフィールドを使用して、コマンドのグループにグループ番号を割り当てることができる。コマンドグループ内のすべてのコマンドが完了し、それらのすべてのコマンドの応答がコマンドプロセッサ122から応答バッファ123に転送され、応答テールが更新されると、割り込みプロセッサ124は割り込みを生成してホスト106に送信することができる。このように、グループ割り込み機構は、ホスト106が割り込みの処理に費やす必要のある時間を短縮するために使用されてもよい。
各々の割り込み機構が、別々に有効又は無効にされてもよい。また、割り込み機構の任意の組み合わせが使用されてもよい。たとえば、ドライバ107は、どの割り込み機構が有効であるか、及びどの割り込み機構が無効であるかを決定するために、QueueControlレジスタの割り込み許可フラグ及び割り込み禁止フラグを設定することができる。このように、割り込みの組み合わせは、ホスト106が割り込みの処理に費やす必要がある時間を短縮するために使用されてもよい。ホスト106は、そのリソースを使用して他のタスクを実行することができる。
1つの例示的な実施態様において、すべての割り込み機構が無効化されてもよい。この状況において、ドライバ107は、処理する準備の整った応答があるかどうか決定するために、応答バッファ123をポーリングするように構成されてもよい。すべての割り込み機構を無効にすると、その結果、最短の可能待ち時間となる。さらに、ドライバ107の高いオーバーヘッドをもたらすことになる。
もう1つの例示的な実施態様において、グループ割り込み機構は、タイムアウト割り込み機構及び/又は電子透かし割り込み機構と共に有効化されてもよい。このように、指定されたグループ内のコマンドの数が応答バッファ123よりも大きい場合、他の有効な割り込み機構のうちの1つは、ドライバ107に割り込みをかけて応答バッファ123からの応答をクリアし、さらに多くの応答を応答バッファ123に追加するためコマンドプロセッサ122にスペースを提供するように機能する。
さまざまな割り込み機構の、単独又は組み合わせによる使用は、ドライバ107に関して待ち時間及び/又はオーバーヘッドを調整するために使用されてもよい。たとえば、1つの例示的な実施態様において、タイムアウト割り込み機構のみが有効化されてもよい。この状態において、ドライバ107のオーバーヘッドは低減されてもよい。もう1つの例示的な実施態様において、電子透かし割り込み機構のみが有効化されてもよい。この状況において、待ち時間は、より低いレベルに低減されてもよい。
一部の例示的な状況において、使用されている特定のタイプのアプリケーションは、どの割り込み機構が有効化されるかの決定を行う際に考慮に入れてもよい。たとえば、Web検索アプリケーションは、待ち時間に敏感であることもあり、Web検索アプリケーションとって最善の待ち時間感応性をもたらすために特定の組み合わせで割り込み機構が有効化されてもよい。もう1つの例において、Web索引付けアプリケーションは、Web検索アプリケーションほど待ち時間に敏感でなくてもよい。代わりに、プロセッサパフォーマンスが、より重要なパラメータとなることもある。このアプリケーションにおいて、割り込み機構は、たとえ待ち時間の増大を犠牲にしても、低いオーバーヘッドを可能にするために、特定の組み合わせで有効化されてもよい。
1つの例示的な実施態様において、ドライバ107は、オペレーティングシステム109を通じてアプリケーション113から受信された入出力(I/O)操作に基づいて、コマンドグループを決定することができる。たとえば、アプリケーション113は、複数メガバイトの読み取り操作を要求することがある。この場合には、アプリケーション113が部分的な応答を使用できないこともあり、アプリケーション113にとって唯一の有用な情報は、操作全体がいつ完了したかということであってもよい。通常、読み取り操作は、多くの複数のコマンドに分割されてもよい。ドライバ107は、読み取り操作をコマンドのグループとして認識し、そのグループ内のコマンドに、各々のコマンドヘッダの同じグループ番号を割り当てるように構成されてもよい。アプリケーション113とドライバ107との間のインターフェイスは、特定の操作がグループとして扱われることをドライバ107に指示するために使用されてもよい。インターフェイスは、コマンドのタイプ、コマンドに関連付けられているデータ要求のサイズ、複数の異なるアプリケーションからの要求を含む要求されるデータのタイプ、要求の優先順位、及びその組み合わせ(ただし、これらに限定されることはない)を含むさまざまな基準に基づいて操作をグループ化するように構成されてもよい。
一部の実施態様において、アプリケーション113は、操作に関連する個々のコマンド情報を、オペレーティングシステム109及び最終的にはドライバ107に渡すことができる。その他の例示的な実施態様において、ドライバ107は、コマンドの1つ以上のスレッドがグループとみなされるよう指定することができる。
図2を参照すると、例示的な割り込みプロセッサ124を示すブロック図が示される。割り込みプロセッサ124は、ホスト106によって有効化される1つ以上の割り込み機構に基づいて割り込みを生成して送信するように構成されてもよい。割り込みプロセッサ124は、ResponseNewカウンタ280、最終応答タイマー282、グループカウンタ284、及び割り込み送信論理286を含むことができる。
ResponseNewカウンタ280は、電子透かし割り込み機構が望ましい場合に、ホスト106によって有効化されてもよい。ホスト106は、ResponseMark 288を設定することができるが、これは上記で説明されるようにResponseNewカウンタ280への入力として提供されるパラメータである。ResponseNewカウンタ280は、いつ応答がホスト106に転送されるか、いつResponseHeadが更新されるか、ホスト応答バッファ123内の未処理の応答の数、及びいつ割り込みが送信されたかを含む情報を入力として受信する。ResponseNewカウンタ280は、ホスト106に転送されてホストがまだ確認してない応答の数を追跡するように構成される。応答が応答バッファ123に転送されるごとに、カウンタがインクリメントされる。カウンタ280が、ホスト106によって設定された電子透かしレベル、すなわちResponseMark 288に到達するか、又はこれを超える場合、電子透かしトリガーが生成され、割り込み送信論理286に送信される。電子透かしレベル、すなわちResponseMark 288は、割り込みを生成する必要のある応答バッファ123内の新しい応答の数である。ホスト106が新しい応答を応答バッファ123から除去する場合、それらは電子透かしレベルに達するようにカウントされることはない。割り込みが生成されると、ResponseMarkへのカウントがリセットされる。
電子透かし割り込み機構が有効化されている唯一の割り込みである場合、電子透かしに到達すると、割り込み送信論理286は、割り込みを生成してホスト106に送信する。ホスト106が割り込みを確認してResponseHeadを更新するまで、それ以上の割り込みは送信されない。更新されたResponseHeadは、割り込みクリア信号として、割り込み送信論理286に伝達される。他の割り込み機構も有効化されている場合、割り込み送信論理286は、他の有効化された割り込み機構も考慮に入れて、割り込みを生成してホスト106に送信する。
最終応答タイマー282は、タイマー割り込み機構が望ましい場合に有効化されてもよい。最終応答タイマー282は、前回の割り込み以降の追跡を行うように構成されてもよい。たとえば、最終応答タイマー282は、前回の割り込み以降の時間をマイクロ秒単位で追跡することができる。ホスト106は、たとえばResponseDelayパラメータ290のようなパラメータを使用して、時間を設定することができる。1つの例示的な実施態様において、ResponseDelay 290タイムアウトは、前回の割り込み以降、又は割り込みが生成される前にホスト106が前回応答バッファ123から新しい応答を除去してからのマイクロ秒数であってもよい。
最終応答タイマー282は、いつ割り込みが送信されるかを指示する信号を入力として受信する。最終応答タイマー282はまた、ResponseHeadが更新されると信号を受信することもできるが、この信号はホスト106が応答バッファ123から応答を除去したことを指示する。割り込みは、応答バッファ123が未処理の応答を含む場合に限り生成されてもよい。
最終応答タイマー282は、最終応答タイマー282によって追跡されている時間がResponseDelayパラメータ290よりも大きい場合に、タイムアウトトリガーを生成するように構成される。この状況が発生して、応答バッファ123が新しい応答を含む場合、タイムアウトトリガー信号は割り込み送信論理286に送信される。最終応答タイマー282が有効化されている唯一の割り込み機構である場合、割り込み送信論理286は、割り込みを生成してホストに送信する。他の割り込み機構も有効化されている場合、割り込み送信論理286は、他の割り込み機構も考慮に入ることができる。
各割り込み機構は有効ビットを含み、割り込み送信論理286は、有効化された割り込み機構のために割り込みトリガーがアサートされる場合、割り込みを生成するように構成されてもよい。論理は、ホスト106が割り込みを確認してResponseHeadを更新するまで、別の割り込みを生成しないように構成されてもよい。Queue Controlパラメータ292は、どの割り込み機構が有効にされ、どの割り込み機構が無効にされているかのような、割り込み機構の状態を指示するために割り込み送信論理286に入力を行うことができる。
グループカウンタ284機構は、ドライバ107によって指定されるグループの一部であるコマンドを追跡するように配置され構成されてもよい。グループカウンタ284は、グループ内のすべてのコマンドが処理される場合に限り、単一割り込みが生成されてホスト106に返信されるように、ホスト106がグループの一部としてコマンドを追跡するよう望むときに、ホスト106によって有効化されてもよい。このように、割り込みは、個々のコマンドごとに生成されることはないが、コマンドのグループに対してのみ生成される。
グループカウンタ284は、コマンドの複数の異なるグループの追跡を有効にするように、複数のカウンタで構成されてもよい。1つの例示的な実施態様において、グループカウンタ284は、コマンドの最大128個までの異なるグループを追跡するように構成されてもよい。このように、コマンドの各グループに対してカウンタがある。カウンタの数は、コマンドヘッダの割り込みグループフィールドを使用して指定されうるグルーブ番号の数に関連してもよい。
グループカウンタ284は、グループの新しいコマンドがコマンドプロセッサ122に入ったときに、グループのカウンタをインクリメントするように構成されてもよい。グループカウンタ284は、グループ内のコマンドの1つが処理を完了したときに、グループのカウンタをデクリメントすることができる。このように新しいコマンドがグループに入るとインクリメントし、コマンドがグループに対して完了するとデクリメントすることで、各グループのコマンドの数は潜在的に無限である。カウンタは、グループ内の潜在的コマンドの最大数を考慮するようにサイズ調整される必要はない。代わりに、カウンタは、データストレージデバイス100が一度に潜在的に処理することができるコマンドの数に基づいてサイズ調整されてもよく、その数は特定のグループ内のコマンドの無限数に満たなくてもよい。
1つの例示的な実施態様において、各々のグループカウンタ284は、ドライバ107によって割り当てられ、各コマンドのコマンドヘッダの割り込みグループフィールドに現れるグループ番号を使用して特定のグループ内のコマンドを追跡することができる。グループカウンタ284は、グループ番号を有するコマンドが処理のためにコマンドプロセッサ122に入るごとに、信号を受信する。この信号に応答して、カウンタはそのグループに対してインクリメントする。グループカウンタ284はまた、グループ番号を有するコマンドが処理を完了するごとに、信号を受信する。この信号に応答して、カウンタはそのグループに対してデクリメントする。
コマンドグループ内の最後のコマンドは、コマンドがグループ内の最後のコマンドであることをグループカウンタ284に指示するためのフラグで、ドライバ107によってマークを付けられてもよい。1つの例示的な実施態様において、コマンドヘッダの割り込みグループフィールド内の最終ビットは、フラグとして使用されてもよい。グループカウンタ284は、いつフラグが設定されるかを認識するように構成されてもよい。このように、グループカウンタ284は、データストレージデバイス100で処理中の特定のグループ内のコマンドの数のカウンタを保持する。グループカウンタ284はまた、いつグループの最後が確認されたかを追跡する。
コマンドがホスト106からデータストレージデバイス100に送信されると、その割り込みグループのカウンタがインクリメントされる。応答がデータストレージデバイス100からホスト106に送信されると、その割り込みグループのカウンタがデクリメントされる。グループ内の最後のコマンドがグループカウンタ284で受信され、そのグループのカウントがゼロになる場合、グループトリガー信号が生成され、割り込み送信論理286に送信される。グループトリガー信号が割り込み送信論理286において受信されると、割り込みはホスト106に送信される。次いで、グループカウンタ284は、そのグループの最終グループフラグをクリアする。
ドライバ107は、使用中のグループを追跡するように構成されてもよい。ドライバ107は、その割り込みグループを使用する以前のコマンドがすべて完了して、割り込みが確認されるまで、割り込みグループ番号を再使用することはない。
1つの例示的な実施態様において、ドライバ107は、生成させたい割り込みの数を動的に決定するように構成されてもよい。たとえば、ドライバ107は、たとえば、ボリューム、待ち時間、及びホスト106のその他の因子を含むさまざまな基準に応じて、コマンドグループのサイズを動的に決定することができる。
1つの例示的な実施態様において、割り込み送信論理286は、複数の割り込みグループの複数の割り込みを集約して、コマンドの複数のグループの単一割り込みのみを送信するように構成されてもよい。
図3は、コマンドプロセッサ122を示すブロック図である。コマンドプロセッサ122は、スロットトラッカモジュール302、コマンド転送モジュール304、処理中コマンドモジュール306、コマンドパケットメモリ308、及びタスクディスパッチモジュール310を含むことができる。コマンドプロセッサ122は、ハードウェア、ソフトウェア、又はハードウェア及びソフトウェアの組み合わせで実施されてもよい。1つの例示的な実施態様において、コマンドプロセッサ122は、フィールドプログラマブルゲートアレイ(field programmable gate array)(FPGA)コントローラの一部として実施されてもよい。FPGAコントローラは、本明細書において説明される機能を実行するようにFPGAコントローラをプログラムするファームウェア又はその他の命令を使用して構成されてもよい。
コマンドプロセッサ122は、ホストからコマンドを取り出して、さまざまなストレージ位置により処理するためにホストからのコマンドをキューに入れて順序付けるように配置され構成されてもよい。コマンドプロセッサ122は、ストレージ位置のすべて、又は実質的にすべてをビジー状態に保持しようと試みることにより、ストレージ位置の可用性を最大化するように構成されてもよい。コマンドプロセッサ122は、ホストから受信されたコマンドの順序が保持されるように、同じストレージ位置に指定されているコマンドを順序正しくディスパッチするように構成されてもよい。コマンドプロセッサ122はまた、異なるストレージ位置に指定されているコマンドを再配列して順不同にディスパッチするように構成されてもよい。このように、ホストから受信されたコマンドは、異なるストレージ位置に指定されているコマンドを再配列することにより並列に処理されてもよく、同時に、同じストレージ位置に指定されているコマンドの順序が保持される。
1つの例示的な実施態様において、コマンドプロセッサ122は、番号付きリストを使用して、ホストからのコマンドをキューに入れて順序付けることができる。1つの例示的な実施態様において、番号付きリストはソートされてもよく、及び/又はそれ以外の場合ホストからのコマンドの経過時間に基づいて順序付けられてもよい。たとえば、ホストから新しいコマンドが受信されると、それらのコマンドは、ホストから受信された順序で番号付きリストの末尾に配置される。このように、順序に依存するコマンド(たとえば、同じストレージ位置に指定されているコマンド)は、正しい順序で保持される。
1つの例示的な実施態様において、ストレージ位置は複数のフラッシュメモリチップを含むことができる。フラッシュメモリチップは、複数のチャネルに配置され構成されてもよく、各々のチャネルは1つ以上のフラッシュメモリチップを含む。コマンドプロセッサ122は、同じチャネル及び/又は同じフラッシュメモリチップに指定されているコマンドを、番号付きリストに基づいて順序正しくディスパッチするように配置され構成されてもよい。また、コマンドプロセッサ122は、異なるチャネル及び/又は異なるフラッシュメモリチップに指定されているコマンドを順不同にディスパッチするように配置され構成されてもよい。このように、コマンドプロセッサ122は、チャネル及びフラッシュメモリチップが同時にビジー状態になるように、必要に応じて、番号付きリストからコマンドを再配列することができる。そうすることで、ホストからのコマンドは並列に処理されるようになり、さらに多くのコマンドが、異なるチャネル及び異なるフラッシュメモリチップで同時に処理されるようになる。
ホストからのコマンドは、ドライバ(たとえば、図1のドライバ107)の制御の下にディスパッチされて追跡されてもよく、ドライバは、ストレージ媒体において明白に具現され、ホスト(たとえば、図1のホスト106)からコマンドを生成してディスパッチするための命令を含むことができるコンピュータプログラム製品であってもよい。ホストからのコマンドは、たとえば、特定のフラッシュメモリチップ及び/又は特定のチャネルなど、特定のストレージ位置を指定することができる。ホストの観点からは、同じストレージ位置に指定されているコマンドが、ホストによって指定された順序で実行されることが重要であってもよい。たとえば、ホストによって生成される特定の操作が、同じフラッシュメモリチップ上で順序正しく生じることが重要であってもよい。たとえば、ホストは、特定のフラッシュメモリチップに対して消去コマンド及び書き込みコマンドを生成して送信することができ、ホストは消去コマンドが先に生じるよう望むとする。書き込みコマンドに関連付けられているデータが、フラッシュメモリチップに書き込まれた直後に消去されることがないように、消去操作が先に生じることが重要である。
もう1つの例として、フラッシュメモリチップの場合、消去ブロックのページに順序正しく書き込むことが重要となることもある。この操作は、同じフラッシュメモリチップ上で操作を実行するための複数のコマンドを含むことができる。この例において、この操作に対するそれらのコマンドを、ホストによって指定された順序で実行することが必要である。たとえば、単一書き込み操作は、60個を超えるコマンドを含むことがある。コマンドプロセッサ122は、同じフラッシュメモリチップへのコマンドが、番号付きリストを使用して順序正しく実行されることを確実にするように構成されてもよい。
1つの例示的な実施態様において、コマンドプロセッサ122は、処理中のコマンドの数を追跡するように構成されてもよい。コマンドプロセッサ122は、受信され処理されるコマンドに使用可能なスロットの数を追跡するように構成されてもよい。コマンドプロセッサ122のコンポーネントの1つである、スロットトラッカモジュール302は、ホストからのコマンドに使用可能なスロットを追跡するように構成されてもよい。スロットトラッカモジュール302は、開放スロットを追跡して、ホストから転送された新しいコマンドをスロットに提供し、コマンドの完了時にスロットを開放状態にあると指定することができる。
1つの例示的な実施態様において、スロットトラッカモジュール302は、固定数のスロットを含むことができ、各スロットは単一コマンドに指定されてもよい。たとえば、スロットトラッカモジュール302は、128個のスロットを含むことができる。その他の例示的な実施態様において、スロットトラッカモジュール302は、異なる数の固定スロットを含むことができる。さらに、たとえば、スロットの数は可変又は構成可能であってもよい。スロットトラッカモジュール302は、ソフトウェア、ハードウェア、又はハードウェア及びソフトウェアの組み合わせにおけるレジスタ又はメモリモジュールとして実施されてもよい。
スロットトラッカモジュール302は、スロットのリストを含むことができ、各々のスロットはグローバルスロット識別子に関連付けられている。コマンドがホストから受信されると、コマンドは、使用可能なホストに割り当てられ、そのスロットのグローバルスロット識別子に関連付けられる。スロットトラッカモジュール302は、各々のコマンドにグローバルスロット識別子を割り当てるように構成されてもよく、グローバルスロット識別子の数は、スロットトラッカモジュール302のスロットの数と一致するように固定される。コマンドが完了してスロットが開放されるまで、コマンドはその処理全体にわたりグローバルスロット識別子に関連付けられている。1つの例示的な実施態様において、グローバルスロット識別子は、特定のスロットを満たすコマンドに割り当てられる特定のスロットに関連付けられているタグである。タグはコマンドに関連付けられており、コマンドの処理が完了して、占有していたスロットが開放され、新しいコマンドの受信に使用できるようにされるまで、コマンドに関連付けられた状態を保つ。コマンドは、スロットの順序で配置されなくてもよいが、その代わり、使用可能なスロットのいずれかに配置されて、そのスロットに関連付けられているグローバルスロット識別子を割り当てられてもよい。
1つの例示的な実施態様において、コマンドプロセッサ122のコンポーネントの1つである、コマンド転送モジュール304は、スロットトラッカモジュール302の使用可能なスロットの数及びホストにおける新しいコマンドの可用性に基づいて、ホストから新しいコマンドを取り出すように構成されてもよい。1つの例示的な実施態様において、コマンド転送モジュール304は、状態マシンとして実施されてもよい。
スロットトラッカモジュール302は、使用可能なスロットの数に関する情報をコマンド転送モジュール304に提供することができる。また、コマンド転送モジュール304は、使用可能なスロットの数についてスロットトラッカモジュール302にクエリを行うことができる。
1つの例示的な実施態様において、コマンド転送モジュール304は、コマンドテールポインタ312及びコマンドヘッドポインタ314を使用して、取り出しのためにホストにおいて新しいコマンドが使用可能になる時及び使用可能なコマンドの数を指示することができる。コマンド転送モジュール304は、コマンドテールポインタ312とコマンドヘッドポインタ314を比較して、ホストから取り出しに使用可能なコマンドがあるかどうかを決定することができる。コマンドテールポインタ312とコマンドヘッドポインタ314が等しい場合、転送に使用可能なコマンドはない。コマンドテールポインタ312がコマンドヘッドポインタ314よりも大きい場合、コマンドは転送に使用可能である。
1つの例示的な実施態様において、コマンドテールポインタ312及びコマンドヘッドポインタ314は、ポインタ値を保持するように構成されるレジスタとして実施されてもよく、コマンドプロセッサ122の一部であってもよい。コマンドテールポインタ314は、ホストによって書き込まれてもよい。たとえば、ドライバは、取り出しのためにホストでコマンドが使用可能である場合、メモリマップ入出力(MMIO)書き込みを使用して、コマンドテールポインタ312を更新することができる。コマンドがホストから取り出されると、コマンド転送モジュール304は、コマンドヘッドポインタ314を更新する。
ホストにおける使用可能なスロット及び使用可能なコマンドの条件が満たされると、コマンド転送モジュール304は、ホストから使用可能なコマンドの一部又は全部を取り出すことができる。1つの例示的な実施態様において、コマンド転送モジュール304は、単一アクセスでコマンドのグループを取り出すことができる。たとえば、コマンド転送モジュール304は、ホストからダイレクトメモリアクセス(direct memory access)(DMA)操作を使用して一度に8つのコマンドのグループを取り出すように構成されてもよい。コマンドが取り出されると、コマンド転送モジュール304は、コマンドヘッドポインタ314を更新する。コマンドは、バスマスタ316を通じてホストから取り出されてもよい。コマンド転送モジュール304はまた、DMA操作を使用してバスマスタ316を通じてホストコマンドヘッドポインタ(図示せず)を書き込み、ホストのコマンドヘッドポインタを更新することもできる。
キューコントロール318は、コマンド転送モジュール304を有効化及び無効化するように構成されてもよい。キューコントロール318は、ドライバを通じてホストから命令を受信するレジスタとして実施されてもよい。キューコントロール318は、コマンドプロセッサ122のコンポーネントであってもよい。キューコントロール318レジスタが有効に設定される場合、コマンド転送モジュール304は、ホストからコマンドを取り出して処理することができる。ドライバは、ホストが準備が整い、準備が整っていることを示す指示を提供した場合に限り、コマンド転送モジュール304がコマンドを取り出すように、キューコントロール318の設定を制御する。キューコントロール318レジスタが無効に設定される場合、コマンド転送モジュール104は、ホストからコマンドを取り出して処理しなくてよい。
取り出されたコマンドは各々、スロットトラッカモジュール302によって使用可能なスロットの1つに割り当てられ、その使用可能なスロットのグローバルスロット識別子に関連付けられる。コマンドのデータは、コマンドパケットメモリ308に格納されてもよい。たとえば、コマンドパケットメモリ308は、グローバルスロット識別子によって索引付けされる固定バッファとして実施されてもよい。特定のコマンドのデータは、コマンドパケットメモリ308に格納され、その割り当てられたグローバルスロット識別子によって索引付けされてもよい。特定のコマンドのデータは、コマンドがタスクディスパッチモジュール310によって指定されたストレージ位置にディスパッチされるまで、コマンドパケットメモリ308に引き続き保持されてもよい。
コマンド転送モジュール304はまた、スロットによって索引付けされる際にコマンドに関連する情報をコントローラの他のコンポーネントに提供するように構成されてもよい。たとえば、コマンド転送モジュール304は、データをDMAエンジンに提供することができる。コマンド転送モジュール304はまた、状態パケットヘッダデータを状態プロセッサに提供することができる。コマンド転送モジュール304は、割り込みグループデータを割り込みプロセッサに提供することができる。たとえば、コマンド転送モジュール304は、グループ情報319を割り込みプロセッサ(たとえば、図1及び図2の割り込みプロセッサ124)に転送することができる。
処理中コマンドモジュール306は、コマンドの経過時間に基づく番号付きリストを使用してコマンドをキューに入れ、順序付けるように構成されてもよい。1つの例示的な実施態様において、処理中コマンドモジュール306は、コマンドをキューに入れて順序付けるために複数のポインタを格納するように構成されるメモリモジュールとして実施されてもよい。処理中コマンドモジュール306は、ストレージ位置識別子と共に処理中のコマンドのグローバルスロット識別子のリストを含むことができる。たとえば、ストレージ位置識別子は、コマンドが処理されるべき指定されたストレージ位置を含むことができる。ストレージ位置識別子は、チャネル識別子及び/又はフラッシュメモリチップ識別子を含むことができる。ストレージ位置識別子は、コマンドの一部であり、そのドライバを通じてホストにより割り当てられる。
新しいコマンドが取り出されると、グローバルスロット識別子及びストレージ位置情報は、処理中コマンドモジュール306の番号付きリストの末尾に追加される。上記で説明されるように、コマンドのデータは、コマンドパケットメモリ308に格納され、グローバルスロット識別子によって索引付けされる。コマンドが番号付きリストに追加されると、以前のコマンドを指し示すポインタがコマンドと共に含まれる。さらに、次のコマンドを指し示すポインタも含まれる。このように、番号付きリスト内の各項目は、グローバルタスク識別子、ストレージ位置識別子、以前のコマンドを指し示すポインタ、及び次のコマンドを指し示すポインタを含む。この例示的な実施態様において、番号付きリストは二重連結リストと呼ぶことができる。番号付きリストは、最も古いものから最新のものへと順序付けられたコマンドのリストである。
タスクディスパッチモジュール310は、処理中コマンドモジュール306の番号付きリストからコマンドを除去し、それらを処理のために適切なストレージ位置にディスパッチするように構成される。タスクディスパッチモジュール310は、ストレージ位置から、新しいコマンドを受け入れる準備が整っていることを指示する入力を受信することができる。1つの例示的な実施態様において、タスクディスパッチモジュール310は、1つ以上のストレージ位置が新しいコマンドを受け入れる準備が整っていることを指示する信号のような、1つ以上の信号320を受信することができる。処理中コマンドモジュール306は、最も古いコマンドを最初にして番号付きリストの先頭から開始して、そのコマンドをタスクディスパッチモジュール310に使用可能にするように構成されてもよい。処理中コマンドモジュール306は、コマンドがタスクディスパッチモジュール310によってリストから除去されるまで番号付きリストを使用して正しい順序でコマンドをタスクディスパッチモジュール310に引き続き使用可能にすることができる。処理中コマンドモジュール306の番号付きリストからコマンドが除去された後、処理中コマンドモジュール306は、番号付きリストの先頭から再度開始して、リスト内に残るコマンドをタスクディスパッチモジュール310に再生する。
タスクディスパッチモジュール310は、最も古いコマンドを最初にして番号付きリストの先頭から開始し、信号320を使用してストレージ位置が新しいコマンドを受信するために使用可能であるかどうか決定するように構成されてもよい。ストレージ位置の準備が整っている場合、タスクディスパッチモジュール310は、コマンドパケットメモリ308からコマンドデータを取り出して、コマンドデータ及びストレージ位置選択信号322をストレージ位置に伝達する。次いで、処理中コマンドモジュール306は、コマンドが処理のためにディスパッチされたことを反映するように、番号付きリスト及びポインタを更新する。コマンドがディスパッチされると、タスクディスパッチモジュール310は再度、番号付きリストの先頭から開始する。
ストレージ位置が新しいコマンドを受信する準備が整っていない場合、タスクディスパッチモジュール310は番号付きリストの次のコマンドに移動する。タスクディスパッチモジュール310は、次のコマンドが、スキップされたコマンドと同じストレージ位置又は異なるストレージ位置に対するものかどうかを決定する。次のコマンドが、スキップされたコマンドと同じストレージ位置に対するものである場合、タスクディスパッチモジュール310はまた、このコマンドをスキップする。このように、同じストレージ位置に指定されているコマンドは、ホストから受信された正しい順序で、ディスパッチされて処理される。タスクディスパッチモジュール310は、同じストレージ位置に指定されているコマンドの順序を保持する。コマンドが異なるストレージ位置に指定されている場合、タスクディスパッチモジュール310は再度、リストの次のコマンドのストレージ位置が新しいコマンドを受け入れる準備が整っているかどうかを決定する。ストレージ位置が新しいコマンドを受け入れる準備が整っていることを示す信号をタスクディスパッチモジュール310が受信する場合、コマンドはタスクディスパッチモジュール310により、ストレージ位置選択信号322と共に、コマンドパケットメモリ308からストレージ位置にディスパッチされる。処理中コマンドモジュール306は、ディスパッチされたコマンドを番号付きリストから除去して、コマンドに関連付けられていたポインタを更新することを含めて、番号付きリストを更新する。このように、残りのポインタは、ディスパッチされたコマンドが除去される際に連結される。
さらに図4を参照すると、処理中コマンドモジュール306を示すブロック図が示される。処理中コマンドモジュール306は、ポートA及びポートBという複数のポートを有する単一メモリモジュール402を含むことができる。メモリモジュール402は、各コマンドのポインタ情報を含む処理中コマンドに関連する情報を格納することができ、ポインタ情報は次のコマンド及び以前のコマンドを指し示すことができる。
操作中、図3のコマンド転送モジュール304は、番号付きリストに追加される新しいコマンドを求める新エントリ要求406を処理中コマンドモジュール306に送信する。新エントリ要求406は、新エントリモジュール408によって受信される。1つの例示的な実施態様において、新エントリモジュール408は、状態マシンとして実施されてもよい。
新エントリモジュール408は、新エントリ要求406を受信し、それをメモリモジュール402の最新のコマンドとしてリストの最後で番号付きリストに追加する。また、新エントリモジュール408は、フリーポインタリストモジュール410にポインタを要求する。フリーポインタリストモジュール410は、新しいエントリに使用されうるポインタのリストを保持する先入れ先出し(FIFO)メモリとして実施されてもよい。
新エントリモジュール408がフリーポインタリストモジュール410にポインタを要求すると、フリーポインタリストモジュール410は、次エントリポインタ412を新エントリモジュール408に提供する。次エントリポインタ412は、現在の新しいエントリの後に続くエントリが番号付きリストに常駐する位置を指し示すポインタである。リスト内の現在の新しいエントリは、このアドレスをその次のアドレスとして指し示す。新エントリポインタ414は、現在の新しいエントリが番号付きリストに常駐する位置を指し示すポインタであり、このポインタは以前のエントリの次エントリポインタ412であった。リスト内の前回のエントリは、このアドレスをその次のアドレスとして指し示す。メモリモジュール402は、コマンド及びポインタに関連するデータフィールドを格納する。新しいエントリが追加されると、終了ポインタ420もまた更新される。
たとえば、エントリ「X」が追加される場合、次エントリポインタ412は次のエントリ「Y」を指し示し、新エントリポインタ414は追加されるべき現在のエントリ「X」を指し示す。「X」が入力されてエントリ「Y」が追加された後、次エントリポインタ412は次のエントリ「Z」を指し示し、新エントリポインタ414は追加されるべき現在のエントリ「Y」を指し示す。
図3のタスクディスパッチモジュール310が、メモリモジュール402の番号付きリストからエントリが除去されることを決定すると、タスクディスパッチモジュールは削除要求416を送信する。削除要求は、エントリ再生及び削除モジュール418によって受信される。エントリ再生及び削除モジュール418は、最も古いコマンドを最初にして番号付きリストの先頭から開始して、そのコマンドをタスクディスパッチモジュール310に使用可能にするように構成されてもよい。エントリ再生及び削除モジュール418は、コマンドがタスクディスパッチモジュール310によってリストから除去されるまで番号付きリストを使用して正しい順序でコマンドをタスクディスパッチモジュール310に引き続き使用可能にすることができる。コマンドが番号付きリストから除去された後、エントリ再生及び削除モジュール418は、メモリモジュール402に、コマンドをディスパッチさせ、それを番号付きリストから除去させる。次いで、ポインタは解放され、エントリ再生及び削除モジュール418は、除去されたコマンドのポインタがフリーであることを示す指示をフリーポインタリストモジュール410に提供する。エントリ再生及び削除モジュール418はまた、リストの正しい順序を保持するためにコマンドが除去されるとき、メモリモジュール402内のポインタを更新する。エントリ再生及び削除モジュール418はまた、番号付きリストの先頭から再度開始して、リストに残っているコマンドをタスクディスパッチモジュール310に再生する。
1つの例示的な実施態様において、エントリ再生及び削除モジュール418は、状態マシンとして実施されてもよい。エントリ再生及び削除モジュール418はまた、新エントリモジュール408から終了ポインタ420の入力を受信する。終了ポインタ420は、エントリ再生及び削除モジュール418が、コマンドをスクディスパッチモジュール310に使用可能にするとき、及び番号付きリストの最後のエントリがリストから除去されるときに使用されてもよい。このように、終了ポインタ420は、番号付きリストの終わりを指し示すように更新されてもよい。
戻って図1を参照すると、1つの例示的な実施態様において、自身のPCBであるコントローラボード102は、自身の別個のPCB上にある各々のメモリボード104a及び104bの間に物理的に配置されてもよい。また図5を参照すると、データストレージデバイス100は、1つのPCB上にメモリボード104a、第2のPCB上にコントローラボード102、及び第3のPCB上にメモリボード104bを含むことができる。メモリボード104aは複数のフラッシュメモリチップ118aを含み、メモリボード104bは複数のフラッシュメモリチップ118bを含む。コントローラボード102は、コントローラ110、及びホスト(図示せず)へのインターフェイス108、並びにその他のコンポーネント(図示せず)を含む。
図5に示される例において、メモリボード104aは、コントローラボード102に機能的に接続され、コントローラボード102の片側520aに配置されてもよい。たとえば、メモリボード104aは、コントローラボード102の上側520aに接続されてもよい。メモリボード104bは、コントローラボード102に機能的に接続され、コントローラボード102の第2の側520bに配置されてもよい。たとえば、メモリボード104bは、コントローラボード102の下側520bに接続されてもよい。
メモリボード104a及び104bとコントローラボード102との間のその他の物理的及び/又は電気的な接続配列が可能である。図5は、単に1つの例示的な配列を示すにすぎない。たとえば、データストレージデバイス100は、3つのメモリボード、4つのメモリボード、又はそれ以上のメモリボードのような、2つ以上のメモリボードを含むことができ、すべてのメモリボードは単一のコントローラボードに接続される。このように、データストレージデバイスは、ディスクドライブフォームファクタでさらに構成されてもよい。また、メモリボードは、たとえばコントローラボードが上部でメモリカードが下部、又はコントローラボードが下部でメモリカードが上部のように、その他の配列でコントローラボードに接続されてもよい。
データストレージデバイス100は、コンピューティングデバイスと協働するように配置され構成されてもよい。1つの例示的な実施態様において、コントローラボード102及びメモリボード104a及び104bは、コンピューティングデバイスのドライブベイ内に適合するように配置され構成されてもよい。図6を参照すると、2つの例示的なコンピューティングデバイス、すなわちサーバ630及びサーバ640が示される。サーバ630及び640は、さまざまな異なるタイプのコンピューティングサービスを提供するように配置され構成されてもよい。サーバ630及び640は、サーバ630及び640の1つ以上のプロセッサにコンピューティングサービスを提供させる命令を有するコンピュータプログラム製品を含むホスト(たとえば、図1のホスト106)を含むことができる。サーバのタイプは、サーバ上で動作している1つ以上のアプリケーションプログラム(たとえば、図1のアプリケーション113)によって異なる。たとえば、サーバ630及び640は、アプリケーションサーバ、Webサーバ、Eメールサーバ、検索サーバ、ストリーミングメディアサーバ、Eコマースサーバ、ファイル転送プロトコル(file transfer protocol)(FTP)サーバ、その他のタイプのサーバ、又はそれらのサーバの組み合わせであってもよい。サーバ630は、サーバラック内で動作するラックマウント型サーバとなるように構成されてもよい。サーバ640は、サーバラックから独立して動作するスタンドアロンのサーバとなるように構成されてもよい。サーバ640がサーバラック内にはない場合であっても、他のサーバと共に動作するように構成されてもよく、他のサーバに機能的に接続されてもよい。サーバ630及び640は、例示のコンピューティングデバイスを示すことが意図されており、その他のタイプのサーバを含む他のコンピューティングデバイスが使用されてもよい。
1つの例示的な実施態様において、図1及び図5のデータストレージデバイス100は、サーバ630及び640のデータストレージ機能をもたらすために、サーバ630のドライブベイ635又はサーバ640のドライブベイ645内に適合するようにサイズ調整されてもよい。たとえば、データストレージデバイス100は、ドライブベイ635及び645に適合するように、3.5"ディスクドライブフォームファクタにサイズ調整されてもよい。データストレージデバイス100はまた、その他のサイズに構成されてもよい。データストレージデバイス100は、インターフェイス108を使用してサーバ630及び560に機能的に接続されて通信することができる。このように、ホストは、インターフェイス108を使用してコントローラボード102にコマンドを伝達することができ、コントローラ110は、メモリボード104a及び104b上のフラッシュメモリチップ118a及び118bを使用してコマンドを実行することができる。
戻って図1を参照すると、インターフェイス108は、コントローラ110とホスト106との間の高速インターフェイスを含むことができる。高速インターフェイスは、ホスト106とフラッシュメモリチップ118a及び118bとの間のデータの高速転送を可能にすることができる。1つの例示の実施態様において、高速インターフェイスは、PCIeインターフェイスを含むことができる。たとえば、PCIeインターフェイスは、PCIe x4インターフェイス又はPCIe x8インターフェイスであってもよい。PCIeインターフェイス108は、たとえばPCIeコネクタケーブルアセンブリのような、ホスト106へのコネクタを含むことができる。その他の高速インターフェイス、コネクタ、及びコネクタアセンブリが使用されてもよい。
1つの例示的な実施態様において、コントローラボード102とメモリボード104a及び104b上のフラッシュメモリチップ118a及び118bとの間の通信は、複数のチャネル112に配置されて構成されてもよい。各チャネル112は、1つ以上のフラッシュメモリチップ118a及び118bと通信することができ、チャネルコントローラ(図示せず)によって制御されてもよい。コントローラ110は、ホスト106から受信されたコマンドが、各々のチャネル112を使用して、同時に、又は少なくとも実質的に同時にコントローラ110によって実行されうるように構成されてもよい。このように、複数のコマンドは、異なるチャネル112で同時に実行することができ、データストレージデバイス100のスループットを向上させることができる。
図1の例において、20個のチャネル112が示される。完全な実線は、コントローラ110とメモリボード104a上のフラッシュメモリチップ118aとの間の10個のチャネルを示す。実線及び破線の混合線は、コントローラ110とメモリボード104b上のフラッシュメモリチップ118bとの間の10個のチャネルを示す。図1に示すように、各々のチャネル112は、複数のフラッシュメモリチップをサポートすることができる。たとえば、各々のチャネル112は、最大32個のフラッシュメモリチップをサポートすることができる。1つの例示的な実施態様において、20個のチャネルは各々、6個のフラッシュメモリチップをサポートして通信するように構成されてもよい。この例において、各々のメモリボード104a及び104bは、それぞれ60個のフラッシュメモリチップを含むことができる。フラッシュメモリチップ118a及び118bのタイプ及び数に応じて、データストレージデバイス100は、最大多数テラバイトのデータまで格納するように構成されてもよい。
コントローラ110は、マイクロコントローラ、FPGAコントローラ、その他のタイプのコントローラ、又はそれらのコントローラの組み合わせを含むことができる。1つの例示の実施態様において、コントローラ110はマイクロコントローラである。マイクロコントローラは、ハードウェア、ソフトウェア、又はハードウェア及びソフトウェアの組み合わせで実施されてもよい。たとえば、マイクロコントローラは、実行されると、特定の方法でマイクロコントローラに実行させることができる命令を含むコンピュータプログラム製品がメモリ(たとえば、メモリモジュール116)からロードされてもよい。マイクロコントローラは、インターフェイス108を使用してホスト106からコマンドを受信し、コマンドを実行するように構成されてもよい。たとえば、コマンドは、フラッシュメモリチップ118a及び118bを使用してデータのブロックの読み取り、書き込み、コピー、及び削除を行うコマンド、並びにその他のコマンドを含むことができる。
もう1つの例示的な実施態様において、コントローラ110はFPGAコントローラである。FPGAコントローラは、ハードウェア、ソフトウェア、又はハードウェア及びソフトウェアの組み合わせで実施されてもよい。たとえば、FPGAコントローラは、実行されると、特定の方法でFPGAコントローラに実行させることができる命令を含むファームウェアがメモリ(たとえば、メモリモジュール116)からロードされてもよい。FPGAコントローラは、インターフェイス108を使用してホスト106からコマンドを受信し、コマンドを実行するように構成されてもよい。たとえば、コマンドは、フラッシュメモリチップ118a及び118bを使用してデータのブロックの読み取り、書き込み、コピー、及び削除を行うコマンド、並びにその他のコマンドを含むことができる。
1つの例示の実施態様において、FPGAコントローラは、ホスト106との複数のインターフェイス108をサポートすることができる。たとえば、FPGAコントローラは、ホスト106との複数のPCIe x4又はPCIe x8インターフェイスをサポートするように構成されてもよい。
メモリモジュール116は、コントローラ110にロードされうるデータを格納するように構成されてもよい。たとえば、メモリモジュール116は、FPGAコントローラの1つ以上のイメージを格納するように構成されてもよく、イメージはFPGAコントローラによって使用されるファームウェアを含む。メモリモジュール116は、ホスト106と通信するために、ホスト106とのインターフェイスをとることができる。メモリモジュール116は、ホスト106と直接インターフェイスをとることができる、及び/又はコントローラ110を通じてホスト106と間接的にインターフェイスをとることができる。たとえば、ホスト106は、ファームウェアの1つ以上のイメージを、格納のためにメモリモジュール116に伝達することができる。1つの例示的な実施態様において、メモリモジュール116は、電気的消去可能プログラマブルROM(electrically erasable programmable read-only memory)(EEPROM)を含む。メモリモジュール116はまた、その他のタイプのメモリモジュールを含むことができる。
電源モジュール114は、電力(Vin)を受信し、受信した電力の任意の変換を実行し、出力電力(Vout)を出力するように構成されてもよい。電源モジュール114は、ホスト106から、又は別の電源から、電力(Vin)を受信することができる。電源モジュール114は、コントローラボード102、及びコントローラ110を含むコントローラボード102上のコンポーネントに電力(Vout)を提供することができる。電源モジュール114はまた、メモリボード104a及び104b、並びにフラッシュメモリチップ118a及び118bを含むメモリボード104a及び104b上のコンポーネントに電力(Vout)を提供することができる。
1つの例示的な実施態様において、電源モジュール114は、1つ以上のDC(直流)-DC変換器を含むことができる。DC-DC変換器は、入力電力(Vin)を受信して、電力を1つ以上の異なる電力レベル(Vout)に変換するように構成されてもよい。たとえば、電源モジュール114は、+12V(Vin)を受信し、電力を3.3V、1.2V、又は1.8Vに変換して、出力電力(Vout)をコントローラボード102並びにメモリボード104a及び104bに供給するように構成されてもよい。
メモリボード104a及び104bは、さまざまなタイプのフラッシュメモリチップ118a及び118bに対処するように構成されてもよい。1つの例示的な実施態様において、フラッシュメモリチップ118a及びフラッシュメモリチップ118bは、電源モジュール114から同じ電圧を必要とすること、及び同じフラッシュメモリチップベンダーのものであることを含む同じタイプのフラッシュメモリチップであってもよい。ベンダー及び製造元という用語は、本文書全体を通じて同義的に使用される。
もう1つの例示的な実施態様において、メモリボード104a上のフラッシュメモリチップ118aは、メモリボード104b上のフラッシュメモリチップ118bとは異なるタイプであってもよい。たとえば、メモリボード104aはSLC NANDフラッシュメモリチップを含むことができ、メモリボード104bはMLC NANDフラッシュメモリチップを含むことができる。もう1つの例において、メモリボード104aはあるフラッシュメモリチップ製造元によるフラッシュメモリチップを含むこともあり、メモリボード104bは別のフラッシュメモリチップ製造元によるフラッシュメモリチップを含むこともある。すべて同じタイプのフラッシュメモリチップを備えるか、又は異なるタイプのフラッシュメモリチップを備えるという柔軟性があるため、データストレージデバイス100は、ホスト106に使用されているさまざまなアプリケーション113に合わせて調整することができる。
もう1つの例示的な実施態様において、メモリボード104a及び104bは、同じメモリボード上に異なるタイプのフラッシュメモリチップを含むことができる。たとえば、メモリボード104aは、同じPCB上にSLC NANDチップとMLC NANDチップの両方を含むことができる。同様に、メモリボード104bは、SLC NANDチップとMLC NANDチップの両方を含むことができる。このように、データストレージデバイス100は、ホスト106の仕様に適合するように有利に調整されてもよい。
もう1つの例示的な実施態様において、メモリボード104a及び104bは、フラッシュメモリ以外のチップを含む、その他のタイプのメモリデバイスを含むことができる。たとえば、メモリボード104a及び104bは、たとえばダイナミックRAM(DRAM)及びスタティックRAM(SRAM)のようなランダムアクセスメモリ(RAM)、並びにその他のタイプのRAM及びその他のタイプのメモリデバイスを含むこともできる。1つの例示的な実施態様において、メモリボード104a及び104bはいずれも、RAMを含むことができる。もう1つの例示的な実施態様において、メモリボードの一方はRAMを含み、もう一方のメモリボードはフラッシュメモリチップを含むことができる。また、メモリボードの一方は、RAM及びフラッシュメモリチップの両方を含むことができる。
メモリボード104a及び104b上のメモリモジュール120a及び120bは、それぞれフラッシュメモリチップ118a及び118bに関連する情報を格納するために使用されてもよい。1つの例示的な実施態様において、メモリモジュール120a及び120bは、フラッシュメモリチップのデバイス特性を格納することができる。デバイス特性は、チップがSLCチップ又はMLCのいずれであるか、チップがNAND又はNORチップのいずれであるか、チップセレクトの数、ブロックの数、ブロックあたりのページの数、ページあたりのバイトの数、及びチップの速度を含むことができる。
1つの例示的な実施態様において、メモリモジュール120a及び120bは、シリアルEEPROMを含むことができる。EEPROMは、デバイス特性を格納することができる。デバイス特性は、任意の所定のタイプのフラッシュメモリチップに対して1回コンパイルされてもよく、適切なEEPROMイメージがデバイス特性と共に生成されてもよい。メモリボード104a及び104bがコントローラボード102に機能的に接続される場合、デバイス特性は、コントローラ110が制御しているフラッシュメモリチップ118a及び118bのタイプをコントローラ110が自動的に認識できるように、EEPROMから読み取られてもよい。加えて、デバイス特性は、特定の1つ以上のタイプのフラッシュメモリチップ118a及び118bの適切なパラメータにコントローラ110を構成するために使用されてもよい。
図7を参照すると、データストレージデバイスでコマンドのグループを処理するためのプロセス700が示される。プロセス700は、ホストからコマンドのグループを受信することであって、グループ内の各々のコマンドがグループの一部としてコマンドを識別するために同じグループ番号を含むこと(710)と、複数のメモリチップを使用してコマンドのグループを処理すること(720)と、コマンドのグループが処理を完了すると、単一割り込みを生成してホストに送信すること(703)とを含むことができる。
1つの例示的な実施態様において、コントローラ110は、プロセス700を実行するように構成されてもよい。たとえば、コントローラ110及びそのコンポーネントは、ホスト106からコマンドのグループを受信するように構成されてもよく、ホスト106は、グループの一部としてコマンドを識別するために、グループ内の各々のコマンドのコマンドヘッダの同じグループ番号を割り当てる(710)。コマンドプロセッサ122は、フラッシュメモリチップ118a及び118bを使用してコマンドを処理するように構成されてもよい(720)。コマンドプロセッサ122は、フラッシュメモリチップ118a及び118bを使用して、不連続の順序でコマンドを処理するように構成されてもよい。割り込みプロセッサ124は、コマンドのグループが処理を完了すると、単一割り込みを生成して送信するように構成されてもよい(730)。
1つの例示的な実施態様において、コントローラ110は、ホスト106からコマンドの複数のグループを受信するように構成されてもよく、コマンドの各々の異なるグループは、異なるグループ番号を割り当てられる。ドライバ107は、コマンドの異なるグループに割り当てられるグループ番号を追跡するように構成されてもよい。コマンドプロセッサ122は、コマンドの複数のグループを処理するように構成されてもよい。割り込みプロセッサ124は、特定のグループ内のすべてのコマンドが処理を完了すると、コマンドの異なるグループの各々に対して単一割り込みを生成して送信するように構成されてもよい。
図8を参照すると、コントローラにおいてコマンドを追跡するためのプロセス800が示される。プロセス800は、コマンドのグループ内のコマンドが処理を開始すると、グループカウンタをインクリメントすること(810)と、コマンドのグループ内のコマンドが処理を完了すると、グループカウンタをデクリメントすること(820)と、グループ内のすべてのコマンドが処理を完了すると、コマンドのグループの単一割り込みを生成して送信すること(830)とを含むことができる。
1つの例示的な実施態様において、プロセス800は、コントローラ110及びそのコンポーネントによって実行されてもよい。たとえば、割り込みプロセッサ124は、コマンドのグループ内のコマンドが処理を開始すると、グループカウンタ284をインクリメントするように構成されてもよい(810)。割り込みプロセッサ124は、コマンドのグループ内のコマンドが処理を完了すると、グループカウンタ284をデクリメントするように構成されてもよい(820)。割り込みプロセッサ124は、グループ内のすべてのコマンドが処理を完了すると、コマンドのグループの単一割り込みを生成して送信するように構成されてもよい(830)。1つの例示的な実施態様において、割り込みプロセッサ124は、コマンドのグループ内の最後のコマンドが処理を開始して、グループカウンタがゼロにデクリメントされると、単一割り込みコマンドを生成して送信することができる。
本明細書において説明されるさまざまな技法の実施態様は、デジタル電子回路において、又はコンピュータハードウェア、ファームウェア、ソフトウェア、若しくはその組み合わせで実施されてもよい。実施態様は、コンピュータプログラム製品として、すなわち、たとえばプログラム可能プロセッサ、コンピュータ、又は複数のコンピュータなどのデータ処理装置により実行するため、若しくはその動作を制御するための、たとえば機械可読ストレージデバイスなどの情報担体において実体的に具現されるコンピュータプログラムとして、実施されてもよい。上記で説明される(1つ以上の)コンピュータプログラムのような、コンピュータプログラムは、コンパイル済み又は解釈済みの言語を含む任意の形態のプログラミング言語で記述されてもよく、スタンドアロンのプログラムとして、又はモジュール、コンポーネント、サブルーチン、若しくはコンピューティング環境において使用に適した他のユニットとしてなど、任意の形態で配置されてもよい。コンピュータプログラムは、1つのサイトにおける1つのコンピュータ上、又は複数サイトに分散されて通信ネットワークにより相互接続された複数コンピュータ上で実行されるように配置されてもよい。
方法ステップは、入力データを操作して出力を生成することにより機能を実行するようにコンピュータプログラムを実行している1つ以上のプログラム可能プロセッサによって実行されてもよい。方法ステップはまた、たとえばフィールドプログラマブルゲートアレイ(field programmable gate array)(FPGA) 又は特殊用途向け集積回路(application-specific integrated circuit)(ASIC)などの特殊用途論理回路によって実行されてもよく、装置は特殊用途論理回路として実施されてもよい。
コンピュータプログラムの実行に適したプロセッサは、一例として、汎用及び特殊用途マイクロプロセッサ、及び任意の種類のデジタルコンピュータの1つ以上のプロセッサを含む。一般に、プロセッサは、読み取り専用メモリ又はランダムアクセスメモリ、若しくはその両方から命令及びデータを受信する。コンピュータの要素は、命令を実行するための少なくとも1つのプロセッサと、命令及びデータを格納するための1つ以上のメモリデバイスを含むことができる。一般に、コンピュータはまた、たとえば磁気、光磁気ディスク、又は光ディスクなど、データを格納するための1つ以上の大容量ストレージデバイスを含むことができるか、又は大容量ストレージデバイスとの間でデータを受信又は転送若しくはその両方を行うように機能的に結合されてもよい。コンピュータプログラム命令及びデータを具現するために適した情報担体は、一例として、たとえばEPROM、EEPROM、及びフラッシュメモリデバイスのような半導体メモリデバイス;たとえば内蔵ハードディスク又はリムーバブルディスクのような磁気ディスク;光磁気ディスク;並びにCD-ROM及びDVD-ROMディスクを含む、あらゆる形態の不揮発性メモリを含む。プロセッサ及びメモリは、特殊用途論理回路によって補完されてもよいか、又は特殊用途論理回路に組み込まれてもよい。
ユーザとの対話に備えるため、実施態様は、情報をユーザに表示するための、たとえばブラウン管(CRT)又は液晶ディスプレイ(LCD)モニタのような表示デバイス、並びにキーボード及び、たとえばマウス又はトラックボールのような、ユーザがコンピュータに入力を行うことができるポインティングデバイスを有するコンピュータで実施されてもよい。その他の種類のデバイスも、ユーザとの対話を行うために使用されてもよく;たとえば、ユーザに提供されるフィードバックは、たとえば視覚フィードバック、聴覚フィードバック、又は触覚フィードバックのような任意の形態の知覚的フィードバックであってもよく;ユーザからの入力は、音響、発語、又は触覚入力を含む任意の形態で受信されてもよい。
実施態様は、たとえばデータサーバのようなバックエンドコンポーネントを含むか、又はたとえばアプリケーションサーバのようなミドルウェアコンポーネントを含むか、又はたとえばユーザが実施態様と対話することができるグラフィカルユーザインターフェイス又はWebブラウザを有するクライアントコンピュータのようなフロントエンドコンポーネントを含むか、若しくはそのようなバックエンド、ミドルウェア、又はフロントエンドコンポーネントの任意の組み合わせを含むコンピューティングシステムにおいて実施されてもよい。コンポーネントは、たとえば通信ネットワークのようなデジタルデータ通信の任意の形態又は媒体によって相互接続されてもよい。通信ネットワークの例は、ローカルエリアネットワーク(LAN)、及びたとえばインターネットのようなワイドエリアネットワーク(WAN)を含む。
説明された実施態様の特定の特徴が本明細書において説明されるように示されたが、当業者には多数の修正、代替、変更、及び等価が考案されよう。したがって、添付の特許請求の範囲は、すべてのそのような修正及び変更を、実施態様の範囲内に含まれるものとして扱うことが意図されていることを理解されたい。

Claims (26)

  1. 複数のメモリチップ(118a、118b)と、
    該メモリチップ(118a、118b)に機能的に結合されるコントローラ(110)とを備え、該コントローラ(110)が、
    ホスト(106)からコマンドの複数のグループを受信するインターフェイス(108)であって、コマンドの各々のグループはグループ番号を割り当てられており、特定のグループの各コマンドが該特定のグループの一部として該コマンドを識別するための同じグループ番号を含むインターフェイス(108)と、
    該メモリチップ(118a、118b)を使用して該コマンドの該複数のグループを処理するコマンドプロセッサ(122)と、
    コマンドの該複数のグループの各々が処理を完了すると、該複数のグループの各々に対して単一割り込みを生成して該ホスト(106)に送信する割り込みプロセッサ(124)
    有し、
    該コマンドプロセッサ(122)は、該メモリチップ(118a、118b)内の同じストレージ位置に指定されているコマンドを順序正しくディスパッチし、かつ、異なるストレージ位置に指定されているコマンドを再配列して順不同にディスパッチするように構成される、データストレージデバイス(100)。
  2. 各々の前記コマンドがコマンドヘッダ(314)を含み、該コマンドヘッダ(314)が前記グループ番号を含む、請求項1記載のデータストレージデバイス(100)。
  3. 前記コマンドの前記グループ内の最後のコマンドが、前記コントローラ(110)に該最後のコマンドを指示するためのフラグをコマンドヘッダ(314)に含む、請求項1又は2項記載のデータストレージデバイス(100)。
  4. 前記グループ番号が、前記グループ内の次のコマンドを指し示すために該コマンドのポインタを使用することなく、各々の該コマンドを該グループの一部として識別する、請求項1から3のいずれか1項記載のデータストレージデバイス(100)。
  5. 前記割り込みプロセッサ(124)が、前記コマンドが該コントローラ(110)によって処理されるときに該コマンドの前記グループを追跡し、該コマンドの該グループが処理を完了すると、前記単一割り込みを生成して前記ホスト(106)に送信するように配置されることで構成される、請求項1から4のいずれか1項記載のデータストレージデバイス(100)。
  6. 前記割り込みプロセッサ(124)が、複数のカウンタを備え、各々の該カウンタは前記コントローラ(110)によって受信されるコマンドの異なるグループに割り当てられる、請求項5記載のデータストレージデバイス(100)。
  7. 前記割り込みプロセッサ(124)が複数の異なる割り込み機構を備える、請求項5又は6記載のデータストレージデバイス(100)。
  8. 2つ以上の割り込み機構が同時に有効化される、請求項7記載のデータストレージデバイス(100)。
  9. 前記割り込み機構が、電子透かし割り込み機構、タイムアウト割り込み機構、及びグループ割り込み機構を含む、請求項7又は8記載のデータストレージデバイス(100)。
  10. 前記メモリチップ(118a、118b)がフラッシュメモリチップであり、前記コントローラ(110)がフィールドプログラマブルゲートアレイ(field programmable gate array)(FPGA)コントローラである、請求項1から9のいずれか1項記載のデータストレージデバイス(100)。
  11. メモリボードであって、その上で前記フラッシュメモリチップが複数のチャネルへと配置されることで構成され、各々の該チャネルが1つ以上の該フラッシュメモリチップに関連付けられている、前記メモリボードと、
    該メモリボードに機能的に接続されるコントローラボード(102)とをさらに備え、該コントローラボード(102)が、
    高速インターフェイス(108)と、
    該高速インターフェイス(108)を使用して前記ホスト(106)から前記コマンドを受信するように配置されることで構成されるコントローラ(110)とを備える、請求項10記載のデータストレージデバイス(100)。
  12. 複数のメモリチップ(118a、118b)を有するデータストレージデバイス(100)でコマンドのグループを処理するための方法であって、
    ホスト(106)からコマンドの複数のグループを受信すること(710)であって、コマンドの各々のグループはグループ番号を割り当てられており、特定のグループの各コマンドが該特定のグループの一部として該コマンドを識別するための同じグループ番号を含むことと、
    該メモリチップ(118a、118b)を使用して該コマンドの該複数のグループを処理すること(720)と、
    該コマンドの該複数のグループの各々が処理を完了すると、該複数のグループの各々に対して単一割り込みを生成して(730)該ホスト(106)に送信することと
    該メモリチップ(118a、118b)内の同じストレージ位置に指定されているコマンドを順序正しくディスパッチし、かつ、異なるストレージ位置に指定されているコマンドを再配列して順不同にディスパッチすることと
    を含む、前記方法。
  13. コントローラ(110)においてコマンドを追跡するための装置であって、
    複数のグループカウンタ(284)であって、各々の該グループカウンタが、コントローラ(110)によりグループ内のコマンドが処理を開始するとインクリメントし、該グループ内のコマンドが処理を終了するとデクリメントすることによって、該コントローラ(110)により処理されているコマンドの該グループを追跡するように構成される、前記グループカウンタと、
    該グループカウンタ(284)に機能的に結合され、該グループ内のすべての該コマンドが処理を完了すると、各々の該グループカウンタの単一割り込みを生成して送信するように配置されることで構成される割り込み送信論理(286)とを備え、
    該コントローラは同じストレージ位置に指定されているコマンドを順序正しくディスパッチし、かつ、異なるストレージ位置に指定されているコマンドを再配列して順不同にディスパッチすることが可能である、前記装置。
  14. 同じグループ内の各々の前記コマンドが、同じグループ番号によって識別される、請求項13記載の装置。
  15. 前記複数のグループカウンタ(284)が、該グループカウンタによって追跡されているコマンドが処理を開始すると、該グループカウンタの1つをインクリメントする信号を受信するように構成される、請求項13又は14記載の装置。
  16. 前記複数のグループカウンタ(284)が、該グループカウンタによって追跡されているコマンドが処理を完了すると、該グループカウンタの1つをデクリメントする信号を受信するように構成される、請求項13から15のいずれか1項記載の装置。
  17. 前記割り込み送信論理(286)が、グループ内の最後のコマンドが処理を開始して、最終コマンドに関連付けられている前記グループカウンタがゼロにデクリメントされると、前記単一割り込みを生成して送信するように構成される、請求項13から16のいずれか1項記載の装置。
  18. コントローラ(110)においてコマンドを追跡するための方法であって、
    コマンドのグループ内のコマンドが処理を開始すると、グループカウンタをインクリメントすること(810)と、
    コマンドの該グループ内のコマンドが処理を完了すると、該グループカウンタをデクリメントすること(820)と、
    該グループ内のすべての該コマンドが処理を完了すると、コマンドの該グループの単一割り込みを生成して(830)送信することと,
    同じストレージ位置に指定されているコマンドを順序正しくディスパッチし、かつ、異なるストレージ位置に指定されているコマンドを再配列して順不同にディスパッチすること
    を備える、前記方法。
  19. 前記単一割り込みを生成して送信することが、前記グループ内の最後のコマンドが処理を開始し、前記グループカウンタがゼロにデクリメントされると、前記単一割り込みを生成して送信することを備える、請求項18記載の方法。
  20. 複数のメモリチップ(118a、118b)と、ホスト(106)と該複数のメモリチップ(118a、118b)間のデータの通信のための複数の物理チャネルとを含むデータストレージデバイス(100)であって、各チャネルが異なる複数の該メモリチップ(118a、118b)に機能的に接続される、前記データストレージデバイス(100)と、
    インターフェイス(108)を使用して該データストレージデバイス(100)に機能的に結合されたホスト(106)であって、
    複数の該メモリチップ(118a、118b)を使用して該データストレージデバイス(100)により処理するためにコマンドを該データストレージデバイス(100)に送信し、
    該コマンドを1つ以上の異なるグループにグループ化して、該グループ内の各々の該コマンドにグループ番号を割り当て、
    グループ内の最後のコマンドにマークを付けるように構成されるドライバを備える、前記ホスト(106)とを備え、
    該データストレージデバイスは同じストレージ位置に指定されているコマンドを順序正しくディスパッチし、かつ、異なるストレージ位置に指定されているコマンドを再配列して順不同にディスパッチすることが可能である、システム。
  21. 前記データストレージデバイス(100)が、前記グループ内の前記コマンドを処理した後、単一割り込みを生成して前記ホスト(106)に送信するように構成される、請求項20記載のシステム。
  22. 前記複数のメモリチップ(118a、118b)がフラッシュメモリチップを備える、請求項20又は21記載のシステム。
  23. 前記ドライバが、グループ番号の使用を追跡するように構成される、請求項20から22のいずれか1項記載のシステム。
  24. 前記データストレージデバイス(100)が、前記複数のメモリチップ(118a、118b)を使用して不連続の順序で前記コマンドのグループを処理するように構成される、請求項20から23のいずれか1項記載のシステム。
  25. 前記ホスト(106)が、前記データストレージデバイス(100)で1つ以上の割り込み機構を有効化するように構成される、請求項20から24のいずれか1項記載のシステム。
  26. 前記割り込み機構が、電子透かし割り込み機構、タイムアウト割り込み機構、及びグループ割り込み機構を含む、請求項25記載のシステム。
JP2012504717A 2009-04-08 2010-04-01 データストレージデバイスのコマンド及び割り込みのグループ化 Active JP5657641B2 (ja)

Applications Claiming Priority (7)

Application Number Priority Date Filing Date Title
US16770909P 2009-04-08 2009-04-08
US61/167,709 2009-04-08
US18783509P 2009-06-17 2009-06-17
US61/187,835 2009-06-17
US12/537,727 US8250271B2 (en) 2009-04-08 2009-08-07 Command and interrupt grouping for a data storage device
US12/537,727 2009-08-07
PCT/US2010/029679 WO2010117878A1 (en) 2009-04-08 2010-04-01 Command and interrupt grouping for a data storage device

Publications (2)

Publication Number Publication Date
JP2012523619A JP2012523619A (ja) 2012-10-04
JP5657641B2 true JP5657641B2 (ja) 2015-01-21

Family

ID=42935237

Family Applications (6)

Application Number Title Priority Date Filing Date
JP2012504717A Active JP5657641B2 (ja) 2009-04-08 2010-04-01 データストレージデバイスのコマンド及び割り込みのグループ化
JP2012504716A Active JP5922016B2 (ja) 2009-04-08 2010-04-01 データストレージデバイス
JP2012504740A Pending JP2012523622A (ja) 2009-04-08 2010-04-05 フラッシュメモリデータストレージデバイスにおけるデータストライピング
JP2012504741A Pending JP2012523623A (ja) 2009-04-08 2010-04-05 フラッシュメモリデータストレージデバイスのパーティション化
JP2012504742A Active JP5347061B2 (ja) 2009-04-08 2010-04-05 フラッシュメモリデータストレージデバイスにデータを格納するための方法及び装置
JP2014208104A Pending JP2015046175A (ja) 2009-04-08 2014-10-09 データストレージデバイス

Family Applications After (5)

Application Number Title Priority Date Filing Date
JP2012504716A Active JP5922016B2 (ja) 2009-04-08 2010-04-01 データストレージデバイス
JP2012504740A Pending JP2012523622A (ja) 2009-04-08 2010-04-05 フラッシュメモリデータストレージデバイスにおけるデータストライピング
JP2012504741A Pending JP2012523623A (ja) 2009-04-08 2010-04-05 フラッシュメモリデータストレージデバイスのパーティション化
JP2012504742A Active JP5347061B2 (ja) 2009-04-08 2010-04-05 フラッシュメモリデータストレージデバイスにデータを格納するための方法及び装置
JP2014208104A Pending JP2015046175A (ja) 2009-04-08 2014-10-09 データストレージデバイス

Country Status (7)

Country Link
US (13) US8566508B2 (ja)
EP (6) EP2728488B1 (ja)
JP (6) JP5657641B2 (ja)
CN (6) CN102428451B (ja)
AU (5) AU2010234772B2 (ja)
DE (6) DE202010017668U1 (ja)
WO (5) WO2010117878A1 (ja)

Families Citing this family (327)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2008070813A2 (en) 2006-12-06 2008-06-12 Fusion Multisystems, Inc. (Dba Fusion-Io) Apparatus, system, and method for a front-end, distributed raid
US8935302B2 (en) 2006-12-06 2015-01-13 Intelligent Intellectual Property Holdings 2 Llc Apparatus, system, and method for data block usage information synchronization for a non-volatile storage volume
US8489817B2 (en) 2007-12-06 2013-07-16 Fusion-Io, Inc. Apparatus, system, and method for caching data
US7975109B2 (en) 2007-05-30 2011-07-05 Schooner Information Technology, Inc. System including a fine-grained memory and a less-fine-grained memory
US9519540B2 (en) 2007-12-06 2016-12-13 Sandisk Technologies Llc Apparatus, system, and method for destaging cached data
US7836226B2 (en) 2007-12-06 2010-11-16 Fusion-Io, Inc. Apparatus, system, and method for coordinating storage requests in a multi-processor/multi-thread environment
US8732386B2 (en) * 2008-03-20 2014-05-20 Sandisk Enterprise IP LLC. Sharing data fabric for coherent-distributed caching of multi-node shared-distributed flash memory
US8229945B2 (en) 2008-03-20 2012-07-24 Schooner Information Technology, Inc. Scalable database management software on a cluster of nodes using a shared-distributed flash memory
JP2010015195A (ja) * 2008-06-30 2010-01-21 Toshiba Corp 記憶制御装置及び記憶制御方法
WO2010005430A1 (en) * 2008-07-08 2010-01-14 Hewlett-Packard Development Company, L.P. Adaptable external drive
TWI385672B (zh) * 2008-11-05 2013-02-11 Lite On It Corp 儲存裝置之適應性多通道控制器及其方法
TWI385517B (zh) * 2008-12-05 2013-02-11 Apacer Technology Inc Storage device and data management method
US20100287217A1 (en) * 2009-04-08 2010-11-11 Google Inc. Host control of background garbage collection in a data storage device
US8566508B2 (en) 2009-04-08 2013-10-22 Google Inc. RAID configuration in a flash memory data storage device
US8447918B2 (en) 2009-04-08 2013-05-21 Google Inc. Garbage collection for failure prediction and repartitioning
KR101516580B1 (ko) * 2009-04-22 2015-05-11 삼성전자주식회사 컨트롤러, 이를 포함하는 데이터 저장 장치 및 데이터 저장 시스템, 및 그 방법
EP2254280A1 (en) 2009-05-19 2010-11-24 Electrolux Home Products Corporation N.V. Bus control for a domestic appliance
WO2011031796A2 (en) 2009-09-08 2011-03-17 Fusion-Io, Inc. Apparatus, system, and method for caching data on a solid-state storage device
EP2476079A4 (en) 2009-09-09 2013-07-03 Fusion Io Inc APPARATUS, SYSTEM, AND METHOD FOR STORAGE ALLOCATION
US8601222B2 (en) 2010-05-13 2013-12-03 Fusion-Io, Inc. Apparatus, system, and method for conditional and atomic storage operations
US9122579B2 (en) 2010-01-06 2015-09-01 Intelligent Intellectual Property Holdings 2 Llc Apparatus, system, and method for a storage layer
US9223514B2 (en) 2009-09-09 2015-12-29 SanDisk Technologies, Inc. Erase suspend/resume for memory
US9021158B2 (en) 2009-09-09 2015-04-28 SanDisk Technologies, Inc. Program suspend/resume for memory
US8289801B2 (en) * 2009-09-09 2012-10-16 Fusion-Io, Inc. Apparatus, system, and method for power reduction management in a storage device
TWI454906B (zh) * 2009-09-24 2014-10-01 Phison Electronics Corp 資料讀取方法、快閃記憶體控制器與儲存系統
US8244946B2 (en) 2009-10-16 2012-08-14 Brocade Communications Systems, Inc. Interrupt moderation
US8307151B1 (en) 2009-11-30 2012-11-06 Micron Technology, Inc. Multi-partitioning feature on e-MMC
US8285946B2 (en) * 2009-12-15 2012-10-09 International Business Machines Corporation Reducing access contention in flash-based memory systems
KR101008923B1 (ko) * 2010-01-15 2011-01-17 주식회사 노바칩스 다양한 종류의 반도체 메모리 장치들을 구비하는 반도체 메모리 시스템 및 이의 제어 방법
US8819208B2 (en) 2010-03-05 2014-08-26 Solidfire, Inc. Data deletion in a distributed data storage system
US8725931B1 (en) 2010-03-26 2014-05-13 Western Digital Technologies, Inc. System and method for managing the execution of memory commands in a solid-state memory
US10210162B1 (en) * 2010-03-29 2019-02-19 Carbonite, Inc. Log file management
US8856593B2 (en) 2010-04-12 2014-10-07 Sandisk Enterprise Ip Llc Failure recovery using consensus replication in a distributed flash memory system
US9047351B2 (en) 2010-04-12 2015-06-02 Sandisk Enterprise Ip Llc Cluster of processing nodes with distributed global flash memory using commodity server technology
US8868487B2 (en) 2010-04-12 2014-10-21 Sandisk Enterprise Ip Llc Event processing in a flash memory-based object store
US8725951B2 (en) 2010-04-12 2014-05-13 Sandisk Enterprise Ip Llc Efficient flash memory-based object store
US9164554B2 (en) * 2010-04-12 2015-10-20 Sandisk Enterprise Ip Llc Non-volatile solid-state storage system supporting high bandwidth and random access
US20110252263A1 (en) * 2010-04-13 2011-10-13 Byungcheol Cho Semiconductor storage device
US8782327B1 (en) 2010-05-11 2014-07-15 Western Digital Technologies, Inc. System and method for managing execution of internal commands and host commands in a solid-state memory
US9026716B2 (en) 2010-05-12 2015-05-05 Western Digital Technologies, Inc. System and method for managing garbage collection in solid-state memory
US8954385B2 (en) 2010-06-28 2015-02-10 Sandisk Enterprise Ip Llc Efficient recovery of transactional data stores
WO2012016089A2 (en) 2010-07-28 2012-02-02 Fusion-Io, Inc. Apparatus, system, and method for conditional and atomic storage operations
US8725934B2 (en) 2011-12-22 2014-05-13 Fusion-Io, Inc. Methods and appratuses for atomic storage operations
US8677028B2 (en) * 2010-08-23 2014-03-18 Qualcomm Incorporated Interrupt-based command processing
US8417877B2 (en) 2010-08-31 2013-04-09 Micron Technology, Inc Stripe-based non-volatile multilevel memory operation
US8984216B2 (en) 2010-09-09 2015-03-17 Fusion-Io, Llc Apparatus, system, and method for managing lifetime of a storage device
US9021192B1 (en) 2010-09-21 2015-04-28 Western Digital Technologies, Inc. System and method for enhancing processing of memory access requests
US9164886B1 (en) 2010-09-21 2015-10-20 Western Digital Technologies, Inc. System and method for multistage processing in a memory storage subsystem
US20120117305A1 (en) * 2010-11-08 2012-05-10 Greenliant Llc Method Of Storing Blocks Of Data In A Plurality Of Memory Devices For High Speed Sequential Read, A Memory Controller And A Memory System
US9003153B2 (en) 2010-11-08 2015-04-07 Greenliant Llc Method of storing blocks of data in a plurality of memory devices in a redundant manner, a memory controller and a memory system
JP5720204B2 (ja) * 2010-11-26 2015-05-20 富士通株式会社 アクセス制御プログラム、アクセス制御方法および情報処理装置
WO2012073071A1 (en) * 2010-12-02 2012-06-07 Freescale Semiconductor, Inc. Error correcting device, method for monitoring an error correcting device and data processing system
US10817421B2 (en) 2010-12-13 2020-10-27 Sandisk Technologies Llc Persistent data structures
CN103262054B (zh) 2010-12-13 2015-11-25 桑迪士克科技股份有限公司 用于自动提交存储器的装置、***和方法
US10817502B2 (en) 2010-12-13 2020-10-27 Sandisk Technologies Llc Persistent memory management
US9208071B2 (en) 2010-12-13 2015-12-08 SanDisk Technologies, Inc. Apparatus, system, and method for accessing memory
US9047178B2 (en) 2010-12-13 2015-06-02 SanDisk Technologies, Inc. Auto-commit memory synchronization
US8601313B1 (en) 2010-12-13 2013-12-03 Western Digital Technologies, Inc. System and method for a data reliability scheme in a solid state memory
US9218278B2 (en) 2010-12-13 2015-12-22 SanDisk Technologies, Inc. Auto-commit memory
US8601311B2 (en) 2010-12-14 2013-12-03 Western Digital Technologies, Inc. System and method for using over-provisioned data capacity to maintain a data redundancy scheme in a solid state memory
US8615681B2 (en) 2010-12-14 2013-12-24 Western Digital Technologies, Inc. System and method for maintaining a data redundancy scheme in a solid state memory in the event of a power loss
US20120239860A1 (en) 2010-12-17 2012-09-20 Fusion-Io, Inc. Apparatus, system, and method for persistent data management on a non-volatile storage media
US8473708B1 (en) * 2010-12-23 2013-06-25 Netapp, Inc. Method and system for managing storage units
US8694733B2 (en) 2011-01-03 2014-04-08 Sandisk Enterprise Ip Llc Slave consistency in a synchronous replication environment
WO2012109677A2 (en) 2011-02-11 2012-08-16 Fusion-Io, Inc. Apparatus, system, and method for managing operations for data storage media
US8700950B1 (en) 2011-02-11 2014-04-15 Western Digital Technologies, Inc. System and method for data error recovery in a solid state subsystem
US9003104B2 (en) 2011-02-15 2015-04-07 Intelligent Intellectual Property Holdings 2 Llc Systems and methods for a file-level cache
US9201677B2 (en) 2011-05-23 2015-12-01 Intelligent Intellectual Property Holdings 2 Llc Managing data input/output operations
US8874823B2 (en) 2011-02-15 2014-10-28 Intellectual Property Holdings 2 Llc Systems and methods for managing data input/output operations
WO2012116369A2 (en) 2011-02-25 2012-08-30 Fusion-Io, Inc. Apparatus, system, and method for managing contents of a cache
US8700951B1 (en) * 2011-03-09 2014-04-15 Western Digital Technologies, Inc. System and method for improving a data redundancy scheme in a solid state subsystem with additional metadata
US8966191B2 (en) 2011-03-18 2015-02-24 Fusion-Io, Inc. Logical interface for contextual storage
US9563555B2 (en) 2011-03-18 2017-02-07 Sandisk Technologies Llc Systems and methods for storage allocation
US8601085B1 (en) * 2011-03-28 2013-12-03 Emc Corporation Techniques for preferred path determination
US8924627B2 (en) * 2011-03-28 2014-12-30 Western Digital Technologies, Inc. Flash memory device comprising host interface for processing a multi-command descriptor block in order to exploit concurrency
US8874515B2 (en) 2011-04-11 2014-10-28 Sandisk Enterprise Ip Llc Low level object version tracking using non-volatile memory write generations
US8694857B2 (en) * 2011-04-13 2014-04-08 Inphi Corporation Systems and methods for error detection and correction in a memory module which includes a memory buffer
US8954670B1 (en) * 2011-04-18 2015-02-10 American Megatrends, Inc. Systems and methods for improved fault tolerance in RAID configurations
US9817700B2 (en) * 2011-04-26 2017-11-14 International Business Machines Corporation Dynamic data partitioning for optimal resource utilization in a parallel data processing system
US9396106B2 (en) * 2011-05-12 2016-07-19 Avago Technologies General Ip (Singapore) Pte. Ltd. Advanced management of a non-volatile memory
US9417894B1 (en) 2011-06-15 2016-08-16 Ryft Systems, Inc. Methods and apparatus for a tablet computer system incorporating a reprogrammable circuit module
US20120324143A1 (en) * 2011-06-15 2012-12-20 Data Design Corporation Methods and apparatus for data access by a reprogrammable circuit module
US10966339B1 (en) 2011-06-28 2021-03-30 Amazon Technologies, Inc. Storage system with removable solid state storage devices mounted on carrier circuit boards
US20130019052A1 (en) * 2011-07-14 2013-01-17 Vinay Ashok Somanache Effective utilization of flash interface
US8806112B2 (en) 2011-07-14 2014-08-12 Lsi Corporation Meta data handling within a flash media controller
US8868867B2 (en) * 2011-09-15 2014-10-21 The Regents Of The University Of California Method for reducing latency of accessing data stored in a file system on a computer storage device by caching file system permission information in the computer storage device
US8966172B2 (en) 2011-11-15 2015-02-24 Pavilion Data Systems, Inc. Processor agnostic data storage in a PCIE based shared storage enviroment
US8842122B2 (en) * 2011-12-15 2014-09-23 Qualcomm Incorporated Graphics processing unit with command processor
US8719647B2 (en) * 2011-12-15 2014-05-06 Micron Technology, Inc. Read bias management to reduce read errors for phase change memory
CN102521160B (zh) * 2011-12-22 2015-04-01 上海交通大学 写缓冲检测器、并行通道写入方法
US9274937B2 (en) 2011-12-22 2016-03-01 Longitude Enterprise Flash S.A.R.L. Systems, methods, and interfaces for vector input/output operations
US8904091B1 (en) * 2011-12-22 2014-12-02 Western Digital Technologies, Inc. High performance media transport manager architecture for data storage systems
CN102567257B (zh) * 2011-12-26 2014-08-27 华中科技大学 一种控制多通道固态盘数据读写的方法
US9054992B2 (en) 2011-12-27 2015-06-09 Solidfire, Inc. Quality of service policy sets
US9838269B2 (en) 2011-12-27 2017-12-05 Netapp, Inc. Proportional quality of service based on client usage and system metrics
US9251086B2 (en) 2012-01-24 2016-02-02 SanDisk Technologies, Inc. Apparatus, system, and method for managing a cache
US10359972B2 (en) 2012-08-31 2019-07-23 Sandisk Technologies Llc Systems, methods, and interfaces for adaptive persistence
US9116812B2 (en) 2012-01-27 2015-08-25 Intelligent Intellectual Property Holdings 2 Llc Systems and methods for a de-duplication cache
US9652182B2 (en) 2012-01-31 2017-05-16 Pavilion Data Systems, Inc. Shareable virtual non-volatile storage device for a server
US9378150B2 (en) * 2012-02-28 2016-06-28 Apple Inc. Memory management unit with prefetch ability
US9135064B2 (en) 2012-03-07 2015-09-15 Sandisk Enterprise Ip Llc Fine grained adaptive throttling of background processes
US9135192B2 (en) 2012-03-30 2015-09-15 Sandisk Technologies Inc. Memory system with command queue reordering
KR20130114354A (ko) 2012-04-09 2013-10-18 삼성전자주식회사 메모리 시스템 및 컨트롤러의 동작 방법
US20130339583A1 (en) * 2012-06-19 2013-12-19 Marvell World Trade Ltd. Systems and methods for transferring data out of order in next generation solid state drive controllers
US9612966B2 (en) 2012-07-03 2017-04-04 Sandisk Technologies Llc Systems, methods and apparatus for a virtual machine cache
US10339056B2 (en) 2012-07-03 2019-07-02 Sandisk Technologies Llc Systems, methods and apparatus for cache transfers
US9389999B2 (en) * 2012-08-17 2016-07-12 Infineon Technologies Ag System and method for emulating an EEPROM in a non-volatile memory device
US9122401B2 (en) * 2012-08-23 2015-09-01 Apple Inc. Efficient enforcement of command execution order in solid state drives
KR20140027859A (ko) 2012-08-27 2014-03-07 삼성전자주식회사 호스트 장치 및 이를 포함하는 시스템
US9009566B2 (en) * 2012-09-12 2015-04-14 Macronix International Co., Ltd. Outputting information of ECC corrected bits
US9471484B2 (en) 2012-09-19 2016-10-18 Novachips Canada Inc. Flash memory controller having dual mode pin-out
US10509776B2 (en) 2012-09-24 2019-12-17 Sandisk Technologies Llc Time sequence data management
US10318495B2 (en) 2012-09-24 2019-06-11 Sandisk Technologies Llc Snapshots for a non-volatile device
US9323499B2 (en) 2012-11-15 2016-04-26 Elwha Llc Random number generator functions in memory
US8925098B2 (en) 2012-11-15 2014-12-30 Elwha Llc Data security and access tracking in memory
US9026719B2 (en) 2012-11-15 2015-05-05 Elwha, Llc Intelligent monitoring for computation in memory
US9442854B2 (en) 2012-11-15 2016-09-13 Elwha Llc Memory circuitry including computational circuitry for performing supplemental functions
US8996951B2 (en) 2012-11-15 2015-03-31 Elwha, Llc Error correction with non-volatile memory on an integrated circuit
US9582465B2 (en) * 2012-11-15 2017-02-28 Elwha Llc Flexible processors and flexible memory
US8966310B2 (en) 2012-11-15 2015-02-24 Elwha Llc Redundancy for loss-tolerant data in non-volatile memory
CN103853629A (zh) * 2012-11-29 2014-06-11 艺伦半导体技术股份有限公司 数据流存储方法及现场可编程门阵列
US9448883B1 (en) * 2012-12-04 2016-09-20 Cadence Design Systems, Inc. System and method for allocating data in memory array having regions of varying storage reliability
US9069658B2 (en) 2012-12-10 2015-06-30 Google Inc. Using a virtual to physical map for direct user space communication with a data storage device
US9164888B2 (en) 2012-12-10 2015-10-20 Google Inc. Using a logical to physical map for direct user space communication with a data storage device
US9236136B2 (en) * 2012-12-14 2016-01-12 Intel Corporation Lower page read for multi-level cell memory
US9842660B1 (en) 2012-12-28 2017-12-12 Virident Systems, Llc System and method to improve enterprise reliability through tracking I/O performance metrics in non-volatile random access memory
US9286002B1 (en) 2012-12-28 2016-03-15 Virident Systems Inc. Dynamic restriping in nonvolatile memory systems
US9781664B2 (en) 2012-12-31 2017-10-03 Elwha Llc Cost-effective mobile connectivity protocols
US9713013B2 (en) 2013-03-15 2017-07-18 Elwha Llc Protocols for providing wireless communications connectivity maps
US9876762B2 (en) 2012-12-31 2018-01-23 Elwha Llc Cost-effective mobile connectivity protocols
US9451394B2 (en) 2012-12-31 2016-09-20 Elwha Llc Cost-effective mobile connectivity protocols
US9980114B2 (en) 2013-03-15 2018-05-22 Elwha Llc Systems and methods for communication management
US8965288B2 (en) 2012-12-31 2015-02-24 Elwha Llc Cost-effective mobile connectivity protocols
US9832628B2 (en) 2012-12-31 2017-11-28 Elwha, Llc Cost-effective mobile connectivity protocols
US9635605B2 (en) 2013-03-15 2017-04-25 Elwha Llc Protocols for facilitating broader access in wireless communications
CN103942219A (zh) * 2013-01-22 2014-07-23 鸿富锦精密工业(深圳)有限公司 存储卡分区***及方法
US11249652B1 (en) 2013-01-28 2022-02-15 Radian Memory Systems, Inc. Maintenance of nonvolatile memory on host selected namespaces by a common memory controller
US10445229B1 (en) 2013-01-28 2019-10-15 Radian Memory Systems, Inc. Memory controller with at least one address segment defined for which data is striped across flash memory dies, with a common address offset being used to obtain physical addresses for the data in each of the dies
US9652376B2 (en) 2013-01-28 2017-05-16 Radian Memory Systems, Inc. Cooperative flash memory control
US10642505B1 (en) 2013-01-28 2020-05-05 Radian Memory Systems, Inc. Techniques for data migration based on per-data metrics and memory degradation
US9110592B2 (en) * 2013-02-04 2015-08-18 Microsoft Technology Licensing, Llc Dynamic allocation of heterogenous memory in a computing system
US8949537B2 (en) 2013-02-25 2015-02-03 Hitachi, Ltd. Storage control apparatus and method for detecting write completion of data
US10073626B2 (en) 2013-03-15 2018-09-11 Virident Systems, Llc Managing the write performance of an asymmetric memory system
US9706382B2 (en) 2013-03-15 2017-07-11 Elwha Llc Protocols for allocating communication services cost in wireless communications
US9866706B2 (en) 2013-03-15 2018-01-09 Elwha Llc Protocols for facilitating broader access in wireless communications
US9781554B2 (en) 2013-03-15 2017-10-03 Elwha Llc Protocols for facilitating third party authorization for a rooted communication device in wireless communications
US9842053B2 (en) 2013-03-15 2017-12-12 Sandisk Technologies Llc Systems and methods for persistent cache logging
US9843917B2 (en) 2013-03-15 2017-12-12 Elwha, Llc Protocols for facilitating charge-authorized connectivity in wireless communications
US9693214B2 (en) 2013-03-15 2017-06-27 Elwha Llc Protocols for facilitating broader access in wireless communications
US9135164B2 (en) 2013-03-15 2015-09-15 Virident Systems Inc. Synchronous mirroring in non-volatile memory systems
US9813887B2 (en) 2013-03-15 2017-11-07 Elwha Llc Protocols for facilitating broader access in wireless communications responsive to charge authorization statuses
US9706060B2 (en) 2013-03-15 2017-07-11 Elwha Llc Protocols for facilitating broader access in wireless communications
US9596584B2 (en) 2013-03-15 2017-03-14 Elwha Llc Protocols for facilitating broader access in wireless communications by conditionally authorizing a charge to an account of a third party
US8996796B1 (en) 2013-03-15 2015-03-31 Virident Systems Inc. Small block write operations in non-volatile memory systems
US9807582B2 (en) 2013-03-15 2017-10-31 Elwha Llc Protocols for facilitating broader access in wireless communications
CN103226976A (zh) * 2013-03-19 2013-07-31 中国科学院声学研究所 一种基于FPGA实现多片Nandflash存储及读取的装置
CN104102599A (zh) * 2013-04-11 2014-10-15 华邦电子股份有限公司 快闪存储器装置与数据传输方法
US10102144B2 (en) 2013-04-16 2018-10-16 Sandisk Technologies Llc Systems, methods and interfaces for data virtualization
US10558561B2 (en) 2013-04-16 2020-02-11 Sandisk Technologies Llc Systems and methods for storage metadata management
US9842128B2 (en) 2013-08-01 2017-12-12 Sandisk Technologies Llc Systems and methods for atomic storage operations
US20150058529A1 (en) * 2013-08-21 2015-02-26 Sandisk Technologies Inc. Systems and methods of processing access requests at a data storage device
US9513869B2 (en) 2013-09-18 2016-12-06 HGST Netherlands B.V. Doorbell-less endpoint-initiated protocol for storage devices
TWI486775B (zh) * 2013-09-18 2015-06-01 Dexin Corp 輸入裝置及其資料傳輸方法
US9535870B2 (en) 2013-09-18 2017-01-03 HGST Netherlands B.V. Acknowledgement-less protocol for solid state drive interface
US9778859B2 (en) 2013-09-18 2017-10-03 Western Digital Technologies, Inc. Doorless protocol having multiple queue read requests in flight
US20160232103A1 (en) * 2013-09-26 2016-08-11 Mark A. Schmisseur Block storage apertures to persistent memory
US10019320B2 (en) 2013-10-18 2018-07-10 Sandisk Technologies Llc Systems and methods for distributed atomic storage operations
US10073630B2 (en) 2013-11-08 2018-09-11 Sandisk Technologies Llc Systems and methods for log coordination
CN103559156B (zh) * 2013-11-11 2016-04-06 北京大学 一种fpga与计算机之间的通信***
US9529710B1 (en) * 2013-12-06 2016-12-27 Western Digital Technologies, Inc. Interleaved channels in a solid-state drive
CN103744744B (zh) * 2014-02-08 2017-08-25 威盛电子股份有限公司 数据储存装置以及易失性存储器的数据校验方法
US20150244795A1 (en) 2014-02-21 2015-08-27 Solidfire, Inc. Data syncing in a distributed system
US9666244B2 (en) 2014-03-01 2017-05-30 Fusion-Io, Inc. Dividing a storage procedure
US9423979B2 (en) 2014-03-10 2016-08-23 Kabushiki Kaisha Toshiba Memory system and memory controller for determining whether one or plurality of pointers can be stored in a second buffer and for executing data transfer between data buffer and host using the pointers
US9337869B2 (en) * 2014-04-30 2016-05-10 Storart Technology Co. Ltd. Encoding and syndrome computing co-design circuit for BCH code and method for deciding the same
WO2015173853A1 (ja) * 2014-05-12 2015-11-19 株式会社日立製作所 情報処理装置、その処理方法、及び入出力装置
KR102211709B1 (ko) 2014-05-19 2021-02-02 삼성전자주식회사 신호 송수신 특성을 향상한 불휘발성 메모리 시스템, 호스트 장치, 불휘발성 메모리 시스템 및 호스트의 동작방법
US9460019B2 (en) 2014-06-26 2016-10-04 Intel Corporation Sending packets using optimized PIO write sequences without SFENCEs
US9477631B2 (en) * 2014-06-26 2016-10-25 Intel Corporation Optimized credit return mechanism for packet sends
JP2016014972A (ja) * 2014-07-01 2016-01-28 富士通株式会社 通信制御装置,ストレージ装置及び通信制御プログラム
US10146482B2 (en) 2014-08-01 2018-12-04 Toshiba Memory Corporation Global error recovery system
US9542118B1 (en) * 2014-09-09 2017-01-10 Radian Memory Systems, Inc. Expositive flash memory control
US10552085B1 (en) 2014-09-09 2020-02-04 Radian Memory Systems, Inc. Techniques for directed data migration
JP2016057876A (ja) * 2014-09-10 2016-04-21 富士通株式会社 情報処理装置、入出力制御プログラム、及び入出力制御方法
US9582201B2 (en) 2014-09-26 2017-02-28 Western Digital Technologies, Inc. Multi-tier scheme for logical storage management
TWI556254B (zh) * 2014-10-14 2016-11-01 慧榮科技股份有限公司 資料儲存裝置及其資料存取方法
US9632702B2 (en) 2014-10-15 2017-04-25 International Business Machines Corporation Efficient initialization of a thinly provisioned storage array
KR20160051367A (ko) * 2014-11-03 2016-05-11 에스케이하이닉스 주식회사 메모리 시스템 및 이의 동작 방법
US9712619B2 (en) 2014-11-04 2017-07-18 Pavilion Data Systems, Inc. Virtual non-volatile memory express drive
US9565269B2 (en) 2014-11-04 2017-02-07 Pavilion Data Systems, Inc. Non-volatile memory express over ethernet
KR101620260B1 (ko) * 2015-01-12 2016-05-12 엘지전자 주식회사 네트워크 시스템 및 그 제어방법
US9933950B2 (en) 2015-01-16 2018-04-03 Sandisk Technologies Llc Storage operation interrupt
CN109471812B (zh) * 2015-01-19 2023-09-05 铠侠股份有限公司 存储装置及非易失性存储器的控制方法
US10175885B2 (en) 2015-01-19 2019-01-08 Toshiba Memory Corporation Memory device managing data in accordance with command and non-transitory computer readable recording medium
WO2016122602A1 (en) * 2015-01-30 2016-08-04 Hewlett Packard Enterprise Development Lp Systems and methods for sharing non-volatile memory between multiple access models
US9946607B2 (en) 2015-03-04 2018-04-17 Sandisk Technologies Llc Systems and methods for storage error management
KR102364381B1 (ko) * 2015-03-06 2022-02-18 에스케이하이닉스 주식회사 메모리 시스템 및 그의 동작방법
KR102309798B1 (ko) * 2015-04-16 2021-10-06 삼성전자주식회사 Sr-iov 기반 비휘발성 메모리 컨트롤러 및 그 비휘발성 메모리 컨트롤러에 의해 큐에 리소스를 동적 할당하는 방법
CN104811235B (zh) * 2015-05-13 2018-07-06 朱洋 双架构的直升机远程通信域互动装置
JP6205386B2 (ja) * 2015-05-18 2017-09-27 長瀬産業株式会社 半導体装置及び情報書込/読出方法
US10169258B2 (en) 2015-06-09 2019-01-01 Rambus Inc. Memory system design using buffer(s) on a mother board
US9547441B1 (en) * 2015-06-23 2017-01-17 Pure Storage, Inc. Exposing a geometry of a storage device
US10552058B1 (en) 2015-07-17 2020-02-04 Radian Memory Systems, Inc. Techniques for delegating data processing to a cooperative memory controller
CN108292279A (zh) * 2015-08-24 2018-07-17 Src实验室有限责任公司 用包含与存储器模块或子***并置的数据维护块的dram存储控制器重新编程可重配置设备时,保留dram数据的***和方法
US9578054B1 (en) * 2015-08-31 2017-02-21 Newman H-R Computer Design, LLC Hacking-resistant computer design
US10073652B2 (en) * 2015-09-24 2018-09-11 International Business Machines Corporation Performance optimized storage vaults in a dispersed storage network
US9697320B2 (en) * 2015-09-24 2017-07-04 Qualcomm Incorporated Rectilinear macros having non-uniform channel spacing
US9977623B2 (en) 2015-10-15 2018-05-22 Sandisk Technologies Llc Detection of a sequential command stream
US10467155B2 (en) * 2015-10-26 2019-11-05 Micron Technology, Inc. Command packets for the direct control of non-volatile memory channels within a solid state drive
JP2017084063A (ja) * 2015-10-27 2017-05-18 Tdk株式会社 メモリコントローラ、フラッシュメモリシステム及び電源電圧供給制御方法
US9996262B1 (en) 2015-11-09 2018-06-12 Seagate Technology Llc Method and apparatus to abort a command
US10572180B1 (en) * 2015-11-09 2020-02-25 Seagate Technology Llc Method and apparatus to perform a function level reset in a memory controller
US10282103B1 (en) * 2015-11-09 2019-05-07 Seagate Technology Llc Method and apparatus to delete a command queue
US9792232B2 (en) 2015-11-16 2017-10-17 International Business Machines Corporation Techniques for queueing interrupts in a data processing system
US10210298B2 (en) 2015-11-24 2019-02-19 Altera Corporation Embedded memory blocks with adjustable memory boundaries
KR102446677B1 (ko) 2015-11-26 2022-09-23 삼성전자주식회사 스토리지 컨트롤러의 동작 방법 및 상기 스토리지 컨트롤러를 포함하는 데이터 저장 장치의 동작 방법
US10817528B2 (en) * 2015-12-15 2020-10-27 Futurewei Technologies, Inc. System and method for data warehouse engine
CN108475240A (zh) * 2016-01-13 2018-08-31 慧与发展有限责任合伙企业 重构的输入/输出请求
JP6544246B2 (ja) * 2016-01-15 2019-07-17 富士通株式会社 不揮発性ストレージおよび不揮発性ストレージの処理方法
US9946596B2 (en) 2016-01-29 2018-04-17 Toshiba Memory Corporation Global error recovery system
US9817586B2 (en) * 2016-02-23 2017-11-14 Samsung Electronics Co., Ltd. Method of application aware IO completion mode changer for key value device
US10198315B2 (en) 2016-02-29 2019-02-05 Sandisk Technologies Llc Non-volatile memory with corruption recovery
US10192633B2 (en) * 2016-03-01 2019-01-29 Intel Corporation Low cost inbuilt deterministic tester for SOC testing
TWI610171B (zh) * 2016-03-22 2018-01-01 群聯電子股份有限公司 記憶體管理方法、記憶體儲存裝置及記憶體控制電路單元
US10191358B2 (en) * 2016-04-13 2019-01-29 Angela Jorgensen Moving head projector system
US10929022B2 (en) 2016-04-25 2021-02-23 Netapp. Inc. Space savings reporting for storage system supporting snapshot and clones
TWI592864B (zh) * 2016-06-21 2017-07-21 慧榮科技股份有限公司 資料儲存裝置及其資料維護方法
US20180046409A1 (en) * 2016-08-10 2018-02-15 International Business Machines Corporation Mass storage devices packages and software-defined arrays of such packages
US10445018B2 (en) 2016-09-09 2019-10-15 Toshiba Memory Corporation Switch and memory device
US10642763B2 (en) 2016-09-20 2020-05-05 Netapp, Inc. Quality of service policy sets
US11615104B2 (en) 2016-09-26 2023-03-28 Splunk Inc. Subquery generation based on a data ingest estimate of an external data system
US11126632B2 (en) 2016-09-26 2021-09-21 Splunk Inc. Subquery generation based on search configuration data from an external data system
US11321321B2 (en) 2016-09-26 2022-05-03 Splunk Inc. Record expansion and reduction based on a processing task in a data intake and query system
US11442935B2 (en) 2016-09-26 2022-09-13 Splunk Inc. Determining a record generation estimate of a processing task
US11250056B1 (en) * 2016-09-26 2022-02-15 Splunk Inc. Updating a location marker of an ingestion buffer based on storing buckets in a shared storage system
US11874691B1 (en) 2016-09-26 2024-01-16 Splunk Inc. Managing efficient query execution including mapping of buckets to search nodes
US10353965B2 (en) 2016-09-26 2019-07-16 Splunk Inc. Data fabric service system architecture
US11599541B2 (en) 2016-09-26 2023-03-07 Splunk Inc. Determining records generated by a processing task of a query
US11269939B1 (en) 2016-09-26 2022-03-08 Splunk Inc. Iterative message-based data processing including streaming analytics
US11593377B2 (en) 2016-09-26 2023-02-28 Splunk Inc. Assigning processing tasks in a data intake and query system
US11586627B2 (en) 2016-09-26 2023-02-21 Splunk Inc. Partitioning and reducing records at ingest of a worker node
US11314753B2 (en) 2016-09-26 2022-04-26 Splunk Inc. Execution of a query received from a data intake and query system
US11023463B2 (en) 2016-09-26 2021-06-01 Splunk Inc. Converting and modifying a subquery for an external data system
US11106734B1 (en) 2016-09-26 2021-08-31 Splunk Inc. Query execution using containerized state-free search nodes in a containerized scalable environment
US10956415B2 (en) 2016-09-26 2021-03-23 Splunk Inc. Generating a subquery for an external data system using a configuration file
US11550847B1 (en) 2016-09-26 2023-01-10 Splunk Inc. Hashing bucket identifiers to identify search nodes for efficient query execution
US20180089324A1 (en) 2016-09-26 2018-03-29 Splunk Inc. Dynamic resource allocation for real-time search
US11580107B2 (en) 2016-09-26 2023-02-14 Splunk Inc. Bucket data distribution for exporting data to worker nodes
US11562023B1 (en) 2016-09-26 2023-01-24 Splunk Inc. Merging buckets in a data intake and query system
US11620336B1 (en) 2016-09-26 2023-04-04 Splunk Inc. Managing and storing buckets to a remote shared storage system based on a collective bucket size
US11281706B2 (en) 2016-09-26 2022-03-22 Splunk Inc. Multi-layer partition allocation for query execution
US11243963B2 (en) 2016-09-26 2022-02-08 Splunk Inc. Distributing partial results to worker nodes from an external data system
US11222066B1 (en) 2016-09-26 2022-01-11 Splunk Inc. Processing data using containerized state-free indexing nodes in a containerized scalable environment
US11294941B1 (en) 2016-09-26 2022-04-05 Splunk Inc. Message-based data ingestion to a data intake and query system
US11604795B2 (en) 2016-09-26 2023-03-14 Splunk Inc. Distributing partial results from an external data system between worker nodes
US11163758B2 (en) 2016-09-26 2021-11-02 Splunk Inc. External dataset capability compensation
US11232100B2 (en) 2016-09-26 2022-01-25 Splunk Inc. Resource allocation for multiple datasets
US11567993B1 (en) 2016-09-26 2023-01-31 Splunk Inc. Copying buckets from a remote shared storage system to memory associated with a search node for query execution
US11461334B2 (en) 2016-09-26 2022-10-04 Splunk Inc. Data conditioning for dataset destination
US12013895B2 (en) 2016-09-26 2024-06-18 Splunk Inc. Processing data using containerized nodes in a containerized scalable environment
US11860940B1 (en) 2016-09-26 2024-01-02 Splunk Inc. Identifying buckets for query execution using a catalog of buckets
US11663227B2 (en) 2016-09-26 2023-05-30 Splunk Inc. Generating a subquery for a distinct data intake and query system
KR20180064588A (ko) * 2016-12-05 2018-06-15 에스케이하이닉스 주식회사 메모리 제어 장치 및 방법
JP6667629B2 (ja) 2016-12-29 2020-03-18 華為技術有限公司Huawei Technologies Co.,Ltd. 記憶システムおよびソリッドステートディスク
CN107102818A (zh) * 2017-03-16 2017-08-29 山东大学 一种基于sd卡的高速数据存储方法
US20180321855A1 (en) * 2017-05-03 2018-11-08 Samsung Electronics Co., Ltd. Multistreaming in heterogeneous environments
US9905294B1 (en) 2017-05-03 2018-02-27 Seagate Technology Llc Writing logically offset pages of data to N-level memory cells coupled to a common word line
CN107256363B (zh) * 2017-06-13 2020-03-06 杭州华澜微电子股份有限公司 一种由加解密模块阵列组成的高速加解密装置
US10606484B2 (en) * 2017-06-23 2020-03-31 Google Llc NAND flash storage device with NAND buffer
US11989194B2 (en) 2017-07-31 2024-05-21 Splunk Inc. Addressing memory limits for partition tracking among worker nodes
US11921672B2 (en) 2017-07-31 2024-03-05 Splunk Inc. Query execution at a remote heterogeneous data store of a data fabric service
JP7105870B2 (ja) * 2017-08-10 2022-07-25 華為技術有限公司 データアクセス方法、装置およびシステム
US11609623B2 (en) 2017-09-01 2023-03-21 Qualcomm Incorporated Ultra-low power neuromorphic artificial intelligence computing accelerator
US10896182B2 (en) 2017-09-25 2021-01-19 Splunk Inc. Multi-partitioning determination for combination operations
TWI685847B (zh) * 2017-10-12 2020-02-21 慧榮科技股份有限公司 資料儲存裝置之非揮發式記憶體的命名空間規劃
CN109656833B (zh) 2017-10-12 2022-11-11 慧荣科技股份有限公司 数据储存装置
US10908832B2 (en) * 2017-10-31 2021-02-02 Micron Technology, Inc. Common pool management
CN107728953B (zh) * 2017-11-03 2021-03-02 记忆科技(深圳)有限公司 一种提升固态硬盘混合读写性能的方法
CN107943726A (zh) * 2017-11-16 2018-04-20 郑州云海信息技术有限公司 一种基于PCIe接口的数据传输***及方法
DE102018123494A1 (de) 2017-11-17 2019-05-23 Samsung Electronics Co., Ltd. Speichervorrichtung, die zum aktualisieren einesfeldprogrammierbaren gate-arrays ausgestaltetist, und betriebsverfahren dafür
CN108092730B (zh) * 2017-12-27 2019-04-26 中国电子科技集团公司第五十四研究所 一种适用于多设备的时序控制方法
US10628359B2 (en) * 2018-03-01 2020-04-21 EMC IP Holding Company LLC Storage management system and method
KR101936951B1 (ko) 2018-04-11 2019-01-11 주식회사 맴레이 메모리 제어 장치 및 이를 포함하는 메모리 시스템
US11334543B1 (en) 2018-04-30 2022-05-17 Splunk Inc. Scalable bucket merging for a data intake and query system
EP3573030B1 (en) * 2018-05-23 2023-10-11 Diebold Nixdorf Systems GmbH System and method to control the access on information of a peripheral storage device
KR102560251B1 (ko) 2018-06-20 2023-07-26 삼성전자주식회사 반도체 장치 및 반도체 시스템
US10884662B2 (en) * 2018-08-06 2021-01-05 Silicon Motion, Inc. Method for performing storage control in a storage server, associated memory device and memory controller thereof, and associated storage server
US11574659B2 (en) * 2018-09-11 2023-02-07 Micron Technology, Inc. Parallel access to volatile memory by a processing device for machine learning
US10725686B2 (en) * 2018-09-28 2020-07-28 Burlywood, Inc. Write stream separation into multiple partitions
KR102576373B1 (ko) 2018-09-28 2023-09-07 에스케이하이닉스 주식회사 저장 공간을 동적으로 할당하는 제어 장치 및 이를 포함하는 데이터 저장 장치
CN110968449A (zh) * 2018-09-28 2020-04-07 方一信息科技(上海)有限公司 用于多通道闪存控制器的bch ecc纠错资源共享***及方法
US10817430B2 (en) * 2018-10-02 2020-10-27 Micron Technology, Inc. Access unit and management segment memory operations
KR20200053204A (ko) 2018-11-08 2020-05-18 삼성전자주식회사 저장 장치, 저장 장치의 동작 방법 및 저장 장치를 제어하는 호스트의 동작 방법
US10871907B2 (en) 2018-12-31 2020-12-22 Micron Technology, Inc. Sequential data optimized sub-regions in storage devices
CN109979498A (zh) * 2019-01-24 2019-07-05 深圳市景阳信息技术有限公司 磁盘视频数据写入、读取的方法及装置
CN110046114B (zh) * 2019-03-06 2020-08-14 上海熠知电子科技有限公司 基于pcie协议的dma控制器及dma数据传输方法
CN109933291B (zh) * 2019-03-20 2022-05-06 浪潮商用机器有限公司 一种sram数据的处理方法、装置、设备及存储介质
JP7074705B2 (ja) * 2019-03-20 2022-05-24 キオクシア株式会社 メモリ装置及びメモリ装置の制御方法
WO2020220216A1 (en) 2019-04-29 2020-11-05 Splunk Inc. Search time estimate in data intake and query system
CN110209606B (zh) * 2019-04-30 2021-01-22 杭州电子科技大学 一种基于PCIe的多接口存储设备的控制方法
US11715051B1 (en) 2019-04-30 2023-08-01 Splunk Inc. Service provider instance recommendations using machine-learned classifications and reconciliation
CN110235111B (zh) * 2019-04-30 2020-06-26 长江存储科技有限责任公司 电子设备和管理闪存的读取电平的方法
EP3915030B1 (en) * 2019-04-30 2023-10-18 Hewlett-Packard Development Company, L.P. Storage of network credentials
KR20200134784A (ko) * 2019-05-23 2020-12-02 에스케이하이닉스 주식회사 저장 장치 및 그 동작 방법
CN110175056B (zh) * 2019-05-30 2022-02-11 西安微电子技术研究所 一种异构平台远程动态加载多目标fpga的控制装置及控制方法
KR20200142219A (ko) 2019-06-12 2020-12-22 삼성전자주식회사 전자 장치 및 그의 저장 공간 이용 방법
KR20210012305A (ko) * 2019-07-24 2021-02-03 삼성전자주식회사 집적회로 장치, 시스템 온 칩 및 패킷 처리 방법
CN112394887A (zh) * 2019-08-17 2021-02-23 森大(深圳)技术有限公司 Onepass打印数据高效率处理方法、装置、设备及存储介质
CN110673989B (zh) * 2019-08-27 2023-05-16 国网浙江省电力有限公司电力科学研究院 一种背板***的子板卡识别装置与方法
US11494380B2 (en) 2019-10-18 2022-11-08 Splunk Inc. Management of distributed computing framework components in a data fabric service system
KR20210054187A (ko) * 2019-11-05 2021-05-13 에스케이하이닉스 주식회사 메모리 시스템, 메모리 장치 및 메모리 시스템의 동작 방법
US11175984B1 (en) 2019-12-09 2021-11-16 Radian Memory Systems, Inc. Erasure coding techniques for flash memory
US11892956B2 (en) * 2019-12-31 2024-02-06 Micron Technology, Inc. Performance of memory system background operations
US11922222B1 (en) 2020-01-30 2024-03-05 Splunk Inc. Generating a modified component for a data intake and query system using an isolated execution environment image
KR20210156985A (ko) 2020-06-19 2021-12-28 삼성전자주식회사 일 함수 층들을 갖는 반도체 소자들
KR20210158607A (ko) 2020-06-24 2021-12-31 삼성전자주식회사 캡핑층을 포함하는 반도체 소자
KR20210158615A (ko) 2020-06-24 2021-12-31 삼성전자주식회사 게이트 라인을 포함하는 집적회로 소자
US11704313B1 (en) 2020-10-19 2023-07-18 Splunk Inc. Parallel branch operation using intermediary nodes
KR20220067872A (ko) * 2020-11-18 2022-05-25 에스케이하이닉스 주식회사 컨트롤러 및 컨트롤러의 동작방법
US11513980B2 (en) * 2021-01-21 2022-11-29 Silicon Motion, Inc. Method and apparatus for performing access management of memory device with aid of universal asynchronous receiver-transmitter connection
US20220350933A1 (en) * 2021-04-29 2022-11-03 EMC IP Holding Company LLC Methods and systems for securing data in a distributed storage system
US20230008974A1 (en) * 2021-07-08 2023-01-12 Toshiba Global Commerce Solutions Holdings Corporation Methods, systems, and computer program products configured to provide consistent look and feel for user input
CN115843379A (zh) * 2021-07-21 2023-03-24 美光科技公司 用来改进顺序存储器命令性能的存储器命令聚合
US20230120600A1 (en) * 2021-10-20 2023-04-20 Western Digital Technologies, Inc. Data Storage Devices, Systems, and Related Methods for Grouping Commands of Doorbell Transactions from Host Devices
KR102385572B1 (ko) 2021-11-02 2022-04-13 삼성전자주식회사 컨트롤러, 스토리지 장치 및 스토리지 장치의 동작 방법
CN116501670A (zh) * 2022-01-18 2023-07-28 联发科技(新加坡)私人有限公司 传感装置的中断处理方法及其集成电路
US20230266897A1 (en) * 2022-02-24 2023-08-24 Micron Technology, Inc. Dynamic zone group configuration at a memory sub-system

Family Cites Families (169)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4449182A (en) * 1981-10-05 1984-05-15 Digital Equipment Corporation Interface between a pair of processors, such as host and peripheral-controlling processors in data processing systems
US4777595A (en) 1982-05-07 1988-10-11 Digital Equipment Corporation Apparatus for transferring blocks of information from one node to a second node in a computer network
DE69024086T2 (de) * 1989-04-13 1996-06-20 Sundisk Corp EEprom-System mit Blocklöschung
JPH0398972A (ja) * 1989-09-08 1991-04-24 Mitsubishi Electric Corp エレベータの制御装置
US5663901A (en) 1991-04-11 1997-09-02 Sandisk Corporation Computer memory cards using flash EEPROM integrated circuit chips and memory-controller systems
EP0610677A3 (en) * 1993-02-12 1995-08-02 Ibm Communication device management module operating in two modes.
US5619687A (en) * 1994-02-22 1997-04-08 Motorola Inc. Queue system having a time-out feature and method therefor
JPH07234764A (ja) * 1994-02-22 1995-09-05 Toshiba Corp スケジューラ
JP3209634B2 (ja) * 1994-03-28 2001-09-17 株式会社日立製作所 計算機システム
JP3561002B2 (ja) * 1994-05-18 2004-09-02 富士通株式会社 ディスク装置
JPH0997124A (ja) * 1995-09-29 1997-04-08 Fujitsu Ltd 電子装置、メモリボード並びにメモリ装着機構
US5708814A (en) 1995-11-21 1998-01-13 Microsoft Corporation Method and apparatus for reducing the rate of interrupts by generating a single interrupt for a group of events
JPH09305330A (ja) * 1996-05-15 1997-11-28 Oki Electric Ind Co Ltd ディスクアレイ装置
JPH10214221A (ja) * 1997-01-31 1998-08-11 Hitachi Ltd 制御装置及びメモリシステム
US6003112A (en) 1997-06-30 1999-12-14 Intel Corporation Memory controller and method for clearing or copying memory utilizing register files to store address information
US5941998A (en) * 1997-07-25 1999-08-24 Samsung Electronics Co., Ltd. Disk drive incorporating read-verify after write method
US7158167B1 (en) 1997-08-05 2007-01-02 Mitsubishi Electric Research Laboratories, Inc. Video recording device for a targetable weapon
US7088387B1 (en) * 1997-08-05 2006-08-08 Mitsubishi Electric Research Laboratories, Inc. Video recording device responsive to triggering event
DE19740525C1 (de) * 1997-09-15 1999-02-04 Siemens Ag Verfahren zur Abspeicherung und Wiedergewinnung von Daten in einem Steuersystem, insbesondere in einem Kraftfahrzeug
JP3534585B2 (ja) 1997-10-21 2004-06-07 株式会社日立製作所 フラッシュメモリを複数使用した外部記憶装置のデータ記憶制御方法及び装置
US6009478A (en) * 1997-11-04 1999-12-28 Adaptec, Inc. File array communications interface for communicating between a host computer and an adapter
US6175900B1 (en) * 1998-02-09 2001-01-16 Microsoft Corporation Hierarchical bitmap-based memory manager
NL1011442C2 (nl) * 1998-03-26 1999-09-28 Franciscus Hubertus Johannes M Frontwerktuigbesturing.
US6172676B1 (en) * 1998-07-17 2001-01-09 International Business Machines Corporation Method and computer program product for implementing multiple drag and drop operations for large objects without blocking an operating system interface
US6313522B1 (en) * 1998-08-28 2001-11-06 Micron Technology, Inc. Semiconductor structure having stacked semiconductor devices
JP2000357125A (ja) * 1999-06-16 2000-12-26 Matsushita Electric Ind Co Ltd バッファメモリ制御方法及び制御装置
US6866581B2 (en) * 1999-09-24 2005-03-15 Igt Video gaming apparatus for wagering with universal computerized controller and I/O interface for unique architecture
US6757797B1 (en) * 1999-09-30 2004-06-29 Fujitsu Limited Copying method between logical disks, disk-storage system and its storage medium
US6678463B1 (en) * 2000-08-02 2004-01-13 Opentv System and method for incorporating previously broadcast content into program recording
US8250617B2 (en) * 1999-10-29 2012-08-21 Opentv, Inc. System and method for providing multi-perspective instant replay
US7000245B1 (en) * 1999-10-29 2006-02-14 Opentv, Inc. System and method for recording pushed data
DK1224806T3 (da) 1999-10-29 2004-02-16 Opentv Corp System og en metode til optagelse af "pushed" dataindhold
US20020053004A1 (en) * 1999-11-19 2002-05-02 Fong Pong Asynchronous cache coherence architecture in a shared memory multiprocessor with point-to-point links
US7024695B1 (en) * 1999-12-30 2006-04-04 Intel Corporation Method and apparatus for secure remote system management
US8037234B2 (en) 2003-12-02 2011-10-11 Super Talent Electronics, Inc. Command queuing smart storage transfer manager for striping data to raw-NAND flash modules
US8266367B2 (en) 2003-12-02 2012-09-11 Super Talent Electronics, Inc. Multi-level striping and truncation channel-equalization for flash-memory system
US20050160218A1 (en) 2004-01-20 2005-07-21 Sun-Teck See Highly integrated mass storage device with an intelligent flash controller
US8341332B2 (en) 2003-12-02 2012-12-25 Super Talent Electronics, Inc. Multi-level controller with smart storage transfer manager for interleaving multiple single-chip flash memory devices
US6317330B1 (en) 2000-02-15 2001-11-13 Bitmicro Networks, Inc. Printed circuit board assembly
US6434660B1 (en) 2000-05-23 2002-08-13 Centennial Technologies, Inc. Emulating one tape protocol of flash memory to a different type protocol of flash memory
US6772273B1 (en) * 2000-06-29 2004-08-03 Intel Corporation Block-level read while write method and apparatus
IL137085A (en) * 2000-06-29 2004-08-31 Eci Telecom Ltd Method for effective utilizing of shared resources in computerized systems
US7104804B2 (en) 2000-07-03 2006-09-12 Advanced Interconnect Solutions Method and apparatus for memory module circuit interconnection
JP2002023962A (ja) * 2000-07-07 2002-01-25 Fujitsu Ltd ディスク装置及び制御方法
CA2398200C (en) 2000-08-02 2011-04-26 Opentv, Inc. System and method for providing multi-perspective instant replay
JP4609680B2 (ja) * 2000-08-09 2011-01-12 ソニー株式会社 データ蓄積装置
US6820148B1 (en) * 2000-08-17 2004-11-16 Sandisk Corporation Multiple removable non-volatile memory cards serially communicating with a host
US6640274B1 (en) 2000-08-21 2003-10-28 Intel Corporation Method and apparatus for reducing the disk drive data transfer interrupt service latency penalty
US6865631B2 (en) * 2000-12-14 2005-03-08 International Business Machines Corporation Reduction of interrupts in remote procedure calls
JP4818812B2 (ja) * 2006-05-31 2011-11-16 株式会社日立製作所 フラッシュメモリストレージシステム
US6931498B2 (en) * 2001-04-03 2005-08-16 Intel Corporation Status register architecture for flexible read-while-write device
US20020178307A1 (en) * 2001-05-25 2002-11-28 Pua Khein Seng Multiple memory card adapter
US6781914B2 (en) * 2001-08-23 2004-08-24 Winbond Electronics Corp. Flash memory having a flexible bank partition
ITRM20010524A1 (it) 2001-08-30 2003-02-28 Micron Technology Inc Struttura a schiera di memoria flash.
US7631084B2 (en) 2001-11-02 2009-12-08 Juniper Networks, Inc. Method and system for providing secure access to private networks with client redirection
KR100449708B1 (ko) 2001-11-16 2004-09-22 삼성전자주식회사 플래시 메모리 관리방법
JP3802411B2 (ja) * 2001-12-20 2006-07-26 株式会社東芝 不揮発性半導体記憶装置のデータコピー方法
US6938188B1 (en) * 2002-01-29 2005-08-30 Advanced Digital Information Corporation Method for verifying functional integrity of computer hardware, particularly data storage devices
US6854022B1 (en) * 2002-02-22 2005-02-08 Western Digital Technologies, Inc. Disk drive using rotational position optimization algorithm to facilitate write verify operations
US7080245B2 (en) 2002-05-23 2006-07-18 Hewlett-Packard Development Company, L.P. Method and system of switching between two or more images of firmware on a host device
US7114051B2 (en) 2002-06-01 2006-09-26 Solid State System Co., Ltd. Method for partitioning memory mass storage device
US20040078729A1 (en) * 2002-06-26 2004-04-22 Siemens Aktiengesellschaft Method, computer, and computer program for detecting a bad block on a hard disk
JP2004071033A (ja) 2002-08-05 2004-03-04 Mitsubishi Electric Corp フラッシュメモリのデータ記録法
DE60204687T2 (de) * 2002-09-06 2006-05-18 Sun Microsystems, Inc., Santa Clara Speicherkopierbefehl mit Angabe von Quelle und Ziel, der in der Speichersteuerung ausgeführt wird
US7137118B2 (en) 2002-09-27 2006-11-14 Texas Instruments Incorporated Data synchronization hardware primitive in an embedded symmetrical multiprocessor computer
US7296213B2 (en) 2002-12-11 2007-11-13 Nvidia Corporation Error correction cache for flash memory
US6901461B2 (en) * 2002-12-31 2005-05-31 Intel Corporation Hardware assisted ATA command queuing
CN1432929A (zh) * 2003-02-14 2003-07-30 威盛电子股份有限公司 多微处理器***内响应中断服务要求的仲裁结构及方法
JP4165747B2 (ja) * 2003-03-20 2008-10-15 株式会社日立製作所 記憶システム、制御装置及び制御装置のプログラム
US7136938B2 (en) * 2003-03-27 2006-11-14 International Business Machines Corporation Command ordering based on dependencies
KR100543447B1 (ko) * 2003-04-03 2006-01-23 삼성전자주식회사 에러정정기능을 가진 플래쉬메모리장치
US7320100B2 (en) * 2003-05-20 2008-01-15 Cray Inc. Apparatus and method for memory with bit swapping on the fly and testing
US7159104B2 (en) * 2003-05-20 2007-01-02 Nvidia Corporation Simplified memory detection
US7200688B2 (en) * 2003-05-29 2007-04-03 International Business Machines Corporation System and method asynchronous DMA command completion notification by accessing register via attached processing unit to determine progress of DMA command
JP4653960B2 (ja) * 2003-08-07 2011-03-16 ルネサスエレクトロニクス株式会社 メモリカードおよび不揮発性メモリ混載マイコン
CN2662316Y (zh) * 2003-11-28 2004-12-08 中国科学院空间科学与应用研究中心 嵌入式计算机***用的***主板
US8176238B2 (en) 2003-12-02 2012-05-08 Super Talent Electronics, Inc. Command queuing smart storage transfer manager for striping data to raw-NAND flash modules
US7865809B1 (en) * 2004-03-11 2011-01-04 Super Talent Electronics, Inc. Data error detection and correction in non-volatile memory devices
JP2005190106A (ja) * 2003-12-25 2005-07-14 Hitachi Ltd 論理ボリュームを管理する記憶制御サブシステム
US7370230B1 (en) 2004-01-08 2008-05-06 Maxtor Corporation Methods and structure for error correction in a processor pipeline
US8108870B2 (en) 2004-01-29 2012-01-31 Klingman Edwin E Intelligent memory device having ASCII-named task registers mapped to addresses of a task
US7127549B2 (en) * 2004-02-04 2006-10-24 Sandisk Corporation Disk acceleration using first and second storage devices
US7984316B2 (en) * 2004-02-24 2011-07-19 Paul Kaler Solid state disk with hot-swappable components
US7328304B2 (en) * 2004-02-27 2008-02-05 Intel Corporation Interface for a block addressable mass storage system
CA2557641A1 (en) * 2004-02-27 2005-09-15 Tigi Corporation System and method for data manipulation
US7406572B1 (en) * 2004-03-26 2008-07-29 Cypress Semiconductor Corp. Universal memory circuit architecture supporting multiple memory interface options
US20080147931A1 (en) * 2006-10-17 2008-06-19 Smart Modular Technologies, Inc. Data striping to flash memory
US7490283B2 (en) 2004-05-13 2009-02-10 Sandisk Corporation Pipelined data relocation and improved chip architectures
US7205532B2 (en) * 2004-08-24 2007-04-17 Avago Technologies Ecbu Ip (Singapore) Pte. Ltd. Integrated ball grid array optical mouse sensor packaging
US20060053308A1 (en) 2004-09-08 2006-03-09 Raidy 2 Go Ltd. Secured redundant memory subsystem
US7283074B2 (en) 2004-09-21 2007-10-16 Telegent Systems, Inc. Pilot-tone calibration for time-interleaved analog-to-digital converters
KR100667780B1 (ko) * 2004-11-22 2007-01-11 삼성전자주식회사 검정 방법, 기록/재생 장치 및 정보 저장 매체
US7730257B2 (en) 2004-12-16 2010-06-01 Broadcom Corporation Method and computer program product to increase I/O write performance in a redundant array
KR100621631B1 (ko) * 2005-01-11 2006-09-13 삼성전자주식회사 반도체 디스크 제어 장치
JP2006195569A (ja) * 2005-01-11 2006-07-27 Sony Corp 記憶装置
US7562366B2 (en) 2005-02-03 2009-07-14 Solarflare Communications, Inc. Transmit completion event batching
WO2006085323A2 (en) * 2005-02-11 2006-08-17 Sandisk Il Ltd. Appliance with communication protocol emulation
TWI266988B (en) 2005-03-01 2006-11-21 Sunplus Technology Co Ltd Method and system for accessing A/V data in computer apparatus
US20060211388A1 (en) * 2005-03-07 2006-09-21 Lambert Grady D Stackable printed circuit boards
US7225289B2 (en) 2005-03-14 2007-05-29 Phison Electronics Corporation Virtual IDE storage with PCI express interface
US20080126658A1 (en) * 2006-05-28 2008-05-29 Phison Electronics Corp. Inlayed flash memory module
US7822912B2 (en) 2005-03-14 2010-10-26 Phision Electronics Corp. Flash storage chip and flash array storage system
JP2007004775A (ja) * 2005-05-23 2007-01-11 Toshiba Corp 半導体メモリカード
KR100690804B1 (ko) 2005-06-13 2007-03-09 엘지전자 주식회사 휴대단말기의 메모리 정리 방법
TWI319160B (en) * 2005-07-11 2010-01-01 Via Tech Inc Memory card capable of supporting various voltage supply and control chip and method of supporting voltage thereof
US7660306B1 (en) 2006-01-12 2010-02-09 Chelsio Communications, Inc. Virtualizing the operation of intelligent network interface circuitry
US20070079098A1 (en) * 2005-10-03 2007-04-05 Hitachi, Ltd. Automatic allocation of volumes in storage area networks
US7778069B2 (en) * 2005-10-17 2010-08-17 Renesas Technology Corp. Semiconductor device and its fabrication method
CN101346703B (zh) 2005-12-21 2012-11-21 Nxp股份有限公司 具有可块擦除单元的非易失性存储器
EP1966699A2 (en) 2005-12-22 2008-09-10 Nxp B.V. Memory with block-erasable locations and a linked chain of pointers to locate blocks with pointer information
WO2007079534A1 (en) 2006-01-12 2007-07-19 Para Kanagasabai Segaram A subsystem for computing devices
US7549021B2 (en) * 2006-02-22 2009-06-16 Seagate Technology Llc Enhanced data integrity using parallel volatile and non-volatile transfer buffers
WO2007096844A2 (en) 2006-02-27 2007-08-30 Nxp B.V. Memory with block-erasable locations
JP2007257791A (ja) 2006-03-24 2007-10-04 Fujitsu Ltd 半導体記憶装置
JP4135747B2 (ja) * 2006-04-06 2008-08-20 ソニー株式会社 データ処理装置及びフラッシュメモリへのアクセス方法
US20070271495A1 (en) 2006-05-18 2007-11-22 Ian Shaeffer System to detect and identify errors in control information, read data and/or write data
CN100433697C (zh) * 2006-06-01 2008-11-12 东南大学 多通道高速数据处理器及处理方法
US7613876B2 (en) * 2006-06-08 2009-11-03 Bitmicro Networks, Inc. Hybrid multi-tiered caching storage system
US7506098B2 (en) 2006-06-08 2009-03-17 Bitmicro Networks, Inc. Optimized placement policy for solid state storage devices
WO2007146845A2 (en) 2006-06-08 2007-12-21 Bitmicro Networks, Inc. Configurable and scalable hybrid multi-tiered caching storage system
TW200805394A (en) * 2006-07-07 2008-01-16 Alcor Micro Corp Memory storage device and the read/write method thereof
US8140738B2 (en) * 2006-07-20 2012-03-20 Stmicroelectronics Pvt. Ltd. Flash memory interface device
US7487428B2 (en) * 2006-07-24 2009-02-03 Kingston Technology Corp. Fully-buffered memory-module with error-correction code (ECC) controller in serializing advanced-memory buffer (AMB) that is transparent to motherboard memory controller
US7827346B2 (en) 2006-08-14 2010-11-02 Plankton Technologies, Llc Data storage device
US7539842B2 (en) * 2006-08-15 2009-05-26 International Business Machines Corporation Computer memory system for selecting memory buses according to physical memory organization information stored in virtual address translation tables
CN100573435C (zh) 2006-08-18 2009-12-23 福昭科技(深圳)有限公司 一种基于闪存记忆体的大容量存储装置
US7904639B2 (en) 2006-08-22 2011-03-08 Mosaid Technologies Incorporated Modular command structure for memory and memory system
KR20080017982A (ko) * 2006-08-23 2008-02-27 삼성전자주식회사 플래시 메모리 시스템 및 그 프로그램 방법
US7730269B2 (en) * 2006-08-29 2010-06-01 International Business Machines Corporation Load management to reduce communication signaling latency in a virtual machine environment
JP2008065575A (ja) * 2006-09-07 2008-03-21 Fuji Xerox Co Ltd 拡張メモリ装置、及びメモリ拡張システム
CN101118783A (zh) * 2006-09-07 2008-02-06 晶天电子(深圳)有限公司 带有闪存坏块控制***的电子数据闪存卡
JP4452261B2 (ja) 2006-09-12 2010-04-21 株式会社日立製作所 ストレージシステムの論理ボリューム管理方法、論理ボリューム管理プログラム、及びストレージシステム
US20080077727A1 (en) * 2006-09-25 2008-03-27 Baca Jim S Multithreaded state machine in non-volatile memory devices
US8051253B2 (en) * 2006-09-28 2011-11-01 Virident Systems, Inc. Systems and apparatus with programmable memory control for heterogeneous main memory
US7587575B2 (en) 2006-10-17 2009-09-08 International Business Machines Corporation Communicating with a memory registration enabled adapter using cached address translations
JP4932427B2 (ja) 2006-10-20 2012-05-16 株式会社日立製作所 記憶装置及び記憶方法
WO2008070813A2 (en) * 2006-12-06 2008-06-12 Fusion Multisystems, Inc. (Dba Fusion-Io) Apparatus, system, and method for a front-end, distributed raid
US8935302B2 (en) 2006-12-06 2015-01-13 Intelligent Intellectual Property Holdings 2 Llc Apparatus, system, and method for data block usage information synchronization for a non-volatile storage volume
US7660911B2 (en) 2006-12-20 2010-02-09 Smart Modular Technologies, Inc. Block-based data striping to flash memory
US7668177B1 (en) 2006-12-28 2010-02-23 Qlogic, Corporation Method and system for quality of service in host bus adapters
KR100813630B1 (ko) * 2007-02-07 2008-03-14 삼성전자주식회사 독출 성능을 향상할 수 있는 플래시 메모리 시스템 및그것의 독출 방법
US20080209157A1 (en) * 2007-02-27 2008-08-28 Inventec Corporation Memory partitioning method
JP5224706B2 (ja) 2007-03-23 2013-07-03 キヤノン株式会社 記憶装置及び記憶装置の制御方法
JP4781373B2 (ja) * 2007-05-14 2011-09-28 株式会社バッファロー 記憶装置
JP2008287404A (ja) 2007-05-16 2008-11-27 Hitachi Ltd 読み出しによる非アクセスメモリセルのデータ破壊を検出及び回復する装置、及びその方法
JP2008293096A (ja) 2007-05-22 2008-12-04 Shinko Electric Ind Co Ltd メモリインタフェースおよびメモリシステム
US20080294814A1 (en) * 2007-05-24 2008-11-27 Sergey Anatolievich Gorobets Flash Memory System with Management of Housekeeping Operations
WO2008147752A1 (en) 2007-05-24 2008-12-04 Sandisk Corporation Managing housekeeping operations in flash memory
KR20080105390A (ko) 2007-05-30 2008-12-04 삼성전자주식회사 플래시 메모리에 사용되는 명령어들을 제어하는 방법 및장치
US8040710B2 (en) 2007-05-31 2011-10-18 Qimonda Ag Semiconductor memory arrangement
US7898813B2 (en) * 2007-06-25 2011-03-01 Kabushiki Kaisha Toshiba Semiconductor memory device and semiconductor memory card using the same
US20090006720A1 (en) 2007-06-27 2009-01-01 Shai Traister Scheduling phased garbage collection and house keeping operations in a flash memory system
US8001444B2 (en) 2007-08-08 2011-08-16 Intel Corporation ECC functional block placement in a multi-channel mass storage device
US7639165B2 (en) 2007-08-10 2009-12-29 Marvell World Trade Ltd. Calibrating replica digital-to-analog converters
JP4977554B2 (ja) 2007-08-22 2012-07-18 株式会社日立製作所 キャッシュメモリ上のデータをバックアップする機能を備えたストレージシステム
KR101466694B1 (ko) 2007-08-28 2014-11-28 삼성전자주식회사 Ecc 회로, ecc 회로를 구비하는 메모리 시스템 및그의 오류 정정 방법
US8082482B2 (en) 2007-08-31 2011-12-20 International Business Machines Corporation System for performing error correction operations in a memory hub device of a memory module
US8086936B2 (en) 2007-08-31 2011-12-27 International Business Machines Corporation Performing error correction at a memory device level that is transparent to a memory channel
US20090063895A1 (en) 2007-09-04 2009-03-05 Kurt Smith Scaleable and maintainable solid state drive
US20090125790A1 (en) 2007-11-13 2009-05-14 Mcm Portfolio Llc Method and Apparatus of Automatically Selecting Error Correction Algorithms by a NAND Flash Controller
TWI384488B (zh) 2007-12-24 2013-02-01 Skymedi Corp Nonvolatile storage device and its data writing method
US20100049914A1 (en) * 2008-08-20 2010-02-25 Goodwin Paul M RAID Enhanced solid state drive
US8266365B2 (en) 2008-12-17 2012-09-11 Sandisk Il Ltd. Ruggedized memory device
US8566508B2 (en) 2009-04-08 2013-10-22 Google Inc. RAID configuration in a flash memory data storage device
US20100262979A1 (en) 2009-04-08 2010-10-14 Google Inc. Circular command queues for communication between a host and a data storage device
US20100287217A1 (en) * 2009-04-08 2010-11-11 Google Inc. Host control of background garbage collection in a data storage device
US8447918B2 (en) 2009-04-08 2013-05-21 Google Inc. Garbage collection for failure prediction and repartitioning
WO2010137178A1 (en) 2009-05-25 2010-12-02 Hitachi,Ltd. Storage subsystem
WO2011007459A1 (ja) 2009-07-17 2011-01-20 株式会社日立製作所 ストレージ装置及びその制御方法

Also Published As

Publication number Publication date
US20140108708A1 (en) 2014-04-17
US20100262738A1 (en) 2010-10-14
CN102428452A (zh) 2012-04-25
EP2728488A3 (en) 2014-06-11
JP2012523624A (ja) 2012-10-04
EP2728488B1 (en) 2018-01-17
EP2417533A1 (en) 2012-02-15
AU2010234772A1 (en) 2011-11-10
EP2417528A1 (en) 2012-02-15
EP2417530A1 (en) 2012-02-15
AU2010234648B2 (en) 2013-08-22
EP2417531B1 (en) 2014-03-12
JP2012523618A (ja) 2012-10-04
DE202010017668U1 (de) 2012-04-04
JP2012523619A (ja) 2012-10-04
DE202010017661U1 (de) 2012-04-04
WO2010117930A1 (en) 2010-10-14
US8250271B2 (en) 2012-08-21
US20100262757A1 (en) 2010-10-14
AU2010234647B2 (en) 2013-08-15
DE202010017666U1 (de) 2012-04-05
US20140047172A1 (en) 2014-02-13
US20100262894A1 (en) 2010-10-14
JP2012523623A (ja) 2012-10-04
US20100262762A1 (en) 2010-10-14
US20100262761A1 (en) 2010-10-14
US20100262758A1 (en) 2010-10-14
US8380909B2 (en) 2013-02-19
EP2417528B1 (en) 2015-02-25
US8205037B2 (en) 2012-06-19
EP2417531A1 (en) 2012-02-15
EP2728488A2 (en) 2014-05-07
WO2010117878A1 (en) 2010-10-14
CN102428454A (zh) 2012-04-25
WO2010117929A1 (en) 2010-10-14
US8244962B2 (en) 2012-08-14
US20100262773A1 (en) 2010-10-14
EP2417529A1 (en) 2012-02-15
CN102428453A (zh) 2012-04-25
DE202010017669U1 (de) 2012-04-05
US20140156915A1 (en) 2014-06-05
US8578084B2 (en) 2013-11-05
AU2010234647A1 (en) 2011-11-10
CN107832010A (zh) 2018-03-23
AU2010234773A1 (en) 2011-11-10
CN102428451B (zh) 2015-01-21
US20100262740A1 (en) 2010-10-14
AU2010234646A1 (en) 2011-11-10
JP2012523622A (ja) 2012-10-04
US20100262760A1 (en) 2010-10-14
CN102428451A (zh) 2012-04-25
JP2015046175A (ja) 2015-03-12
JP5922016B2 (ja) 2016-05-24
WO2010117928A1 (en) 2010-10-14
US8566507B2 (en) 2013-10-22
US20100262759A1 (en) 2010-10-14
AU2010234648A1 (en) 2011-11-10
AU2010234773B2 (en) 2013-11-14
DE202010017665U1 (de) 2012-04-04
CN102428455A (zh) 2012-04-25
DE202010017667U1 (de) 2012-04-04
JP5347061B2 (ja) 2013-11-20
WO2010117877A1 (en) 2010-10-14
AU2010234772B2 (en) 2013-12-05
US8639871B2 (en) 2014-01-28
US8566508B2 (en) 2013-10-22
US8239724B2 (en) 2012-08-07

Similar Documents

Publication Publication Date Title
JP5657641B2 (ja) データストレージデバイスのコマンド及び割り込みのグループ化
US20100262979A1 (en) Circular command queues for communication between a host and a data storage device
US9317204B2 (en) System and method for I/O optimization in a multi-queued environment
US9898341B2 (en) Adjustable priority ratios for multiple task queues
EP2849076B1 (en) Dma transmission method and system
EP2849077B1 (en) Method for writing data into storage device and storage device
US8683126B2 (en) Optimal use of buffer space by a storage controller which writes retrieved data directly to a memory
EP3647932B1 (en) Storage device processing stream data, system including the same, and operation method thereof
US8762682B1 (en) Data storage apparatus providing host full duplex operations using half duplex storage devices
US9098209B2 (en) Communication via a memory interface
KR20160049200A (ko) 데이터 저장 장치의 작동 방법, 이를 포함하는 모바일 컴퓨팅 장치, 및 이의 작동 방법
US7809068B2 (en) Integrated circuit capable of independently operating a plurality of communication channels
US20090282188A1 (en) Memory device and control method
US20080301381A1 (en) Device and method for controlling commands used for flash memory
US10089039B2 (en) Memory controller, memory device having the same, and memory control method
US10169235B2 (en) Methods of overriding a resource retry
US20240168876A1 (en) Solving submission queue entry overflow using metadata or data pointers
US20160098306A1 (en) Hardware queue automation for hardware engines
WO2011119151A1 (en) Communication between a computer and a data storage device
CN118377747A (zh) 数据传输方法、***、控制器及存储介质

Legal Events

Date Code Title Description
A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20130306

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20130326

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20130624

A602 Written permission of extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A602

Effective date: 20130701

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20130926

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20140121

A601 Written request for extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A601

Effective date: 20140416

A602 Written permission of extension of time

Free format text: JAPANESE INTERMEDIATE CODE: A602

Effective date: 20140423

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20140718

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

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20141126

R150 Certificate of patent or registration of utility model

Ref document number: 5657641

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

RD02 Notification of acceptance of power of attorney

Free format text: JAPANESE INTERMEDIATE CODE: R3D02

RD02 Notification of acceptance of power of attorney

Free format text: JAPANESE INTERMEDIATE CODE: R3D02

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

S533 Written request for registration of change of name

Free format text: JAPANESE INTERMEDIATE CODE: R313533

R350 Written notification of registration of transfer

Free format text: JAPANESE INTERMEDIATE CODE: R350

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250