

【公報種別】特許法第17条の2の規定による補正の掲載

【部門区分】第6部門第3区分

【発行日】平成28年12月28日(2016.12.28)

【公開番号】特開2014-130587(P2014-130587A)

【公開日】平成26年7月10日(2014.7.10)

【年通号数】公開・登録公報2014-037

【出願番号】特願2013-264768(P2013-264768)

【国際特許分類】

G 06 F 12/16 (2006.01)

【F I】

G 06 F 12/16 320 F

G 06 F 12/16 320 L

【手続補正書】

【提出日】平成28年11月14日(2016.11.14)

【手続補正1】

【補正対象書類名】特許請求の範囲

【補正対象項目名】全文

【補正方法】変更

【補正の内容】

【特許請求の範囲】

【請求項1】

方法であって、

不揮発性メモリコントローラにおいて、複数の不揮発性メモリのうちのN個の部分をプログラムするためのデータを受け取る工程であって、当該データは当該N個の部分のうちの特定の1つをプログラムするための特定のデータを有するものである、前記受け取る工程と、

前記特定のデータを割り当てられたバッファに記憶する工程であって、当該バッファは前記不揮発性メモリコントローラと関連付けられているものである、前記記憶する工程と、

前記不揮発性メモリのうちの特定の1つに対して前記特定のデータのプログラミングを開始する工程と、

前記N個の部分のうちM個の障害から回復するのに十分な冗長情報を更新する工程と、前記割り当てられたバッファを解放する工程と

を有し、

前記記憶する工程、前記特定のデータのプログラミングを開始する工程、前記冗長情報を更新する工程、および前記解放する工程のうちの少なくとも1つは、前記受け取る工程に応答するものであり、

前記解放する工程は、前記特定の不揮発性メモリが前記プログラミングを完了する前に行われるものである、

方法。

【請求項2】

請求項1に記載の方法において、前記冗長情報は第1の冗長情報であり、データは前記N個の部分のサブセットのために受け取られるものであり、プログラミングは前記N個の部分の前記サブセットについてまだ開始されていないものであり、この方法は、さらに、

前記N個の部分の前記サブセットのうちの少なくとも一部のプログラミングを遅延させる工程と、

前記不揮発性メモリのうちの複数のメモリに対して前記第1の冗長情報のプログラミン

グを開始する工程と、

前記 N 個の部分の前記サブセットのうちの前記少なくとも一部のプログラミングを開始する工程と、

前記第 1 の冗長情報とは異なる、前記 N 個の部分の前記サブセットのうち M 個の障害から回復するのに十分な第 2 の冗長情報を更新する工程と

を有するものであり、

前記プログラミングを遅延させる工程、前記第 1 の冗長情報のプログラミングを開始する工程、前記 N 個の部分の前記サブセットのうちの前記少なくとも一部のプログラミングを開始する前記工程、および前記第 2 の冗長情報を更新する工程のうちの少なくとも 1 つは、前記特定のデータの前記プログラミングの障害を検出したことに応答するものである方法。

#### 【請求項 3】

請求項 2 に記載の方法において、前記特定のデータは、前記障害が検出された場合、もっぱら前記第 1 の冗長情報で符号化されているとおりに記憶されるものである方法。

#### 【請求項 4】

請求項 1 ~ 3 のいずれか 1 項に記載の方法において、前記データは、前記 N 個の部分のうちの第 1 の部分をプログラムするための初期データをさらに有するものであり、さらには、

少なくとも部分的に前記初期データに基づいて前記冗長情報を初期設定する工程を有するものである方法。

#### 【請求項 5】

請求項 1 ~ 4 のいずれか 1 項に記載の方法において、前記不揮発性メモリコントローラは前記割り当てられたバッファを有するものである方法。

#### 【請求項 6】

請求項 1 ~ 5 のいずれか 1 項に記載の方法において、前記割り当てられたバッファは、前記不揮発性メモリコントローラを有する第 2 のチップとは独立した第 1 のチップに具備される方法。

