JP2015534409A - データストレージシステムのための適応誤り訂正符号 - Google Patents

データストレージシステムのための適応誤り訂正符号 Download PDF

Info

Publication number
JP2015534409A
JP2015534409A JP2015539605A JP2015539605A JP2015534409A JP 2015534409 A JP2015534409 A JP 2015534409A JP 2015539605 A JP2015539605 A JP 2015539605A JP 2015539605 A JP2015539605 A JP 2015539605A JP 2015534409 A JP2015534409 A JP 2015534409A
Authority
JP
Japan
Prior art keywords
data
memory page
ldpc
volatile memory
memory array
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
JP2015539605A
Other languages
English (en)
Other versions
JP2015534409A5 (ja
JP6129328B2 (ja
Inventor
グアンミン ルー
グアンミン ルー
Original Assignee
ウェスタン デジタル テクノロジーズ インコーポレーテッド
ウェスタン デジタル テクノロジーズ インコーポレーテッド
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by ウェスタン デジタル テクノロジーズ インコーポレーテッド, ウェスタン デジタル テクノロジーズ インコーポレーテッド filed Critical ウェスタン デジタル テクノロジーズ インコーポレーテッド
Publication of JP2015534409A publication Critical patent/JP2015534409A/ja
Publication of JP2015534409A5 publication Critical patent/JP2015534409A5/ja
Application granted granted Critical
Publication of JP6129328B2 publication Critical patent/JP6129328B2/ja
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/08Error detection or correction by redundancy in data representation, e.g. by using checking codes
    • G06F11/10Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's
    • G06F11/1008Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's in individual solid state devices
    • G06F11/1072Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's in individual solid state devices in multilevel memories
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/08Error detection or correction by redundancy in data representation, e.g. by using checking codes
    • G06F11/10Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's
    • G06F11/1008Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's in individual solid state devices
    • G06F11/1048Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's in individual solid state devices using arrangements adapted for a specific error detection or correction feature
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
    • H03M13/03Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words
    • H03M13/05Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits
    • H03M13/11Error detection or forward error correction by redundancy in data representation, i.e. code words containing more digits than the source words using block codes, i.e. a predetermined number of check bits joined to a predetermined number of information bits using multiple parity bits
    • H03M13/1102Codes on graphs and decoding on graphs, e.g. low-density parity check [LDPC] codes
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
    • H03M13/35Unequal or adaptive error protection, e.g. by providing a different level of protection according to significance of source information or by adapting the coding according to the change of transmission channel characteristics
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
    • H03M13/35Unequal or adaptive error protection, e.g. by providing a different level of protection according to significance of source information or by adapting the coding according to the change of transmission channel characteristics
    • H03M13/353Adaptation to the channel
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
    • H03M13/61Aspects and characteristics of methods and arrangements for error correction or error detection, not provided for otherwise
    • H03M13/618Shortening and extension of codes
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
    • H03M13/63Joint error correction and other techniques
    • H03M13/635Error control coding in combination with rate matching
    • H03M13/6356Error control coding in combination with rate matching by repetition or insertion of dummy data, i.e. rate reduction
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
    • H03M13/65Purpose and implementation aspects
    • H03M13/6508Flexibility, adaptability, parametrability and configurability of the implementation
    • H03M13/6516Support of multiple code parameters, e.g. generalized Reed-Solomon decoder for a variety of generator polynomials or Galois fields

Abstract

適応符号データの構成されるデータストレージシステムが開示され、一実施形態において、データストレージシステムコントローラは、不揮発性メモリアレイに対して、例えばEページサイズなどの共通のメモリページサイズを決定する。共通のメモリページサイズに基づいて、コントローラは、低密度パリティチェック(LDPC)符号語長を、複数の定義済みLDPC符号語長から選択する。コントローラは、選択されたLDPC符号語長に基づいてメモリアレイに書き込まれるかまたはメモリアレイから読み込まれる符号化データ用のLDPC符号化パラメータを決定する。複数の定義済みLDPC符号語長を用いることにより、データストレージシステムは、共通のメモリページサイズが複数の定義済みLDPC符号語長のいかなるLDPC符号語長にも等しくないメモリページフォーマットを含む複数の不揮発性メモリページフォーマットをサポートすることができる。これにより、データ符号化の柔軟性および効率性が達成可能である。【選択図】図1

Description

本開示は、コンピュータシステム用のデータストレージシステム(例えばソリッドステートドライブ)に関する。より詳細には、データストレージシステムのための適応誤り訂正符号に関する。
不揮発性メモリアレイは、限られた耐久性をしばしば有する。メモリアレイの耐久性は、典型的に使用パターンおよび損耗次第である。耐久性はさらに、特定のタイプの不揮発性メモリアレイに依存する。例えば、マルチレベルセル(MLC)NAND媒体を有するメモリアレイは、シングルレベルセル(SLC)NAND媒体を有するメモリアレイより低い耐久性を概して有する。
メモリアレイに保存されるユーザデータを破損(低下した耐久性によって生じる場合がある)から保護するため、パリティデータは、誤り検出および/または訂正を容易にするために、ユーザデータと共に決定され得、保存され得る。
特定の実施形態が記載されると共に、これらの実施形態はほんの一例として示され、保護の範囲を制限することを意図していない。実際、本書において記載されている新規な方法およびシステムは、様々な他の形で例示され得る。
さらにまた、本書において記載されている方法およびシステムの形のさまざまな省略、置き換えおよび変更は、保護の要旨を逸脱しない範囲で行われ得る。
一部の実施形態において本開示にて用いられている「符号化」または「符号化するための」データは、データを符号化する(符号化データの)プロセスおよび/またはデータを復号化する(復号化データの)プロセスに、言及する。
ソリッドステートドライブのようなストレージシステムは、不揮発性メモリアレイと一体になった一つ以上のコントローラを含み、この種のコントローラは一関係者によって設計/製造がなされ、不揮発性メモリアレイにあっては他の関係者によって設計/製造されることは通常である。加えて、異なる製造業者からのメモリアレイは異なるメモリページフォーマットを含む異なる内部フォーマッティングを有する傾向がある。ここで、各メモリページフォーマットは複数のメモリページサイズの一つに対応する。また、コストおよび様々な他の競争的理由のために、ストレージシステム製造業者は、異なる製造業者からのメモリアレイを概して使用する。例えば、ストレージシステム製造業者は、現在の生産サイクルにおけるメモリアレイの一つのブランドおよび次の生産サイクルの他のブランドを使用することができる。また、異なるレベルで価格を付けられる異なるストレージシステムモデル用に、異なるメモリアレイが用いられ得る。
従って、一つの一般的な設計手法は、組み立て時あるいは最終的な設計段階で、コントローラと組み合わされる実在のメモリアレイに応じて実際に用いられるこのようなハードウェア、ファームウェアおよび/またはソフトウェアのサブセットを伴う異なる製造業者製のメモリアレイから読み込まれる、あるいはそれに書き込まれるデータを符号化/復号化する専用ハードウェア、ファームウェアおよび/またはソフトウェア、を有する一つ以上のコントローラを含むストレージシステムを備えることである。その結果、最後に組立てられたストレージシステムに含まれない一つ以上のメモリアレイに対する複数のメモリページフォーマットをサポートするために、ストレージシステムは、複数のコントローラまたは追加の、未使用のハードウェア、ファームウェアおよび/またはソフトウェアを含むことができる。
ストレージシステムに含まれるハードウェア、ファームウェアおよび/またはソフトウェアの量を減らすための別の手段では、ストレージシステムおよびコントローラは、周知のメモリページサイズを有する一つの特定の周知のメモリページフォーマットだけをサポートするために構成され得、他のメモリページフォーマットをサポートすることができない。
しかしながら、このようなやり方はストレージシステムおよびコントローラの有用性を他のタイプのメモリアレイに制限してしまい、多数のタイプのメモリアレイをサポートするために多数の異なるストレージシステムおよびコントローラが構成されることを必要とする場合があり、加えて場合によっては、ストレージシステムおよびコントローラが設計/構成されるときに、メモリアレイのメモリページフォーマットは周知でなくてもよい。
したがって、複数の周知または未知のメモリストレージフォーマットのための適応符号化データに対して改良されたシステムと方法が要求される。
本発明の一部の実施形態において、ストレージシステムは、コントローラおよび共通のメモリページサイズで複数のメモリページを有する不揮発性メモリアレイを含む。コントローラは、不揮発性メモリアレイに対して共通のメモリページサイズを決定し、共通のメモリページサイズに基づいて、符号語長(例えば低密度パリティチェック(LDPC)符号語長)を複数の定義済み符号語長から選択する。適切な符号語長(複数の定義済み符号語長から選択される)および対応する符号化パラメータを選択的に使用することにより、コントローラは、複数の周知または未知のメモリページフォーマットをサポートする少なくとも一部の一般的なハードウェア、ファームウェアおよび/またはソフトウェアを使用する。このように、コントローラはその運用を選択的に適応させることができるので、異なる製造業者によって作られる異なるフォーマットのメモリアレイと組み合わせられ得る。
実施形態によっては、不揮発性メモリアレイのメモリページ、ブロックまたはダイが古くなりおよび/またはメモリアレイの使用も手伝って消耗するにつれて、ストレージシステムのコントローラは符号化ユーザデータに対して符号化パラメータを調整する。符号化パラメータ調整のメカニズムは、時間と共にユニットデータごとに付加的なパリティをサポートするコントローラを可能にする。それによって、メモリアレイの質(例えば、データ保持能力)が低下するにつれて、誤り訂正または検出能力を高める。さらに、符号化パラメータ調整のメカニズムは、誤り訂正を有するユニットデータごとの付加的なパリティのために符号化時間のバランスまたは付加的なパリティデータの検出利益を促進する。加えて、異なるメモリページ、ブロックまたはダイに対して異なる符号またはパリティレートを許容するために、コントローラは、メモリアレイのメモリページ、ブロックまたはダイのための調整された符号化パラメータを保存することができる。
これから以下の図面を参照して本発明の様々な特徴を実施するシステム及び方法が説明される。
本発明の一実施形態に従ってデータを適応的に符号化するストレージシステムを例示する図である。 本発明の一実施形態に従って符号化データ用の符号化パラメータを決定するプロセスを例示している流れ図である。 本発明の一実施形態に従って低密度パリティチェック(LDPC)符号化パラメータとバイナリ低密度パリティチェック(LDPC)符号語長の関係を例示しているテーブルである。 本発明の一実施形態例に従ってパディングされたユーザデータおよびパリティデータを例示している略図である。 本発明の一実施形態例に従ってパディングされたユーザデータおよびパリティデータを例示している略図である。 本発明の一実施形態例に従ってパディングされたユーザデータおよびパリティデータを例示している略図である。 本発明の一実施形態に従って適応符号短縮のプロセスを例示している流れ図である。 本発明の一実施形態に従って符号レートを調整するプロセスを例示している流れ図である。
(システム概要)
図1は、本発明の一実施形態に従ってデータを適応して符号化するストレージシステム120を例示している。図示されているように、ストレージシステム120(例えば、ハイブリッドハードディスク、ソリッドステートドライブなど)は、コントローラ130およびブロック「A」142からブロック「N」までを含むストレージの一つ以上のブロックからなる不揮発性メモリアレイ140を含む。各ブロックは、複数のフラッシュページ(Fページ)を含む。例えば、図1のブロックA142は、FページA143、BからNまでとされる複数のFページを含む。一部の実施形態において、各「Fページ」は、単一の演算(運用)または一ユニットとしてプログラムされ得る不揮発性メモリアレイ140におけるメモリセルの最も小さいグループ化されたものである。さらに、各Fページは、複数の誤り訂正符号ページ(Eページ)を含む。例示の実施形態において、各Fページは、4つのボックスとして例示するEページ144を含む4つのEページを有する。他の実施形態としては、異なって定められる、あるいは4つのEページよりも多くまたは少なく含むことができるFページまたはEページを使用する場合がある。
コントローラ130は、ホストシステム110におけるストレージインタフェースモジュール112(例えば、デバイスドライバ)から、データおよび/またはストレージアクセス命令を受け取ることができる。ストレージインタフェース112によって伝達されるストレージアクセス命令は、ホストシステム110が発する書き込みおよび読み込み命令を含むことができる。命令はストレージシステム120の論理ブロックアドレスを特定することができ、コントローラ130は、不揮発性メモリアレイ140の受け取った命令を実行することができる。ハイブリッドハードドライブにおいて、データは、不揮発性メモリアレイ140に加えて磁気媒体記憶コンポーネント(図1に図示せず)に保存され得る。
ストレージシステム120がホストシステム110に対してメモリストレージシステムとして作用することができるように、ストレージシステム120はホストシステム110から受け取られるデータを保存することができる。この機能を促進するために、コントローラ130は、論理インタフェースを実装することができる。論理インタフェースは、ストレージシステムメモリをデータが保存され得る一連の論理アドレス(例えば、隣接するアドレス)としてホストシステム110に提示することができる。内部的には、コントローラ130は、論理アドレスを不揮発性メモリアレイ140および/または他のメモリモジュールにおける様々な物理メモリアドレスにマップすることができる。
コントローラ130は、コーダーモジュール132を含む。一実施形態において、コーダーモジュール132は、不揮発性メモリアレイ140のメモリページ(例えばEページ)から読み込まれるかまたはそれに書き込まれるデータ(例えば、ユーザデータ)を復号化/符号化するための符号化パラメータを決定する。符号化パラメータは、不揮発性メモリアレイ140から読み出されたユーザデータを復号化するために、不揮発性メモリアレイ140に保存するためのユーザデータを符号化するために、および誤り検出または訂正のような他の用途に使用され得る。符号化パラメータは、LDPC符号化パラメータ(例えばGまたはH符号化マトリクスのカラムのウェイト、GまたはH符号化マトリクスのロウのウェイト、Pマトリクスサイズ(例えば、PマトリクスがGまたはH符号化マトリクスのサブマトリクスである所での)などを、含むことができる。さらに、コーダーモジュール132は、対応するパリティデータおよびパディングを有するユーザデータを復号するのはもちろん、パディングされないまたはパディングされたユーザデータに対してパリティデータを決定することができる。加えて、コーダーモジュール132は、符号化パラメータを調整することによって、符号化データに対して符号またはパリティレートを調整することができる。コントローラ130および/またはコーダーモジュール132は、一つ以上の適切なメモリタイプの内部メモリ(図示せず)をさらに含むことができる。
不揮発性メモリアレイ140は、NANDフラッシュメモリデバイスを使用して実装され得る。フラッシュ集積回路のアレイ、カルコゲナイドRAM(C―RAM)、相変化メモリ(PC―RAMまたはPRAM)、プログラムメタライゼーションセルRAM(PMC―RAMまたはPMCm)、オボニックユニファイドメモリ(OUM)、抵抗変化型RAM(RRAM(登録商標))、NORメモリ、EEPROM、強誘電体メモリ(FeRAM)、磁気抵抗メモリ(MRAM)、他のディスクリートNVM(不揮発性メモリ)チップまたはそれらのあらゆる組み合わせ等の、他のタイプのソリッドステートメモリデバイスが選択的に使用され得る。一実施形態において、不揮発性メモリアレイ140は、シングルビットの情報よりも多くの情報を記憶できるマルチレベルセル(MLC)デバイスを含むことがより好ましい。とはいえ、シングルレベルセル(SLC)メモリデバイスまたはSLCとMLCデバイスの組合せが使用される場合がある。一実施形態において、ストレージシステム120は、他のメモリモジュール(例えば一つ以上の磁気メモリモジュール)を含むことができる。ストレージシステム120は、磁気ストレージなど他のタイプの記憶媒体をさらに含むことができる。
(適応データ符号化)
図2は、本発明の一実施形態に従って符号化データ用の符号化パラメータを決定するプロセス200を例示している流れ図である。プロセス200は、コントローラ130および/またはコーダーモジュール132によって実行され得る。好都合に、プロセス200は、複数の符号語長を使用している複数の不揮発性メモリページフォーマットをサポートするために、コントローラ130および/またはコーダーモジュール132を有効にすることができる。
ブロック205において、プロセス200は、不揮発性メモリアレイ(例えば不揮発性メモリアレイ140)に対してメモリページサイズを決定する。メモリページサイズは、例えば、メモリアレイメーカー(販売業者)によって与えられるかまたは他の周知のメモリサイズに基づいて算出され得る。例えば、メモリページサイズは、不揮発性メモリアレイのEページサイズに対応し、プロセス200は、メーカー(販売業者)が提供するメモリアレイのFページサイズを検索し、不揮発性メモリアレイに対して、例えば4または8の適切な定数によってFページサイズを分割することによって、Eページサイズを算出することができる。他の実施形態では、メモリページサイズは、Fページサイズに対応することができる。
ブロック210において、プロセス200は、複数の符号語長から、メモリページサイズに等しいかまたはメモリページサイズを超える符号語長を選択する。例えば、メモリページサイズは2164バイトまたはオクテットであり得、複数の定義済み符号語長は2176バイトおよび2304バイトの長さを含むことができる。一実施形態において、プロセス200は、複数の定義済みLDPC符号語長からメモリページサイズ以上のデータの最小限のサイズまたはバイト数を有するLDPC符号語長を選択する。例えば、プロセス200は、2164バイトのメモリページサイズを超えて、複数の定義済みLDPC符号語長の最小限のサイズを有する2176バイトの符号語長を選択することができる。
ブロック215において、プロセス200は、選択された符号語長に少なくとも部分的に基づいて符号化パラメータを決定する。データに対して符号レート(例えば、ユーザデータおよびパリティデータを含む、データユニットの全体のデータごとのユーザデータの量)を管理するために、符号化データが不揮発性メモリから読み込まれ、または不揮発性メモリに書き込まれ、プロセス200を有効にする際に、符号化パラメータが使用され得る。一実施形態において、LDPC符号語長のための符号化パラメータは、カラムのウェイト、Pマトリクスサイズおよびロウのウェイトを含むとともに、符号レート、ユーザデータの量およびパリティデータの量の少なくとも一つをさらに含む。
ブロック220において、プロセス200は、符号化パラメータを保存する。例えば、プロセス200は、符号化パラメータを、不揮発性メモリアレイ140および/またはストレージシステム120の一つ以上の他の記憶媒体に保存することができる。プロセス200は、符号化パラメータを、コントローラ130および/またはコーダーモジュール132の内部メモリに保存することができる。保存された符号化パラメータは、異なるページ、ブロックあるいは不揮発性メモリアレイ140の他の区分および/または再分割区分の符号化のために、そして、不揮発性メモリアレイの部分が古くなりおよび/または消耗するにつれて、時間とともに符号化パラメータをトラッキングおよび調整するために、異なる符号化パラメータを使用することを促進することができる。
図3は、本発明の一実施形態に従ってLDPC符号化パラメータとLDPC符号語長の関係を例示しているテーブル300である。テーブル300は、LDPC符号語長、および例えばコントローラ130および/またはコーダーモジュール132などのコントローラによってサポートされるLDPC符号化パラメータを指定することができる。テーブル300は、不揮発性メモリアレイ140、ストレージシステム120の一つ以上の他の記憶媒体、および/またはコントローラ130および/またはコーダーモジュール132の内部メモリ、に保存され得る。テーブル300は、サポートする二つのLDPC符号語長を指示している二つの符号長カラムを含む。一つのLDPC符号語長は、2176バイトに等しく(2048+128×1バイト)、他のLDPC符号語長は、2304バイトに等しい(2048+128×2バイト)。2キロバイト辺りの様々な符号レートが複雑さと実行(性能)の間に最適トレードオフを提供することができると発見された。
カラムのウェイト、PマトリクスサイズおよびロウのウェイトのLDPC符号化パラメータは、テーブル300にリストされるような異なる設計の符号レート(例えば、データユニット(全体のデータがユーザデータおよびパリティデータを含む)の全体のデータごとに異なる量のユーザデータ)を使用しているデータの符号化を可能にするために、変化することができる。例えば、LDPC符号語長が2176バイトに等しい場合、適用されるLDPC符号化パラメータは丸で囲ったサークルC1、C2、C3またはC4のLDPC符号化パラメータセットの一つであり得る。一例を挙げると、LDPC符号化パラメータは、サークルC3で選択され得、それはカラムのウェイトが4、Pマトリクスサイズが512、およびロウのウェイトが34であり、さらに0.882の符号レート(2176バイトの総符号長に対して1920バイトのユーザデータ)に対応する。さらに、一実施形態において、2048+128×Δと定義され得る符号長は、Δを1、2、その他として選択することに基づいて調整され得る。例示されるように、Δの値を選択することもまた、符号レートに影響を及ぼす。例えば、サークルC1で、Δに1を選択することは、結果として0.941の符号レートになり、カラムのウェイト、Pマトリクスサイズおよびロウのウェイトが不変のままである場合、Δに2を選択することは、結果として0.944の符号レートになる。さらに説明されるように、様々な定義済み符号レートは、異なるページサイズのメモリアレイを収容するために用いることができる。例えば、図示のように、2176および2304バイトの二つの符号長は2176および2304バイトのページサイズに適合することができる。実際には、定義済み符号長の数は、様々なページサイズに適合するために2よりはるかに高くなり得る点に留意する必要がある。
テーブル300のLDPC符号化パラメータをサポートしているコントローラは、有利に不揮発性メモリアレイに対して一つの符号長を選択することができ、異なる符号レートでLDPC符号化パラメータを符号データに適合させることができる。例えば、2176バイトのEページサイズを有するメモリアレイが比較的新規(例えば、あまり使われていない)で、および/またはほとんど符号化エラーを経験しないか提示しない場合に、サークルC1でのLDPC符号化パラメータが符号化データのために選択され得る。サークルC1においてLDPC符号化パラメータは、カラムのウェイトが4、Pマトリクスサイズが256、ロウのウェイトが68、そして、さらに0.941の符号レートに対応する。サークルC1で2048バイトのデータを符号化するために、合計128バイトのパリティが、使用され得る。メモリアレイのメモリページ、ブロックまたはダイが古くなりおよび/または消耗するにつれて、サークルC2、C3およびC4のLDPC符号化パラメータは、符号化データのためにその代わりに選択され得る。従って、コントローラは、不揮発性メモリアレイの質の変化(例えば、質の劣化)に応じて、それぞれ、サークルC2、C3およびC4でユニットデータにつき0.941の符号レートから0.926、0.882および0.853の符号レートまでパリティの量を段階的に増加させることができる。
(適応符号短縮)
本発明の一部の実施形態は、適応符号短縮を使って、必ずしも定義済み符号長とマッチしないページサイズを、メモリアレイに適応することができる。図4A−4Cは、本発明の一実施形態例に従ってパディングされたユーザデータおよび短縮している適応符号で使用されるパリティデータを例示している略図である。図4A−4Cは、特にメモリに不揮発性メモリアレイに対してメモリページサイズとマッチする符号語長を適応させるために、符号短縮がどのように使用され得るかについて、説明する。好都合に、符号短縮は、メモリページサイズが複数の定義済み符号語長のいかなる符号語長にも等しくないメモリページフォーマットをサポートするために、コントローラ130および/またはコーダーモジュール132を有効にすることができる。例えば、コントローラ130および/またはコーダーモジュール132が2176および2304バイトに等しい定義済みLDPC符号語長をサポートする場合、コントローラ130および/またはコーダーモジュール132が、2164バイトのメモリページサイズをさらにサポートするように、符号短縮が用いられ得る。さらに、符号短縮は、多大なビット誤り率性能を犠牲にすることのない不揮発性メモリアレイフォーマットに合うような適応符号データにするコントローラ130および/またはコーダーモジュール132を可能にする。
一実施形態において、符号短縮は、3つの運用からなる。第一に、パディングデータは、符号化されるユーザデータに加えられる。一実施形態においてパディングデータは、定義済み符号長とメモリページサイズ間の差であるために、サイズ指定される。第2に、パディングおよびユーザデータに基づいてパリティデータが生成される。第3に、ユーザデータおよびパリティデータ(合計するとメモリページサイズ)は、メモリページに保存される。パディングデータは、保存されなくて、復号(例えば、ユーザデータおよびパリティデータがあとでメモリページから読み出されるとき)で、ユーザデータに追加される。
図4Aは、データユニット400aのパディング410およびユーザデータ420を例示している。ユーザデータ420は、データユニット400aに対してユーザデータの量に対応し、パディング410は符号短縮を容易にするパディングに対応する。パディング410は、全てが0(ゼロ)、全てが1、等々、またはあらゆる周知または定義済みデータパターンのデータセットを含むことができる。前の段落の例に引き続き、不揮発性メモリアレイに対してメモリページサイズが2164バイトである場合、コントローラ130および/またはコーダーモジュール132は、例えば、2164バイト以上のサイズを有する最も短いLDPC符号語長など様々な定義済み符号長から選択することができる。この場合、2176バイトの符号長が選択される。コントローラ130および/またはコーダーモジュール132は、パディング410が、符号語長(2176)と不揮発性メモリアレイのメモリページサイズ(2164)の差またはパディングデータの2176−2164=12バイトに等しい長さを有するデータセットを含まなければならないと、決定することができる。データユニット400aのためのLDPC符号化パラメータに応じて、コントローラ130および/またはコーダーモジュール132は、ユーザデータ420およびパリティデータを決定および/または生成するための適切なG符号化マトリクスに確保されているバイトの量をさらに決定することができる。
図4Bは、一実施形態に従って符号化プロセスを例示しており、実際において、ユーザデータ420は、複合化ユーザデータおよびパディングが、選ばれた定義済み符号長のユーザデータのために確保されているバイトの量を満たすように、パディングされる。その後、データユニット400bの複合化パディング410およびユーザデータ420用にパリティ430が生成される。前の段落の例に引き続き、適切なG符号化マトリクスは、パリティ430用のLDPCパリティデータを決定するために利用され得る。上記の通りに、パディング410、ユーザデータ420とパリティデータ430間の2176バイトの実際の配分が変わることがある点に注意する。以下のテーブルにおいて、可能な設定(バイトで表す全サイズ)の一部を例示する:
図4Cはデータユニット400cを例示しており、パディング410の取り除かれたデータユニット400bのユーザデータ420およびパリティ430を有する。ユーザデータ420およびパリティ430は、不揮発性メモリアレイ140のメモリページに書き込まれ得、その後、不揮発性メモリアレイ140のメモリページから読むことができる。上の表に示すように、ユーザデータ420およびパリティデータ430の量は不揮発性メモリアレイのメモリページサイズに等しくなり得、パディングデータはページに書き込まれない。ページが後で読み出されるときに、復号の一部として、ページから読まれるユーザデータに戻って、パディングが付加される。このように、任意のページサイズのための符号化は、符号化効率の小さい損失を犠牲にして複数の定義済み符号語長の一つを用いて行える。
図5は、本発明の一実施形態に従って適応符号短縮のプロセス500を例示している流れ図である。プロセス500は、コントローラ130および/またはコーダーモジュール132によって実行され得る。好都合に、プロセス500は、コントローラ130および/またはコーダーモジュール132によってサポートされる複数の定義済み符号語長のいかなる符号語長にも等しくないメモリページサイズをサポートするために、コントローラ130および/またはコーダーモジュール132を有効にすることができる。プロセス500は、図4A−4Cに表されるデータユニット400a、400bおよび400cを構成し、管理するために用いられ得る。ブロック505において、プロセス500は、ユーザデータを受け取る。ユーザデータは、例えば不揮発性メモリアレイ140などの不揮発性メモリにユーザデータを書き込むための、書き込み命令と併せてストレージインタフェースモジュール112から受け取られ得る。
ブロック510において、プロセス500は、パディングデータでユーザデータをパディングする。パディングデータは、全てが0(ゼロ)、全てが1、あるいは周知または定義済みデータパターンのデータセットを含むことができ、加えて、ブロック510において、プロセス500は、対応する符号化パラメータに依存するデータユニットごとのユーザの量に等しいサイズを有するユニットにユーザデータをさらに分けることができる。例えば、不揮発性メモリアレイが2164バイトに等しいメモリページサイズを有し、LDPC符号化パラメータが図3のサークルC3でのパラメータに対応する場合、ユーザデータは1908バイトに等しいサイズを有するユニットに分割され得る。
ブロック515において、プロセス500は、パディングされたユーザデータに対して符号化パラメータを用いて、パリティデータを決定する。前の段落の例に引き続き、LDPC符号化パラメータがサークルC3でのパラメータに対応する場合、パディングされたユーザデータに対してLDPCパリティデータを決定するために、適切なG符号化マトリクスが選択され使用され得る。
ブロック520において、プロセス500は、ユーザデータおよびパリティデータを出力する。例えば、プロセス500は、ストレージのためのユーザデータおよびパリティデータを、不揮発性メモリアレイ140のFページ143のEページ144に出力することができる。ブロック510および515について示されているパディングは、パディングそれ自体がメモリページに書き込まれ得ないことから、「仮想パディング」として特徴付けることができる。
(符号レート調整)
図6は、本発明の一実施形態に従って符号レートを調整するプロセス600を例示している流れ図である。プロセス600は、コントローラ130および/またはコーダーモジュール132によって実行され得る。好都合に、プロセス600は、不揮発性メモリアレイのメモリページ、ブロックまたは他の区分が消耗および/または品質の低下を経験するので、不揮発性メモリアレイのメモリページ、ブロックまたは他の区分の符号レート(例えば、ユニットデータごとのパリティの量)を調整するために、コントローラ130および/またはコーダーモジュール132を有効にすることができる。
ブロック605において、プロセス600は、メモリページに保存されたユーザデータおよびパリティデータを読み込む。例えば、プロセス600は、ホストシステム110からの読取命令に応答してFページ143の読み出しを実行することができる。
ブロック610において、パリティデータおよび符号化パラメータを用いてユーザデータを復号する際、プロセス600はいくつかのビット誤りを検出する。例えば、プロセス600は、メモリページに対応する保存されたパリティデータおよびLDPC符号化パラメータを用いてユーザデータを復号する際、いくつかの検出ビット誤りを決定することができる。
ブロック615において、プロセス600は、ビット誤りの数がビット誤り閾値を超えるかどうか、決定する。ビット誤り閾値は、メモリページへの符号化データ用の符号化パラメータに基づいて左右され、変化し得る。例えば、図3のサークルC1でのLDPC符号化パラメータのためのビット誤り閾値は、サークルC2でのLDPC符号化パラメータのためのビット誤り閾値より低くてもよい。プロセス600が、ビット誤りの数がビット誤り閾値を超えないと確定すると、プロセス600は終了する。一方、プロセス600が、ビット誤りの数がビット誤り閾値を超えると確定する場合、プロセス600はブロック620へと移動する。
ブロック620において、プロセス600は、符号化パラメータが符号レートを低下させるように調整され得るかどうか、チェックする。換言すれば、プロセス600は、符号化のためにより多くのパリティデータが使用され得るかどうか決定することができる。一実施形態において、プロセス600は、LDPC符号語長を不変に保つと共に、LDPC符号化パラメータが調整され得るかどうか、決定することができる。例えば、Eページ144が図3のサークルC3でのLDPC符号化パラメータを使用して現在符号化される場合、LDPC符号化パラメータはサークルC4でパラメータに適応させることができる。あるいは、Eページ144が現在サークルC4でのLDPC符号化パラメータを用いて符号化され、テーブル300が唯一の利用できるLDPC符号化パラメータを含む場合、パラメータは低い符号レートにさらに適応させることができない。プロセス600が、符号化パラメータが符号レートを低下させるように調整され得ないと確定する場合、プロセス600は終了する。一方では、プロセス600が、符号化パラメータが符号レートを低下させるように調整され得ると確定する場合、プロセス600はブロック625へ移動する。一実施形態において、符号レートの変化は、ブロックにおけるページが同時に新しい符号レートに切り替えられるブロックレベルで、管理され得る。
ブロック625において、プロセス600は、次の書込み操作に対して符号レートを低下させるために、符号化パラメータを調整し、調整された符号化パラメータを保存する。プロセス600は、調整された符号化パラメータを、不揮発性メモリアレイ140、ストレージシステム120の他のメモリモジュールおよび/またはコントローラ130および/またはコーダーモジュール132の内部メモリに、保存することができる。プロセス600は、不揮発性メモリアレイのメモリページ、ブロックまたは他のレベル区分上のLDPC符号化パラメータの管理を容易にするために、符号レートまたは符号化データ用のLDPC符号化パラメータの指標を保存することができる。調整された符号化パラメータは、さらに、ホストシステム110から受け取られる次の書き込み命令と関連付けられている符号化ユーザデータに対して使用され得る。
(他の変形例)
当業者は、実施形態によっては、他の手段および方法が用いられることができると、理解している。例えば、本書において開示される符号化技術は、LDPC符号の他、例えばターボ符号のような他の反復的な符号に適用することができる。加えて、図3のテーブル300において開示される符号化パラメータおよび他の値が符号化パラメータと符号語長の関係の中でセットされる例示にもかかわらず、他のまたはさらなる符号化関係が使用され得る。テーブル300は、4未満および5を超える値(例えば3または6)を有するカラムのウェイト、256ビット未満または512を超える値(例えば128または1024)を有するPマトリクスサイズ、1未満または2を超える(例えば−1、0、3または4)のΔ値、128バイト以外(例えば64バイト)の対応する粒度(精度)を有するΔ値、および2048より少ないまたは大きい(例えば2176のような)値を有するベース符号長、を含むことができる。さらに、各データユニットにおけるパリティデータの量は、異なる値に設定され得るかまたはストレージ媒体の質に応じて変化され得る。加えて、符号化データに対して符号化パラメータを調整するべきかどうか決定するために、ビット誤りとは異なる良質な評価基準が用いられ得る。そのうえ、実施形態に応じて、上述のステップが取り除かれ、他のものが加えられ得ることを確信している。したがって、現在の開示の範囲は、添付の請求の範囲の参照によってのみ定められることを意図する。
特定の実施形態が記載されると共に、これらの実施形態は、ほんの一例として示され、保護の範囲を制限することを意図しない。実際、本書において記載されている新規な方法およびシステムは、様々な他の形で具体化され得る。さらにまた、本書において記載されている方法およびシステムの形の様々な省略、置換えおよび変更は、保護の趣旨を逸脱しない範囲でなされることが可能である。添付の請求の範囲およびそれらの等価物は、保護の範囲および趣旨に入るような形または修正をカバーすることを意図する。例えば、本書において開示されるシステム及び方法は、ハードディスクドライブ、ハイブリッドハードドライブおよび同類のものに適用され得る。加えて、ストレージの他の形(例えば、DRAMまたはSRAM、バッテリバックアップされた揮発性のDRAMまたはSRAMデバイス、EPROM、EEPROMのメモリ等々)が、さらに、または、代わりに用いられ得る。別の例として、図に例示した各種コンポーネントは、プロセッサ、ASIC/FPGAまたは専用ハードウェア上のソフトウェアおよび/またはファームウェアとして実施され得る。また、上記開示される特定の実施形態の特徴および属性は、付加的な実施形態を形成する異なる手段に組み込まれ得、その全ては現在の開示の範囲内になる。現在の開示が特定の好ましい実施形態および適用を提供するにもかかわらず、本書において記載される特徴および効果の全てを提供するというわけではない実施形態を含んで、当業者にとって明らかである他の実施形態はこの開示の範囲内でもある。したがって、現在の開示の範囲は、添付の請求の範囲を参照することでのみ定められることを意図する。

Claims (13)

  1. 共通のメモリページサイズを有する各メモリページからなる複数のメモリページを含む不揮発性メモリアレイと、
    コントローラであって、
    前記不揮発性メモリアレイに対して前記共通のメモリページサイズを決定し、
    低密度パリティチェック(LDPC)符号語長を、前記不揮発性メモリアレイに対して前記共通のメモリページサイズ以上のサイズを有する複数の定義済みLDPC符号語長から選択し、
    少なくとも部分的に前記LDPC符号語長に基づいて前記不揮発性メモリアレイの一つ以上のメモリページに書き込まれる、または前記不揮発性メモリアレイの一つ以上のメモリページから読み込まれる符号化データ用のLDPC符号化パラメータを決定するように構成され、前記複数の定義済みLDPC符号語長を使用している前記複数の不揮発性メモリページフォーマットをサポートし、前記共通のメモリページサイズが前記複数の定義済みLDPC符号語長のいかなるLDPC符号語長にも等しくないメモリページフォーマットをサポートするように構成される、
    コントローラと、
    を含むソリッドステートストレージシステム。
  2. 前記LDPC符号化パラメータは、Pマトリクスサイズ、カラムのウェイトおよびロウのウェイトを含み、さらに、符号レート、ユーザデータの量、およびパリティデータの量の少なくとも一つを含む、請求項1に記載のソリッドステートストレージシステム。
  3. 前記コントローラは、前記不揮発性メモリアレイに対して前記共通のメモリページサイズ以上の最小限のサイズを有するLDPC符号語長を選択するように構成される、請求項1に記載のソリッドステートストレージシステム。
  4. 前記メモリページは、誤り訂正符号ページ(Eページ)を含む、請求項1に記載のソリッドステートストレージシステム。
  5. 前記コントローラは、前記LDPC符号化パラメータを使用している、ユーザデータおよびパディングデータを含むパディングされたユーザデータに対してパリティデータを決定し、かつ、
    前記ユーザデータおよび前記パリティデータを前記不揮発性メモリアレイのメモリページに保存するように、さらに構成される、請求項1に記載のソリッドステートストレージシステム。
  6. 前記パディングされたユーザデータのパディングデータの量は、前記LDPC符号語長と前記不揮発性メモリアレイのための前記共通のメモリページサイズとの差に少なくとも部分的に依存する、請求項5に記載のソリッドステートストレージシステム。
  7. コントローラを含むデータストレージシステムにおける、データの符号化の方法であって、
    各メモリページが共通のメモリページサイズを有する複数のメモリページを含む不揮発性メモリアレイに対して共通のメモリページサイズを決定するステップと、
    低密度パリティチェック(LDPC)符号語長を、前記不揮発性メモリアレイに対して前記共通のメモリページサイズ以上のサイズを有する複数の定義済みLDPC符号語長から選択するステップと、
    少なくとも部分的に前記LDPC符号語長に基づいて前記不揮発性メモリアレイの一つ以上のメモリページに書き込まれる、または前記不揮発性メモリアレイの一つ以上のメモリページから読み込まれる符号化データ用のLDPC符号化パラメータを決定するステップと、
    を含む方法。
  8. 前記LDPC符号化パラメータは、Pマトリクスサイズ、カラムのウェイトおよびロウのウェイトを含み、さらに、符号レート、ユーザデータの量、およびパリティデータの量の少なくとも一つを含む、請求項7に記載の方法。
  9. 前記LDPC符号語長を選択するステップは、前記不揮発性メモリアレイに対して前記共通のメモリページサイズ以上の最小限のサイズを有するLDPC符号語長を選択することを含む、請求項7に記載の方法。
  10. 前記メモリページは、誤り訂正符号ページ(Eページ)を含む請求項7に記載の方法。
  11. 前記LDPC符号化パラメータを使用している、ユーザデータおよびパディングデータを含むパディングされたユーザデータに対してパリティデータを決定するステップと、
    前記ユーザデータおよび前記パリティデータを前記不揮発性メモリアレイのメモリページに保存するステップと、
    をさらに含む請求項7に記載の方法。
  12. 前記パディングされたユーザデータのパディングデータの量は、前記LDPC符号語長と前記不揮発性メモリアレイのための前記共通のメモリページサイズとの差に少なくとも部分的に依存する、請求項11に記載の方法。
  13. 共通のメモリページサイズを有する各メモリページからなる複数のメモリページを含む不揮発性メモリアレイと、
    コントローラであって、
    前記不揮発性メモリアレイに対して前記共通のメモリページサイズを決定し、
    符号語長を、前記不揮発性メモリアレイに対して前記共通のメモリページサイズ以上のサイズを有する複数の定義済み符号語長から選択し、
    少なくとも部分的に前記符号語長に基づいて前記不揮発性メモリアレイの一つ以上のメモリページに書き込まれる、または前記不揮発性メモリアレイの一つ以上のメモリページから読み込まれる符号化データ用の符号化パラメータを決定し、前記複数の定義済み符号語長を使用している前記複数の不揮発性メモリページフォーマットをサポートするように構成されるコントローラと、
    を含むソリッドステートストレージシステム。
JP2015539605A 2012-10-24 2013-09-23 データストレージシステムのための適応誤り訂正符号 Expired - Fee Related JP6129328B2 (ja)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US13/659,099 US8972826B2 (en) 2012-10-24 2012-10-24 Adaptive error correction codes for data storage systems
US13/659,099 2012-10-24
PCT/US2013/061249 WO2014065967A1 (en) 2012-10-24 2013-09-23 Adaptive error correction codes for data storage systems

Publications (3)

Publication Number Publication Date
JP2015534409A true JP2015534409A (ja) 2015-11-26
JP2015534409A5 JP2015534409A5 (ja) 2017-01-26
JP6129328B2 JP6129328B2 (ja) 2017-05-17

Family

ID=50486506

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2015539605A Expired - Fee Related JP6129328B2 (ja) 2012-10-24 2013-09-23 データストレージシステムのための適応誤り訂正符号

Country Status (7)

Country Link
US (2) US8972826B2 (ja)
EP (1) EP2912667A4 (ja)
JP (1) JP6129328B2 (ja)
KR (1) KR101927575B1 (ja)
CN (1) CN104871249B (ja)
HK (1) HK1214401A1 (ja)
WO (1) WO2014065967A1 (ja)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2018045744A (ja) * 2016-09-14 2018-03-22 東芝メモリ株式会社 メモリシステムおよび方法
JP2019009776A (ja) * 2017-06-14 2019-01-17 ランディグラッド, リミテッド ライアビリティー カンパニーLANDIGRAD, Limited Liability Company 情報の符号化及び復号化の諸法

Families Citing this family (136)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9176859B2 (en) 2009-01-07 2015-11-03 Siliconsystems, Inc. Systems and methods for improving the performance of non-volatile memory operations
US10079048B2 (en) 2009-03-24 2018-09-18 Western Digital Technologies, Inc. Adjusting access of non-volatile semiconductor memory based on access time
US9317717B2 (en) 2012-12-28 2016-04-19 Open Invention Network, Llc Separate cryptographic keys for protecting different operations on data
US9753847B2 (en) 2009-10-27 2017-09-05 Western Digital Technologies, Inc. Non-volatile semiconductor memory segregating sequential, random, and system data to reduce garbage collection for page based mapping
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
US8959284B1 (en) 2010-06-28 2015-02-17 Western Digital Technologies, Inc. Disk drive steering write data to write cache based on workload
US9058280B1 (en) 2010-08-13 2015-06-16 Western Digital Technologies, Inc. Hybrid drive migrating data from disk to non-volatile semiconductor memory based on accumulated access time
US8769190B1 (en) 2010-09-15 2014-07-01 Western Digital Technologies, Inc. System and method for reducing contentions in solid-state memory access
US8788779B1 (en) 2010-09-17 2014-07-22 Western Digital Technologies, Inc. Non-volatile storage subsystem with energy-based performance throttling
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
US9069475B1 (en) 2010-10-26 2015-06-30 Western Digital Technologies, Inc. Hybrid drive selectively spinning up disk when powered on
US8700950B1 (en) 2011-02-11 2014-04-15 Western Digital Technologies, Inc. System and method for data error recovery in a solid state subsystem
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
US9361044B2 (en) 2011-03-28 2016-06-07 Western Digital Technologies, Inc. Power-safe data management system
US8898373B1 (en) 2011-06-29 2014-11-25 Western Digital Technologies, Inc. System and method for improving wear-leveling performance in solid-state memory
US9195530B1 (en) 2011-09-06 2015-11-24 Western Digital Technologies, Inc. Systems and methods for improved data management in data storage systems
US8700834B2 (en) 2011-09-06 2014-04-15 Western Digital Technologies, Inc. Systems and methods for an enhanced controller architecture in data storage systems
US8707104B1 (en) 2011-09-06 2014-04-22 Western Digital Technologies, Inc. Systems and methods for error injection in data storage systems
US8713357B1 (en) 2011-09-06 2014-04-29 Western Digital Technologies, Inc. Systems and methods for detailed error reporting in data storage systems
US9268701B1 (en) 2011-11-21 2016-02-23 Western Digital Technologies, Inc. Caching of data in data storage systems by managing the size of read and write cache based on a measurement of cache reliability
US8977804B1 (en) 2011-11-21 2015-03-10 Western Digital Technologies, Inc. Varying data redundancy in storage systems
US8959416B1 (en) 2011-12-16 2015-02-17 Western Digital Technologies, Inc. Memory defect management using signature identification
US9348741B1 (en) 2011-12-19 2016-05-24 Western Digital Technologies, Inc. Systems and methods for handling write data access requests in data storage devices
US9053008B1 (en) 2012-03-26 2015-06-09 Western Digital Technologies, Inc. Systems and methods for providing inline parameter service in data storage devices
US8984247B1 (en) 2012-05-10 2015-03-17 Western Digital Technologies, Inc. Storing and reconstructing mapping table data in a data storage system
US8966205B1 (en) 2012-05-10 2015-02-24 Western Digital Technologies, Inc. System data management using garbage collection and hybrid self mapping
US9977612B1 (en) 2012-05-11 2018-05-22 Western Digital Technologies, Inc. System data management using garbage collection and logs
US9170932B1 (en) 2012-05-22 2015-10-27 Western Digital Technologies, Inc. System data storage mechanism providing coherency and segmented data loading
US8924832B1 (en) 2012-06-26 2014-12-30 Western Digital Technologies, Inc. Efficient error handling mechanisms in data storage systems
US8954653B1 (en) 2012-06-26 2015-02-10 Western Digital Technologies, Inc. Mechanisms for efficient management of system data in data storage systems
US8966343B2 (en) 2012-08-21 2015-02-24 Western Digital Technologies, Inc. Solid-state drive retention monitor using reference blocks
US9507523B1 (en) 2012-10-12 2016-11-29 Western Digital Technologies, Inc. Methods, devices and systems for variable size logical page management in a solid state drive
US9489296B1 (en) 2012-10-17 2016-11-08 Western Digital Technologies, Inc. Methods, devices and systems for hardware-based garbage collection in solid state drives
US8972826B2 (en) 2012-10-24 2015-03-03 Western Digital Technologies, Inc. Adaptive error correction codes for data storage systems
US9177638B2 (en) 2012-11-13 2015-11-03 Western Digital Technologies, Inc. Methods and devices for avoiding lower page corruption in data storage devices
US8954694B2 (en) 2012-11-15 2015-02-10 Western Digital Technologies, Inc. Methods, data storage devices and systems for fragmented firmware table rebuild in a solid state drive
US9021339B2 (en) 2012-11-29 2015-04-28 Western Digital Technologies, Inc. Data reliability schemes for data storage systems
US9059736B2 (en) 2012-12-03 2015-06-16 Western Digital Technologies, Inc. Methods, solid state drive controllers and data storage devices having a runtime variable raid protection scheme
US9032271B2 (en) 2012-12-07 2015-05-12 Western Digital Technologies, Inc. System and method for lower page data recovery in a solid state drive
US8966339B1 (en) 2012-12-18 2015-02-24 Western Digital Technologies, Inc. Decoder supporting multiple code rates and code lengths for data storage systems
US9619317B1 (en) 2012-12-18 2017-04-11 Western Digital Technologies, Inc. Decoder having early decoding termination detection
US9122625B1 (en) 2012-12-18 2015-09-01 Western Digital Technologies, Inc. Error correcting code encoder supporting multiple code rates and throughput speeds for data storage systems
US9214963B1 (en) 2012-12-21 2015-12-15 Western Digital Technologies, Inc. Method and system for monitoring data channel to enable use of dynamically adjustable LDPC coding parameters in a data storage system
US8954655B2 (en) 2013-01-14 2015-02-10 Western Digital Technologies, Inc. Systems and methods of configuring a mode of operation in a solid-state memory
US8972655B2 (en) 2013-01-21 2015-03-03 Western Digital Technolgies, Inc. Initialization of a storage device
US9274966B1 (en) 2013-02-20 2016-03-01 Western Digital Technologies, Inc. Dynamically throttling host commands to disk drives
US9454474B2 (en) 2013-03-05 2016-09-27 Western Digital Technologies, Inc. Methods, devices and systems for two stage power-on map rebuild with free space accounting in a solid state drive
US9641378B1 (en) 2013-03-12 2017-05-02 Western Digital Technologies, Inc. Adjustment of compression ratios for data storage
US8924824B1 (en) 2013-03-12 2014-12-30 Western Digital Technologies, Inc. Soft-decision input generation for data storage systems
US9280472B1 (en) 2013-03-13 2016-03-08 Western Digital Technologies, Inc. Caching data in a high performance zone of a data storage system
US8990668B2 (en) 2013-03-14 2015-03-24 Western Digital Technologies, Inc. Decoding data stored in solid-state memory
US9059742B1 (en) 2013-03-15 2015-06-16 Western Digital Technologies, Inc. System and method for dynamic scaling of LDPC decoder in a solid state drive
US9448738B2 (en) 2013-03-15 2016-09-20 Western Digital Technologies, Inc. Compression and formatting of data for data storage systems
US9218279B2 (en) 2013-03-15 2015-12-22 Western Digital Technologies, Inc. Atomic write command support in a solid state drive
US9335950B2 (en) 2013-03-15 2016-05-10 Western Digital Technologies, Inc. Multiple stream compression and formatting of data for data storage systems
US9013920B2 (en) 2013-04-03 2015-04-21 Western Digital Technologies, Inc. Systems and methods of write precompensation to extend life of a solid-state memory
US9123686B2 (en) 2013-04-12 2015-09-01 Western Digital Technologies, Inc. Thermal management for solid-state drive
US9338927B2 (en) 2013-05-02 2016-05-10 Western Digital Technologies, Inc. Thermal interface material pad and method of forming the same
US9195293B1 (en) 2013-05-03 2015-11-24 Western Digital Technologies, Inc. User controlled data storage device power and performance settings
US9081700B2 (en) 2013-05-16 2015-07-14 Western Digital Technologies, Inc. High performance read-modify-write system providing line-rate merging of dataframe segments in hardware
US9632926B1 (en) 2013-05-16 2017-04-25 Western Digital Technologies, Inc. Memory unit assignment and selection for internal memory operations in data storage systems
US9170938B1 (en) 2013-05-17 2015-10-27 Western Digital Technologies, Inc. Method and system for atomically writing scattered information in a solid state storage device
US9280200B1 (en) 2013-05-20 2016-03-08 Western Digital Technologies, Inc. Automatic peak current throttle of tiered storage elements
US9740248B2 (en) 2013-06-07 2017-08-22 Western Digital Technologies, Inc. Component placement within a solid state drive
US9274978B2 (en) 2013-06-10 2016-03-01 Western Digital Technologies, Inc. Migration of encrypted data for data storage systems
US9436630B2 (en) 2013-06-11 2016-09-06 Western Digital Technologies, Inc. Using dual phys to support multiple PCIe link widths
US9830257B1 (en) 2013-06-12 2017-11-28 Western Digital Technologies, Inc. Fast saving of data during power interruption in data storage systems
US9665501B1 (en) 2013-06-18 2017-05-30 Western Digital Technologies, Inc. Self-encrypting data storage device supporting object-level encryption
US9304560B2 (en) 2013-06-19 2016-04-05 Western Digital Technologies, Inc. Backup power for reducing host current transients
US9208101B2 (en) 2013-06-26 2015-12-08 Western Digital Technologies, Inc. Virtual NAND capacity extension in a hybrid drive
US9583153B1 (en) 2013-06-28 2017-02-28 Western Digital Technologies, Inc. Memory card placement within a solid state drive
US9042197B2 (en) 2013-07-23 2015-05-26 Western Digital Technologies, Inc. Power fail protection and recovery using low power states in a data storage device/system
US9070379B2 (en) 2013-08-28 2015-06-30 Western Digital Technologies, Inc. Data migration for data storage device
US9442668B1 (en) 2013-08-29 2016-09-13 Western Digital Technologies, Inc. Adaptive power management control with performance feedback
US9263136B1 (en) 2013-09-04 2016-02-16 Western Digital Technologies, Inc. Data retention flags in solid-state drives
US9304709B2 (en) 2013-09-06 2016-04-05 Western Digital Technologies, Inc. High performance system providing selective merging of dataframe segments in hardware
US10444998B1 (en) 2013-10-24 2019-10-15 Western Digital Technologies, Inc. Data storage device providing data maintenance services
US9007841B1 (en) 2013-10-24 2015-04-14 Western Digital Technologies, Inc. Programming scheme for improved voltage distribution in solid-state memory
US9330143B2 (en) 2013-10-24 2016-05-03 Western Digital Technologies, Inc. Data storage device supporting accelerated database operations
US9323467B2 (en) 2013-10-29 2016-04-26 Western Digital Technologies, Inc. Data storage device startup
US9286176B1 (en) 2013-11-08 2016-03-15 Western Digital Technologies, Inc. Selective skipping of blocks in an SSD
US9270296B1 (en) 2013-11-13 2016-02-23 Western Digital Technologies, Inc. Method and system for soft decoding through single read
US9529710B1 (en) 2013-12-06 2016-12-27 Western Digital Technologies, Inc. Interleaved channels in a solid-state drive
US9007854B1 (en) 2013-12-09 2015-04-14 Western Digital Technologies, Inc. Method and system for optimized soft decoding in a data storage device
US10140067B1 (en) 2013-12-19 2018-11-27 Western Digital Technologies, Inc. Data management for data storage device with multiple types of non-volatile memory media
US9036283B1 (en) 2014-01-22 2015-05-19 Western Digital Technologies, Inc. Data storage device with selective write to a first storage media or a second storage media
US9337864B1 (en) 2014-01-29 2016-05-10 Western Digital Technologies, Inc. Non-binary LDPC decoder using binary subgroup processing
US9250994B1 (en) 2014-02-05 2016-02-02 Western Digital Technologies, Inc. Non-binary low-density parity check (LDPC) decoding using trellis maximization
US9384088B1 (en) 2014-02-24 2016-07-05 Western Digital Technologies, Inc. Double writing map table entries in a data storage system to guard against silent corruption
US9354955B1 (en) 2014-03-19 2016-05-31 Western Digital Technologies, Inc. Partial garbage collection for fast error handling and optimized garbage collection for the invisible band
US9268487B2 (en) 2014-03-24 2016-02-23 Western Digital Technologies, Inc. Method and apparatus for restricting writes to solid state memory when an end-of life condition is reached
US9348520B2 (en) 2014-03-24 2016-05-24 Western Digital Technologies, Inc. Lifetime extension of non-volatile semiconductor memory for data storage device
US9448742B2 (en) 2014-03-27 2016-09-20 Western Digital Technologies, Inc. Communication between a host and a secondary storage device
US9564212B2 (en) 2014-05-06 2017-02-07 Western Digital Technologies, Inc. Solid-state memory corruption mitigation
US9690696B1 (en) 2014-05-14 2017-06-27 Western Digital Technologies, Inc. Lifetime extension of memory for data storage system
US9472222B2 (en) 2014-05-16 2016-10-18 Western Digital Technologies, Inc. Vibration mitigation for a data storage device
TWI550615B (zh) * 2014-08-28 2016-09-21 群聯電子股份有限公司 資料存取方法、記憶體儲存裝置及記憶體控制電路單元
US9275741B1 (en) 2014-09-10 2016-03-01 Western Digital Technologies, Inc. Temperature compensation management in solid-state memory
US9418699B1 (en) 2014-10-09 2016-08-16 Western Digital Technologies, Inc. Management of sequentially written data
US9405356B1 (en) 2014-10-21 2016-08-02 Western Digital Technologies, Inc. Temperature compensation in data storage device
US9823859B2 (en) 2014-11-06 2017-11-21 Western Digital Technologies, Inc. Mechanical shock mitigation for data storage
CN105811996B (zh) * 2014-12-30 2019-12-06 华为技术有限公司 一种基于准循环ldpc的数据处理方法及系统
US9857995B1 (en) 2015-03-09 2018-01-02 Western Digital Technologies, Inc. Data storage device and method providing non-volatile memory buffer for real-time primary non-volatile memory protection
DE102015111729B4 (de) * 2015-07-20 2017-03-30 Infineon Technologies Ag Verfahren und decoder zum bestimmen eines fehlervektors für ein datenwort gemäss einem reed-muller-code
US9785563B1 (en) 2015-08-13 2017-10-10 Western Digital Technologies, Inc. Read command processing for data storage system based on previous writes
JP6542076B2 (ja) * 2015-08-28 2019-07-10 東芝メモリ株式会社 メモリシステム
US9668337B2 (en) 2015-09-08 2017-05-30 Western Digital Technologies, Inc. Temperature management in data storage devices
US9727261B2 (en) 2015-09-24 2017-08-08 Western Digital Technologies, Inc. Weighted programming patterns in solid-state data storage systems
US9836232B1 (en) 2015-09-30 2017-12-05 Western Digital Technologies, Inc. Data storage device and method for using secondary non-volatile memory for temporary metadata storage
US10013174B2 (en) 2015-09-30 2018-07-03 Western Digital Technologies, Inc. Mapping system selection for data storage device
US9620226B1 (en) 2015-10-30 2017-04-11 Western Digital Technologies, Inc. Data retention charge loss and read disturb compensation in solid-state data storage systems
US10056920B1 (en) 2015-11-03 2018-08-21 Western Digital Technologies, Inc. Data storage device encoding and interleaving codewords to improve trellis sequence detection
US10063257B1 (en) 2015-11-03 2018-08-28 Western Digital Technologies, Inc. Data storage device encoding and interleaving codewords to improve trellis sequence detection
US9761273B1 (en) 2015-11-03 2017-09-12 Western Digital Technologies, Inc. Data storage device encoding and interleaving codewords to improve trellis sequence detection
KR102435181B1 (ko) * 2015-11-16 2022-08-23 삼성전자주식회사 반도체 메모리 장치, 이를 포함하는 메모리 시스템 및 메모리 시스템의 동작 방법
US10126981B1 (en) 2015-12-14 2018-11-13 Western Digital Technologies, Inc. Tiered storage using storage class memory
US10223198B2 (en) * 2016-02-18 2019-03-05 Micron Technology, Inc. Error rate reduction
CN107168816B (zh) * 2016-03-07 2021-03-23 北京忆恒创源科技有限公司 Ecc帧长调整方法及其装置
US9904594B2 (en) * 2016-04-15 2018-02-27 Micron Technology, Inc. Monitoring error correction operations performed in memory
US10387303B2 (en) 2016-08-16 2019-08-20 Western Digital Technologies, Inc. Non-volatile storage system with compute engine to accelerate big data applications
US10061691B2 (en) * 2016-09-08 2018-08-28 Toshiba Memory Corporation Write data optimization methods for non-volatile semiconductor memory devices
US10459644B2 (en) 2016-10-28 2019-10-29 Western Digital Techologies, Inc. Non-volatile storage system with integrated compute engine and optimized use of local fast memory
US10574270B1 (en) * 2016-11-09 2020-02-25 Seagate Technology Llc Sector management in drives having multiple modulation coding
US10565123B2 (en) 2017-04-10 2020-02-18 Western Digital Technologies, Inc. Hybrid logical to physical address translation for non-volatile storage devices with integrated compute module
TWI659359B (zh) * 2018-04-27 2019-05-11 慧榮科技股份有限公司 控制儲存裝置之方法
US10897273B2 (en) 2018-06-27 2021-01-19 Western Digital Technologies, Inc. System-level error correction coding allocation based on device population data integrity sharing
US10802908B2 (en) 2018-07-31 2020-10-13 Western Digital Technologies, Inc. Data dependent allocation of error correction resources
US10769062B2 (en) 2018-10-01 2020-09-08 Western Digital Technologies, Inc. Fine granularity translation layer for data storage devices
US10956071B2 (en) 2018-10-01 2021-03-23 Western Digital Technologies, Inc. Container key value store for data storage devices
US10740231B2 (en) 2018-11-20 2020-08-11 Western Digital Technologies, Inc. Data access in data storage device including storage class memory
US11016905B1 (en) 2019-11-13 2021-05-25 Western Digital Technologies, Inc. Storage class memory access
US11249921B2 (en) 2020-05-06 2022-02-15 Western Digital Technologies, Inc. Page modification encoding and caching
CN112256473A (zh) * 2020-10-30 2021-01-22 浪潮云信息技术股份公司 一种分布式存储系统自适应纠错方法
CN116662063B (zh) * 2023-05-10 2024-02-23 珠海妙存科技有限公司 一种闪存的纠错配置方法、纠错方法、系统、设备及介质

Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2004326867A (ja) * 2003-04-22 2004-11-18 Toshiba Corp データ記憶システム
US20050160218A1 (en) * 2004-01-20 2005-07-21 Sun-Teck See Highly integrated mass storage device with an intelligent flash controller
US20100251068A1 (en) * 2009-03-27 2010-09-30 Li-Lien Lin Storage controller with encoding/decoding circuit programmable to support different ecc requirements and related method thereof
US20100315874A1 (en) * 2009-06-15 2010-12-16 Ramin Ghodsi Use of emerging non-volatile memory elements with flash memory
CN102005250A (zh) * 2010-10-27 2011-04-06 记忆科技(深圳)有限公司 准循环低密度奇偶校验码译码器及译码方法
US20110231737A1 (en) * 2010-03-16 2011-09-22 Kenshi Dachiku Data storage apparatus and data writing/reading method
US20110283164A1 (en) * 2010-05-17 2011-11-17 Skymedi Corporation Configurable coding system and method of multiple eccs
US20120079351A1 (en) * 2010-09-24 2012-03-29 International Business Machines Corporation Systems and Methods for Memory Devices
WO2012058328A1 (en) * 2010-10-27 2012-05-03 Sandforce, Inc. Adaptive ecc techniques for flash memory based data storage

Family Cites Families (167)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5499337A (en) 1991-09-27 1996-03-12 Emc Corporation Storage device array architecture with solid-state redundancy unit
US5621660A (en) 1995-04-18 1997-04-15 Sun Microsystems, Inc. Software-based encoder for a software-implemented end-to-end scalable video delivery system
US6011868A (en) 1997-04-04 2000-01-04 Hewlett-Packard Company Bitstream quality analyzer
US6418549B1 (en) * 1998-10-30 2002-07-09 Merunetworks, Inc. Data transmission using arithmetic coding based continuous error detection
US20080282128A1 (en) 1999-08-04 2008-11-13 Super Talent Electronics, Inc. Method of Error Correction Code on Solid State Disk to Gain Data Security and Higher Performance
US8266367B2 (en) 2003-12-02 2012-09-11 Super Talent Electronics, Inc. Multi-level striping and truncation channel-equalization for flash-memory system
US7072417B1 (en) 2000-06-28 2006-07-04 Marvell International Ltd. LDPC encoder and method thereof
US6934904B2 (en) 2001-04-30 2005-08-23 Sun Microsystems, Inc. Data integrity error handling in a redundant storage array
US6895547B2 (en) 2001-07-11 2005-05-17 International Business Machines Corporation Method and apparatus for low density parity check encoding of data
US7149846B2 (en) 2002-04-17 2006-12-12 Lsi Logic Corporation RAID protected external secondary memory
US7702986B2 (en) 2002-11-18 2010-04-20 Qualcomm Incorporated Rate-compatible LDPC codes
US6856556B1 (en) 2003-04-03 2005-02-15 Siliconsystems, Inc. Storage subsystem with embedded circuit for protecting against anomalies in power signal from host
US20090193184A1 (en) 2003-12-02 2009-07-30 Super Talent Electronics Inc. Hybrid 2-Level Mapping Tables for Hybrid Block- and Page-Mode Flash-Memory System
US7395495B2 (en) 2004-01-12 2008-07-01 Intel Corporation Method and apparatus for decoding forward error correction codes
US7260763B2 (en) 2004-03-11 2007-08-21 Nortel Networks Limited Algebraic low-density parity check code design for variable block sizes and code rates
JP3875693B2 (ja) 2004-03-24 2007-01-31 株式会社東芝 Lpc符号を用いた符号化ビットのマッピング方法及び送信装置
CN1947368B (zh) 2004-04-28 2010-06-16 三星电子株式会社 对具有可变块长度的块低密度奇偶校验码编码/解码的设备和方法
US7395490B2 (en) 2004-07-21 2008-07-01 Qualcomm Incorporated LDPC decoding methods and apparatus
US7346832B2 (en) 2004-07-21 2008-03-18 Qualcomm Incorporated LDPC encoding methods and apparatus
US7203897B2 (en) 2004-08-12 2007-04-10 Motorola, Inc. Method and apparatus for encoding and decoding data
US7516391B2 (en) 2004-08-16 2009-04-07 Samsung Electronics Co., Ltd Apparatus and method for coding/decoding block low density parity check code with variable block length
US8131926B2 (en) 2004-10-20 2012-03-06 Seagate Technology, Llc Generic storage container for allocating multiple data formats
US7502256B2 (en) 2004-11-30 2009-03-10 Siliconsystems, Inc. Systems and methods for reducing unauthorized data recovery from solid-state storage devices
KR100641052B1 (ko) 2004-12-08 2006-11-02 한국전자통신연구원 Ldpc 부호기 및 복호기, 및 ldpc 부호화 방법 및복호화 방법
US7500172B2 (en) 2005-02-26 2009-03-03 Broadcom Corporation AMP (accelerated message passing) decoder adapted for LDPC (low density parity check) codes
US7657816B2 (en) 2005-07-13 2010-02-02 Leanics Corporation Low-complexity hybrid LDPC code encoder
KR100732628B1 (ko) 2005-07-28 2007-06-27 삼성전자주식회사 멀티-비트 데이터 및 싱글-비트 데이터를 저장하는 플래시메모리 장치
US7129862B1 (en) 2005-07-29 2006-10-31 Texas Instruments Incorporated Decoding bit streams encoded according to variable length codes
KR100809616B1 (ko) 2005-10-19 2008-03-05 삼성전자주식회사 가변 블록 길이를 가지는 블록 저밀도 패리티 검사 부호부호화/복호 장치 및 방법
US20070124648A1 (en) 2005-10-31 2007-05-31 Ajay Dholakia Data protection method
US7797611B2 (en) 2005-11-14 2010-09-14 International Business Machines Corporation Creating an error correction coding scheme and reducing data loss
US7631246B2 (en) 2006-01-09 2009-12-08 Broadcom Corporation LDPC (low density parity check) code size adjustment by shortening and puncturing
US7774689B2 (en) * 2006-03-17 2010-08-10 Industrial Technology Research Institute Encoding and decoding methods and systems
JP4863749B2 (ja) 2006-03-29 2012-01-25 株式会社日立製作所 フラッシュメモリを用いた記憶装置、その消去回数平準化方法、及び消去回数平準化プログラム
US7653778B2 (en) 2006-05-08 2010-01-26 Siliconsystems, Inc. Systems and methods for measuring the useful life of solid-state storage devices
WO2007132456A2 (en) * 2006-05-12 2007-11-22 Anobit Technologies Ltd. Memory device with adaptive capacity
US7809994B2 (en) 2006-05-17 2010-10-05 Sandisk Corporation Error correction coding for multiple-sector pages in flash memory devices
US8108692B1 (en) 2006-06-27 2012-01-31 Siliconsystems, Inc. Solid-state storage subsystem security solution
US7765373B1 (en) 2006-06-27 2010-07-27 Siliconsystems, Inc. System for controlling use of a solid-state storage subsystem
US7447807B1 (en) 2006-06-30 2008-11-04 Siliconsystems, Inc. Systems and methods for storing data in segments of a storage subsystem
US7509441B1 (en) 2006-06-30 2009-03-24 Siliconsystems, Inc. Systems and methods for segmenting and protecting a storage subsystem
US7739576B2 (en) 2006-08-31 2010-06-15 Micron Technology, Inc. Variable strength ECC
JP4932427B2 (ja) 2006-10-20 2012-05-16 株式会社日立製作所 記憶装置及び記憶方法
US8161227B1 (en) 2006-10-30 2012-04-17 Siliconsystems, Inc. Storage subsystem capable of programming field-programmable devices of a target computer system
US8402201B2 (en) 2006-12-06 2013-03-19 Fusion-Io, Inc. Apparatus, system, and method for storage space recovery in solid-state storage
US8090980B2 (en) 2006-12-08 2012-01-03 Sandforce, Inc. System, method, and computer program product for providing data redundancy in a plurality of storage devices
US8549236B2 (en) 2006-12-15 2013-10-01 Siliconsystems, Inc. Storage subsystem with multiple non-volatile memory arrays to protect against data losses
US7660911B2 (en) 2006-12-20 2010-02-09 Smart Modular Technologies, Inc. Block-based data striping to flash memory
US7913149B2 (en) 2006-12-20 2011-03-22 Lsi Corporation Low complexity LDPC encoding algorithm
US7596643B2 (en) 2007-02-07 2009-09-29 Siliconsystems, Inc. Storage subsystem with configurable buffer
US7900118B2 (en) 2007-02-12 2011-03-01 Phison Electronics Corp. Flash memory system and method for controlling the same
US8359522B2 (en) 2007-05-01 2013-01-22 Texas A&M University System Low density parity check decoder for regular LDPC codes
US7685338B2 (en) 2007-05-24 2010-03-23 Siliconsystems, Inc. Solid state storage subsystem for embedded applications
US7685337B2 (en) 2007-05-24 2010-03-23 Siliconsystems, Inc. Solid state storage subsystem for embedded applications
US7685374B2 (en) 2007-07-26 2010-03-23 Siliconsystems, Inc. Multi-interface and multi-bus structured solid-state storage subsystem
US8181089B1 (en) 2007-08-24 2012-05-15 Datadirect Networks, Inc. Method for auto-correction of errors in a solid-state memory system
US8095851B2 (en) 2007-09-06 2012-01-10 Siliconsystems, Inc. Storage subsystem capable of adjusting ECC settings based on monitored conditions
US8261152B2 (en) 2007-09-10 2012-09-04 Samsung Electronics Co., Ltd. Apparatus and method for channel encoding/decoding in communication system using variable-length LDPC codes
US8312341B1 (en) * 2007-12-05 2012-11-13 Marvell International Ltd. Interleaved error correction coding for channels with non-uniform SNRs
US8751755B2 (en) 2007-12-27 2014-06-10 Sandisk Enterprise Ip Llc Mass storage controller volatile memory containing metadata related to flash memory storage
US8078918B2 (en) 2008-02-07 2011-12-13 Siliconsystems, Inc. Solid state storage subsystem that maintains and provides access to data reflective of a failure risk
US7962792B2 (en) 2008-02-11 2011-06-14 Siliconsystems, Inc. Interface for enabling a host computer to retrieve device monitor data from a solid state storage subsystem
KR101398212B1 (ko) 2008-03-18 2014-05-26 삼성전자주식회사 메모리 장치 및 인코딩/디코딩 방법
KR101398200B1 (ko) 2008-03-18 2014-05-26 삼성전자주식회사 메모리 장치 및 인코딩/디코딩 방법
US8180954B2 (en) 2008-04-15 2012-05-15 SMART Storage Systems, Inc. Flash management using logical page size
US7733712B1 (en) 2008-05-20 2010-06-08 Siliconsystems, Inc. Storage subsystem with embedded circuit for protecting against anomalies in power signal from host
WO2009143375A2 (en) 2008-05-21 2009-11-26 The Regents Of The University Of Calfornia Lower-complexity layered belief propagation deconding ldpc codes
US8276028B2 (en) * 2008-05-23 2012-09-25 Intel Corporation Using error information from nearby locations to recover uncorrectable data in non-volatile memory
US20100017650A1 (en) 2008-07-19 2010-01-21 Nanostar Corporation, U.S.A Non-volatile memory data storage system with reliability management
US20100125695A1 (en) 2008-11-15 2010-05-20 Nanostar Corporation Non-volatile memory storage system
KR101391362B1 (ko) 2008-07-23 2014-05-07 삼성전자주식회사 읽기 전압 레벨이 설정가능한 플래시 메모리 시스템 및읽기 전압 레벨의 설정방법
US8583835B1 (en) 2008-08-06 2013-11-12 Siliconsystems, Inc. Command portal for executing non-standard storage subsystem commands
US8375151B1 (en) 2009-02-12 2013-02-12 Siliconsystems, Inc. Command portal for securely communicating and executing non-standard storage subsystem commands
US20100049914A1 (en) 2008-08-20 2010-02-25 Goodwin Paul M RAID Enhanced solid state drive
US8239734B1 (en) 2008-10-15 2012-08-07 Apple Inc. Efficient data storage in storage device arrays
US8281214B2 (en) 2008-10-17 2012-10-02 Lsi Corporation Programmable quasi-cyclic low-density parity check (QC LDPC) encoder for read channel
US8161345B2 (en) 2008-10-29 2012-04-17 Agere Systems Inc. LDPC decoders using fixed and adjustable permutators
US9356623B2 (en) 2008-11-26 2016-05-31 Avago Technologies General Ip (Singapore) Pte. Ltd. LDPC decoder variable node units having fewer adder stages
KR101059673B1 (ko) 2008-12-26 2011-08-25 서울대학교산학협력단 신뢰도 또는 저장 용량을 동적으로 조절하는 저장 장치 및 그 방법
US9176859B2 (en) 2009-01-07 2015-11-03 Siliconsystems, Inc. Systems and methods for improving the performance of non-volatile memory operations
US8090899B1 (en) 2009-03-04 2012-01-03 Western Digital Technologies, Inc. Solid state drive power safe wear-leveling
KR100929371B1 (ko) 2009-03-18 2009-12-02 한국과학기술원 페이지-디퍼런셜을 이용하여 dbms에 독립적인 방법으로 플래시 메모리에 데이터를 저장하는 방법
US10079048B2 (en) 2009-03-24 2018-09-18 Western Digital Technologies, Inc. Adjusting access of non-volatile semiconductor memory based on access time
US8327224B2 (en) 2009-04-16 2012-12-04 Micron Technology, Inc. Data recovery in a solid state storage system
US8578256B2 (en) 2009-04-22 2013-11-05 Agere Systems Llc Low-latency decoder
US8341501B2 (en) * 2009-04-30 2012-12-25 International Business Machines Corporation Adaptive endurance coding of non-volatile memories
US8176284B2 (en) 2009-08-11 2012-05-08 Texas Memory Systems, Inc. FLASH-based memory system with variable length page stripes including data protection information
US7941696B2 (en) 2009-08-11 2011-05-10 Texas Memory Systems, Inc. Flash-based memory system with static or variable length page stripes including data protection information and auxiliary protection stripes
US8255620B2 (en) * 2009-08-11 2012-08-28 Texas Memory Systems, Inc. Secure Flash-based memory system with fast wipe feature
US8402217B2 (en) 2009-09-15 2013-03-19 Marvell International Ltd. Implementing RAID in solid state memory
US8683302B2 (en) 2009-09-25 2014-03-25 Panasonic Corporation Coding device, decoding device, coding method, decoding method, and communication system
US8254172B1 (en) 2009-09-30 2012-08-28 Western Digital Technologies, Inc. Wear leveling non-volatile semiconductor memory based on erase times and program times
US8243525B1 (en) 2009-09-30 2012-08-14 Western Digital Technologies, Inc. Refreshing non-volatile semiconductor memory by reading without rewriting
JP2011086333A (ja) 2009-10-14 2011-04-28 Sony Corp データ変調装置および方法、並びにプログラム、記録媒体
US9753847B2 (en) 2009-10-27 2017-09-05 Western Digital Technologies, Inc. Non-volatile semiconductor memory segregating sequential, random, and system data to reduce garbage collection for page based mapping
US8261012B2 (en) 2009-10-30 2012-09-04 Western Digital Technologies, Inc. Non-volatile semiconductor memory comprising power fail circuitry for flushing write data in response to a power fail signal
US8135903B1 (en) 2009-10-30 2012-03-13 Western Digital Technologies, Inc. Non-volatile semiconductor memory compressing data to improve performance
TWI415396B (zh) 2009-11-23 2013-11-11 Nat Univ Tsing Hua 適用於根據里德-索羅門碼建立之低密度同位檢查碼的解碼器及解碼方法
US8397107B1 (en) 2009-12-11 2013-03-12 Western Digital Technologies, Inc. Data storage device employing data path protection using both LBA and PBA
US8443167B1 (en) 2009-12-16 2013-05-14 Western Digital Technologies, Inc. Data storage device employing a run-length mapping table and a single address mapping table
KR101623119B1 (ko) 2010-02-01 2016-05-20 삼성전자주식회사 솔리드 스테이트 드라이브의 에러 제어 방법
US8316176B1 (en) 2010-02-17 2012-11-20 Western Digital Technologies, Inc. Non-volatile semiconductor memory segregating sequential data during garbage collection to reduce write amplification
US8407449B1 (en) 2010-02-26 2013-03-26 Western Digital Technologies, Inc. Non-volatile semiconductor memory storing an inverse map for rebuilding a translation table
KR20120137416A (ko) 2010-03-22 2012-12-20 모사이드 테크놀로지스 인코퍼레이티드 에러 정정을 갖는 복합 반도체 메모리 디바이스
US8726126B2 (en) 2010-03-23 2014-05-13 Apple Inc. Non-regular parity distribution detection via metadata tag
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
US8713066B1 (en) 2010-03-29 2014-04-29 Western Digital Technologies, Inc. Managing wear leveling and garbage collection operations in a solid-state memory using linked lists
US9544090B2 (en) 2010-03-31 2017-01-10 Avago Technologies General Ip (Singapore) Pte. Ltd. Hard input low density parity check decoder
US8527840B2 (en) * 2010-04-06 2013-09-03 Densbits Technologies Ltd. System and method for restoring damaged data programmed on a flash device
KR101610727B1 (ko) 2010-04-09 2016-04-08 에스케이 하이닉스 메모리 솔루션즈 인크. Ldpc 선택적 디코딩 스케줄링의 구현
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
US8489979B2 (en) 2010-05-28 2013-07-16 Seagate Technology Llc Methods and devices to reduce outer code failure rate variability
US8799747B2 (en) 2010-06-03 2014-08-05 Seagate Technology Llc Data hardening to compensate for loss of data retention characteristics in a non-volatile memory
US8341339B1 (en) 2010-06-14 2012-12-25 Western Digital Technologies, Inc. Hybrid drive garbage collecting a non-volatile semiconductor memory by migrating valid data to a disk
US8612669B1 (en) 2010-06-28 2013-12-17 Western Digital Technologies, Inc. System and method for performing data retention in solid-state memory using copy commands and validity and usage data
US8447920B1 (en) 2010-06-29 2013-05-21 Western Digital Technologies, Inc. System and method for managing data access in non-volatile memory
US8521972B1 (en) 2010-06-30 2013-08-27 Western Digital Technologies, Inc. System and method for optimizing garbage collection in data storage
US8639872B1 (en) 2010-08-13 2014-01-28 Western Digital Technologies, Inc. Hybrid drive comprising write cache spanning non-volatile semiconductor memory and disk
US8775720B1 (en) 2010-08-31 2014-07-08 Western Digital Technologies, Inc. Hybrid drive balancing execution times for non-volatile semiconductor memory and disk
US8638602B1 (en) 2010-09-10 2014-01-28 Western Digital Technologies, Inc. Background selection of voltage reference values for performing memory read operations
US8769190B1 (en) 2010-09-15 2014-07-01 Western Digital Technologies, Inc. System and method for reducing contentions in solid-state memory access
US8788779B1 (en) 2010-09-17 2014-07-22 Western Digital Technologies, Inc. Non-volatile storage subsystem with energy-based performance throttling
US8463991B2 (en) 2010-09-28 2013-06-11 Pure Storage Inc. Intra-device data protection in a raid array
US8612804B1 (en) 2010-09-30 2013-12-17 Western Digital Technologies, Inc. System and method for improving wear-leveling performance in solid-state memory
US9348696B2 (en) 2010-10-01 2016-05-24 Pure Storage, Inc. Distributed multi-level protection in a raid array based storage system
US20120084507A1 (en) 2010-10-01 2012-04-05 John Colgrove Multi-level protection with intra-device protection in a raid array based storage system
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
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
US8458435B1 (en) 2010-12-20 2013-06-04 Western Digital Technologies, Inc. Sequential write thread detection
US8392635B2 (en) 2010-12-22 2013-03-05 Western Digital Technologies, Inc. Selectively enabling a host transfer interrupt
US8626989B2 (en) * 2011-02-02 2014-01-07 Micron Technology, Inc. Control arrangements and methods for accessing block oriented nonvolatile memory
US8683113B2 (en) 2011-02-04 2014-03-25 Western Digital Technologies, Inc. Concurrently searching multiple devices of a non-volatile semiconductor memory
US8700950B1 (en) 2011-02-11 2014-04-15 Western Digital Technologies, Inc. System and method for data error recovery in a solid state subsystem
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
US9432298B1 (en) * 2011-12-09 2016-08-30 P4tents1, LLC System, method, and computer program product for improving memory systems
US8769232B2 (en) 2011-04-06 2014-07-01 Western Digital Technologies, Inc. Non-volatile semiconductor memory module enabling out of order host command chunk media access
US8751728B1 (en) 2011-04-29 2014-06-10 Western Digital Technologies, Inc. Storage system bus transfer optimization
US8862804B2 (en) 2011-04-29 2014-10-14 Western Digital Technologies, Inc. System and method for improved parity determination within a data redundancy scheme in a solid state memory
US9021178B2 (en) 2011-05-02 2015-04-28 Western Digital Technologies, Inc. High performance path for command processing
US8503237B1 (en) 2011-05-18 2013-08-06 Western Digital Technologies, Inc. System and method for data recovery in a solid state storage device
US8793429B1 (en) 2011-06-03 2014-07-29 Western Digital Technologies, Inc. Solid-state drive with reduced power up time
US8719531B2 (en) 2011-06-14 2014-05-06 Western Digital Technologies, Inc. System and method for performing data retention that incorporates environmental conditions
US8806112B2 (en) * 2011-07-14 2014-08-12 Lsi Corporation Meta data handling within a flash media controller
US20130031301A1 (en) * 2011-07-29 2013-01-31 Stec, Inc. Backend organization of stored data
US8423722B1 (en) 2011-08-26 2013-04-16 Western Digital Technologies, Inc. System and method for high performance command processing in solid state drives
US8713357B1 (en) 2011-09-06 2014-04-29 Western Digital Technologies, Inc. Systems and methods for detailed error reporting in data storage systems
US8700834B2 (en) 2011-09-06 2014-04-15 Western Digital Technologies, Inc. Systems and methods for an enhanced controller architecture in data storage systems
US8707104B1 (en) 2011-09-06 2014-04-22 Western Digital Technologies, Inc. Systems and methods for error injection in data storage systems
US8977803B2 (en) 2011-11-21 2015-03-10 Western Digital Technologies, Inc. Disk drive data caching using a multi-tiered memory
US8339919B1 (en) 2011-12-14 2012-12-25 Western Digital Technologies, Inc. Disk drive margining read channel by biasing log-likelihood ratios of a nonbinary iterative decoder
US8724422B1 (en) 2012-02-29 2014-05-13 Western Digital Technologies, Inc. System and method for charging back-up charge storage element for data storage device using spindle phase switching elements
US9003224B2 (en) 2012-04-25 2015-04-07 Western Digital Technologies, Inc. Managing unreliable memory in data storage systems
US8996957B1 (en) * 2012-05-22 2015-03-31 Pmc-Sierra, Inc. Systems and methods for initializing regions of a flash drive having diverse error correction coding (ECC) schemes
US8788778B1 (en) 2012-06-04 2014-07-22 Western Digital Technologies, Inc. Garbage collection based on the inactivity level of stored data
US8966343B2 (en) 2012-08-21 2015-02-24 Western Digital Technologies, Inc. Solid-state drive retention monitor using reference blocks
US8788880B1 (en) 2012-08-22 2014-07-22 Western Digital Technologies, Inc. Efficient retry mechanism for solid-state memory failures
US8898548B1 (en) * 2012-08-24 2014-11-25 Western Digital Technologies, Inc. Methods, data storage devices and systems having variable size ECC page size
US9268682B2 (en) 2012-10-05 2016-02-23 Skyera, Llc Methods, devices and systems for physical-to-logical mapping in solid state drives
US8972826B2 (en) 2012-10-24 2015-03-03 Western Digital Technologies, Inc. Adaptive error correction codes for data storage systems
US9177638B2 (en) 2012-11-13 2015-11-03 Western Digital Technologies, Inc. Methods and devices for avoiding lower page corruption in data storage devices
US8954694B2 (en) 2012-11-15 2015-02-10 Western Digital Technologies, Inc. Methods, data storage devices and systems for fragmented firmware table rebuild in a solid state drive
US9021339B2 (en) 2012-11-29 2015-04-28 Western Digital Technologies, Inc. Data reliability schemes for data storage systems
US9059736B2 (en) 2012-12-03 2015-06-16 Western Digital Technologies, Inc. Methods, solid state drive controllers and data storage devices having a runtime variable raid protection scheme
US20140223255A1 (en) 2012-12-18 2014-08-07 Western Digital Technologies, Inc. Decoder having early decoding termination detection
US9430376B2 (en) 2012-12-26 2016-08-30 Western Digital Technologies, Inc. Priority-based garbage collection for data storage systems

Patent Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2004326867A (ja) * 2003-04-22 2004-11-18 Toshiba Corp データ記憶システム
US20050160218A1 (en) * 2004-01-20 2005-07-21 Sun-Teck See Highly integrated mass storage device with an intelligent flash controller
US20100251068A1 (en) * 2009-03-27 2010-09-30 Li-Lien Lin Storage controller with encoding/decoding circuit programmable to support different ecc requirements and related method thereof
US20100315874A1 (en) * 2009-06-15 2010-12-16 Ramin Ghodsi Use of emerging non-volatile memory elements with flash memory
US20110231737A1 (en) * 2010-03-16 2011-09-22 Kenshi Dachiku Data storage apparatus and data writing/reading method
US20110283164A1 (en) * 2010-05-17 2011-11-17 Skymedi Corporation Configurable coding system and method of multiple eccs
US20120079351A1 (en) * 2010-09-24 2012-03-29 International Business Machines Corporation Systems and Methods for Memory Devices
CN102005250A (zh) * 2010-10-27 2011-04-06 记忆科技(深圳)有限公司 准循环低密度奇偶校验码译码器及译码方法
WO2012058328A1 (en) * 2010-10-27 2012-05-03 Sandforce, Inc. Adaptive ecc techniques for flash memory based data storage

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2018045744A (ja) * 2016-09-14 2018-03-22 東芝メモリ株式会社 メモリシステムおよび方法
US10789125B2 (en) 2016-09-14 2020-09-29 Toshiba Memory Corporation Memory system and method
JP2019009776A (ja) * 2017-06-14 2019-01-17 ランディグラッド, リミテッド ライアビリティー カンパニーLANDIGRAD, Limited Liability Company 情報の符号化及び復号化の諸法

Also Published As

Publication number Publication date
EP2912667A4 (en) 2016-06-01
US10216574B2 (en) 2019-02-26
US20150100854A1 (en) 2015-04-09
KR20150082334A (ko) 2015-07-15
EP2912667A1 (en) 2015-09-02
KR101927575B1 (ko) 2018-12-10
US20140115427A1 (en) 2014-04-24
CN104871249B (zh) 2018-09-07
US8972826B2 (en) 2015-03-03
CN104871249A (zh) 2015-08-26
HK1214401A1 (zh) 2016-07-22
WO2014065967A1 (en) 2014-05-01
JP6129328B2 (ja) 2017-05-17

Similar Documents

Publication Publication Date Title
JP6129328B2 (ja) データストレージシステムのための適応誤り訂正符号
US9214963B1 (en) Method and system for monitoring data channel to enable use of dynamically adjustable LDPC coding parameters in a data storage system
US20190377632A1 (en) Method of equalizing bit error rates of memory device
KR101872573B1 (ko) 런타임 가변 raid 보호 방식을 갖는 방법들, 솔리드 스테이트 드라이브 제어기들 및 데이터 저장 디바이스들
US9465552B2 (en) Selection of redundant storage configuration based on available memory space
US11798627B2 (en) Multi-phased programming with balanced gray coding
US11683053B2 (en) Memory controller, memory system, and memory control method
JP2016505937A (ja) データストレージシステムのためのデータ信頼性スキーム
US10191683B2 (en) One-pass programming in a multi-level nonvolatile memory device with improved write amplification
CN107257958A (zh) 用于定制应用的动态近似存储
KR20170076350A (ko) 데이터 저장 장치 및 그것의 동작 방법
US20220004455A1 (en) Method of equalizing bit error rates of memory device
CN108268338B (zh) 逐渐缩减大小的可变节点存储器
US10026464B2 (en) Devices, systems, and methods for increasing the usable life of a storage system by optimizing the energy of stored data
WO2021230003A1 (ja) メモリモジュール
WO2023047149A1 (en) Improved ecc configuration in memories
TW202244934A (zh) 用於減少糾錯碼功率消耗之方法及系統
TW202240594A (zh) 用於管理具有動態錯誤更正碼保護之記憶體的方法及系統

Legal Events

Date Code Title Description
RD04 Notification of resignation of power of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7424

Effective date: 20151217

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20160923

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20161205

A871 Explanation of circumstances concerning accelerated examination

Free format text: JAPANESE INTERMEDIATE CODE: A871

Effective date: 20161205

A975 Report on accelerated examination

Free format text: JAPANESE INTERMEDIATE CODE: A971005

Effective date: 20170308

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

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20170411

R150 Certificate of patent or registration of utility model

Ref document number: 6129328

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

RD04 Notification of resignation of power of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7424

Effective date: 20170817

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

LAPS Cancellation because of no payment of annual fees