#### 【請求項 7】

請求項 1 ~ 6 のいずれか 1 項に記載の方法において、前記不揮発性メモリコントローラは、ストレージインターフェース規格と適合するコンピューティング・ホスト・インターフェースを少なくとも部分的に介してコンピューティングホストと通信可能なソリッドステート・ディスク・コントローラとして動作するものである方法。

#### 【請求項 8】

処理要素によって実行されると、当該処理要素に動作を実行させ、かつ / または制御させる命令のセットが記憶されている有形のコンピュータ可読媒体であって、前記動作は、

不揮発性メモリコントローラにおいて、複数の不揮発性メモリのうちの N 個の部分をプログラムするためのデータを受け取る動作であって、当該データは当該 N 個の部分のうちの特定の 1 つをプログラムするための特定のデータを有するものである、前記受け取る動作と、

前記特定のデータを割り当てられたバッファに記憶する動作であって、当該バッファは前記不揮発性メモリコントローラと関連付けられているものである、前記記憶する動作と、

前記不揮発性メモリのうちの特定の 1 つに対して前記特定のデータのプログラミングを開始する動作と、

前記 N 個の部分のうち M 個の障害から回復するのに十分な冗長情報を更新する動作と、前記割り当てられたバッファを解放する動作とを有し、

前記記憶する動作、前記特定のデータのプログラミングを開始する動作、前記冗長情報を更新する動作、および前記解放する動作のうちの少なくとも 1 つは、前記特定のデータを受け取る動作に応答するものであり、

前記解放する動作は、前記特定の不揮発性メモリが前記プログラミングを完了する前に行われるものである、

有形のコンピュータ可読媒体。

【請求項 9】

請求項 8 に記載の有形のコンピュータ可読媒体において、前記冗長情報は第 1 の冗長情報であり、データは前記 N 個の部分のサブセットのために受け取られるものであり、プログラミングは前記 N 個の部分の前記サブセットについてまだ開始されていないものであり、前記動作は、さらに、

前記 N 個の部分の前記サブセットのうちの少なくとも一部のプログラミングを遅延させる動作と、

前記不揮発性メモリのうちの複数のメモリに対して前記第 1 の冗長情報のプログラミングを開始する動作と、

前記 N 個の部分の前記サブセットのうちの前記少なくとも一部のプログラミングを開始する動作と、

前記第 1 の冗長情報とは異なる、前記 N 個の部分の前記サブセットのうち M 個の障害から回復するのに十分な第 2 の冗長情報を更新する動作と

を有するものであり、

前記プログラミングを遅延させる動作、前記第 1 の冗長情報のプログラミングを開始する動作、前記 N 個の部分の前記サブセットのうちの前記少なくとも一部のプログラミングを開始する動作、および前記第 2 の冗長情報を更新する動作のうちの少なくとも 1 つは、前記特定のデータの前記プログラミングの障害を検出したことに応答するものである有形のコンピュータ可読媒体。

【請求項 10】

請求項 9 に記載の有形のコンピュータ可読媒体において、前記特定のデータは、前記障害が検出された場合、もっぱら前記第 1 の冗長情報で符号化されているとおりに記憶されるものである有形のコンピュータ可読媒体。

【請求項 11】

請求項 8 ~ 10 のいずれか 1 項に記載の有形のコンピュータ可読媒体において、前記データは、前記 N 個の部分のうちの第 1 の部分をプログラムするための初期データをさらに有するものであり、さらに、

少なくとも部分的に前記初期データに基づいて前記冗長情報を初期設定する動作を有するものである有形のコンピュータ可読媒体。

【請求項 12】

請求項 8 ~ 11 のいずれか 1 項に記載の有形のコンピュータ可読媒体において、前記不揮発性メモリコントローラは前記割り当てられたバッファを有する有形のコンピュータ可読媒体。

【請求項 13】

請求項 8 ~ 12 のいずれか 1 項に記載の有形のコンピュータ可読媒体において、前記割り当てられたバッファは、前記不揮発性メモリコントローラを有する第 2 のチップとは独立した第 1 のチップに具備される有形のコンピュータ可読媒体。

【請求項 14】

請求項 8 ~ 13 のいずれか 1 項に記載の有形のコンピュータ可読媒体において、前記不揮発性メモリコントローラは、ストレージインターフェース規格と適合するコンピュティング・ホスト・インターフェースを少なくとも部分的に介してコンピュティングホストと通信可能なソリッドステート・ディスク・コントローラとして動作するものである有形のコンピュータ可読媒体。

【請求項 15】

請求項 8 ~ 14 のいずれか 1 項に記載の有形のコンピュータ可読媒体において、前記不揮発性メモリコントローラは前記処理要素を有するものである有形のコンピュータ可読媒体。

**【請求項 1 6】**

システムであって、

割り当てられたバッファと、

不揮発性メモリコントローラにおいて、複数の不揮発性メモリのうちのN個の部分をプログラムするためのデータを受け取る手段であって、当該データは当該N個の部分のうちの特定の1つをプログラムするための特定のデータを有するものである、前記受け取る手段と、

前記特定のデータを前記割り当てられたバッファに記憶する手段であって、当該バッファは前記不揮発性メモリコントローラと関連付けられているものである、前記記憶する工程と、

前記不揮発性メモリのうちの特定の1つに対して前記特定のデータのプログラミングを開始する手段と、

前記N個の部分のうちM個の障害から回復するのに十分な冗長情報を更新する手段と、前記割り当てられたバッファを解放する手段と

を有し、

前記記憶する手段、前記特定のデータのプログラミングを開始する手段、前記冗長情報を更新する手段、および前記解放する手段のうちの少なくとも1つは、前記受け取る手段に応答するものであり、

前記解放する手段は、前記特定の不揮発性メモリが前記プログラミングを完了する前に前記割り当てられたバッファを解放するように動作するものである、

システム。

**【請求項 1 7】**

請求項16に記載のシステムにおいて、前記冗長情報は第1の冗長情報であり、データは前記N個の部分のサブセットのために受け取られるものであり、プログラミングは前記N個の部分の前記サブセットについてまだ開始されていないものであり、このシステムは、さらに、

前記N個の部分の前記サブセットのうちの少なくとも一部のプログラミングを遅延させる手段と、

前記不揮発性メモリのうちの複数のメモリに対して前記第1の冗長情報のプログラミングを開始する手段と、

前記N個の部分の前記サブセットのうちの前記少なくとも一部のプログラミングを開始する手段と、

前記第1の冗長情報とは異なる、前記N個の部分の前記サブセットのうちM個の障害から回復するのに十分な第2の冗長情報を更新する手段と

を有するものであり、

前記プログラミングを遅延させる手段、前記第1の冗長情報のプログラミングを開始する前記手段、前記N個の部分の前記サブセットのうちの前記少なくとも一部のプログラミングを開始する前記手段、および前記第2の冗長情報を更新する手段のうちの少なくとも1つは、前記特定のデータの前記プログラミングの障害を検出する手段に応答するものであるシステム。

**【請求項 1 8】**

請求項17に記載のシステムにおいて、前記特定のデータは、前記障害が検出された場合、もっぱら前記第1の冗長情報で符号化されているとおりに記憶されるものであるシステム。

**【請求項 1 9】**

請求項16～18のいずれか1項に記載のシステムにおいて、前記データは、前記N個の部分のうちの第1の部分をプログラムするための初期データをさらに有するものであり、さらに、

少なくとも部分的に前記初期データに基づいて前記冗長情報を初期設定する手段を有するものであるシステム。

**【請求項 20】**

請求項 1 6 ~ 1 9 のいずれか 1 項に記載のシステムにおいて、前記不揮発性メモリコントローラは前記割り当てられたバッファを有するものであるシステム。