

(19) 日本国特許庁(JP)

## (12) 特許公報(B2)

(11) 特許番号

特許第5221593号  
(P5221593)

(45) 発行日 平成25年6月26日(2013.6.26)

(24) 登録日 平成25年3月15日(2013.3.15)

(51) Int.Cl.

F 1

G06F 12/02 (2006.01)  
G06F 12/00 (2006.01)G06F 12/02 530C  
G06F 12/00 597U

請求項の数 20 (全 52 頁)

(21) 出願番号 特願2010-102697 (P2010-102697)  
 (22) 出願日 平成22年4月27日 (2010.4.27)  
 (62) 分割の表示 特願2008-63404 (P2008-63404)  
 の分割  
 原出願日 平成20年3月12日 (2008.3.12)  
 (65) 公開番号 特開2010-176702 (P2010-176702A)  
 (43) 公開日 平成22年8月12日 (2010.8.12)  
 審査請求日 平成23年3月14日 (2011.3.14)

(73) 特許権者 000003078  
 株式会社東芝  
 東京都港区芝浦一丁目1番1号  
 (74) 代理人 100089118  
 弁理士 酒井 宏明  
 (72) 発明者 矢野 純二  
 東京都港区芝浦一丁目1番1号 株式会社  
 東芝内  
 (72) 発明者 松崎 秀則  
 東京都港区芝浦一丁目1番1号 株式会社  
 東芝内  
 (72) 発明者 初田 幸輔  
 東京都港区芝浦一丁目1番1号 株式会社  
 東芝内

最終頁に続く

(54) 【発明の名称】メモリシステム

## (57) 【特許請求の範囲】

## 【請求項 1】

データ消去単位であるブロックを複数備え、各々の前記ブロックはデータ書き込み及び読み出し単位であるページを複数含む不揮発性半導体メモリと、

前記不揮発性半導体メモリが備える複数のブロックを、セクタ単位の自然数倍である第1の管理単位でデータが管理される第1の記憶領域と、前記第1の管理単位の2以上の自然数倍である第2の管理単位でデータが管理される第2の記憶領域とに割り当てるコントローラと、を具備し、

前記コントローラは、

前記第1の管理単位の有効データを前記第1の記憶領域から追い出し、当該有効データを前記第2の管理単位のデータに統合して、前記第2の記憶領域に記憶する第1の手段と、

前記第1の記憶領域内における前記第1の管理単位の有効データを複数選択して、前記第1の記憶領域内の新たなブロックに書き直す第2の手段と、を備え、

前記第2の手段を実行する前に、少なくとも1回、前記第1の手段を実行することを特徴とするメモリシステム。

## 【請求項 2】

前記コントローラは、前記第1の記憶領域に割り当てられたブロックの個数が上限値を超えた場合に、前記第1の手段を実行した後、前記第2の手段を実行することを特徴とする請求項1に記載のメモリシステム。

**【請求項 3】**

前記コントローラは、前記第1の手段を実行した後、前記第1の記憶領域内における前記第1の管理単位の有効データの合計容量が所定値以上である場合、再度前記第1の手段を実行することを特徴とする請求項2に記載のメモリシステム。

**【請求項 4】**

前記コントローラは、前記第1の手段を実行した後、前記第1の記憶領域内における前記第1の管理単位の有効データの合計容量が所定値未満である場合、前記第2の手段を実行することを特徴とする請求項2に記載のメモリシステム。

**【請求項 5】**

前記所定値は、1ブロック分の記憶容量に等しいことを特徴とする請求項3または請求項4に記載にメモリシステム。

10

**【請求項 6】**

前記コントローラは、前記第1の手段を実行する際に、複数ブロックの記憶容量に対応する前記第2の管理単位のアドレス範囲を選択し、選択された前記第2の管理単位のアドレス範囲内に含まれる前記第1の管理単位の有効データを追い出すことを特徴とする請求項1に記載のメモリシステム。

**【請求項 7】**

前記コントローラは、前記第2の手段を実行する際に、前記第1の管理単位の有効データの個数が少ない方から順にブロック選択し、選択されたブロックに含まれる前記第1の管理単位の有効データを書き直すことを特徴とする請求項1に記載のメモリシステム。

20

**【請求項 8】**

前記コントローラは、前記第1の手段を実行する際に、前記第2の管理単位のアドレス範囲内に含まれる前記第1の管理単位の有効データの個数に基づいて、前記第1の記憶領域から前記第2の記憶領域に追い出す有効データを選択することを特徴とする請求項1に記載のメモリシステム。

**【請求項 9】**

前記コントローラは、前記第1の手段を実行する際に、前記有効データの個数が多い方から順に前記第2の管理単位のアドレス範囲を選択し、選択された前記第2の管理単位のアドレス範囲内に含まれる前記第1の管理単位の有効データを追い出すことを特徴とする請求項8に記載のメモリシステム。

30

**【請求項 10】**

前記コントローラは、前記第1の手段を実行する際に、前記第1の記憶領域内において前記第1の管理単位の有効データを含む前記第2の管理単位のアドレス範囲に対応する前記第2の管理単位の有効データが、前記第2の記憶領域内において前記第2の管理単位の無効データを含むブロック内に記憶されているか否かに基づいて、前記第1の記憶領域から前記第2の記憶領域に追い出すデータを選択することを特徴とする請求項8に記載のメモリシステム。

**【請求項 11】**

前記コントローラは、前記第1の手段を実行する際に、前記無効データの個数が多いブロックに記憶されている前記第2の管理単位の有効データに対応する前記第2の管理単位のアドレス範囲を優先的に選択し、選択された前記第2の管理単位のアドレス範囲内に含まれる前記第1の管理単位の有効データを追い出すことを特徴とする請求項10に記載のメモリシステム。

40

**【請求項 12】**

前記コントローラは、前記第1の手段を実行する際に、前記第2の記憶領域に追い出された前記第1の管理単位の有効データを前記第1の記憶領域内において無効化し、有効データが存在しないブロックを前記第1の記憶領域から解放することを特徴とする請求項1に記載のメモリシステム。

**【請求項 13】**

前記コントローラは、前記第2の手段を実行する際に、第1の記憶領域内の新たなブロ

50

ツクに書き直された前記第1の管理単位の有効データを前記第1の記憶領域内において無効化し、有効データが存在しないブロックを前記第1の記憶領域から解放することを特徴とする請求項1に記載のメモリシステム。

**【請求項14】**

前記コントローラは、前記第1の手段を実行する際に、前記第1の記憶領域から追い出される前記第1の管理単位の有効データと、前記第1の記憶領域及び前記第2の記憶領域の少なくとも一方から読み出されたデータとを、前記第2の管理単位のデータに統合することを特徴とする請求項1に記載のメモリシステム。

**【請求項15】**

前記不揮発性半導体メモリに転送するデータを保持可能な半導体メモリを更に具備し、前記コントローラは、

前記半導体メモリに前記セクタ単位のデータを記憶する第3の手段と、

前記半導体メモリから追い出されたデータを、前記第1の管理単位のデータに統合して前記第1の記憶領域に記憶する第4の手段と、

前記半導体メモリから追い出されたデータを、前記第2の管理単位のデータに統合して前記第2の記憶領域に記憶する第5の手段と、

を備えることを特徴とする請求項1に記載のメモリシステム。

**【請求項16】**

前記半導体メモリは、揮発性ランダムアクセスメモリであることを特徴とする請求項15に記載のメモリシステム。

**【請求項17】**

前記半導体メモリは、不揮発性ランダムアクセスメモリであることを特徴とする請求項15に記載のメモリシステム。

**【請求項18】**

前記ページ単位は、前記第1の管理単位の2以上の自然数倍であり、かつ、前記第1の管理単位は、前記ブロック単位よりも小さいことを特徴とする請求項1に記載のメモリシステム。

**【請求項19】**

前記ブロック単位は、前記第2の管理単位の2以上の自然数倍であり、かつ、前記第2の管理単位は、前記ページ単位よりも大きいことを特徴とする請求項1に記載のメモリシステム。

**【請求項20】**

前記不揮発性半導体メモリは、NAND型フラッシュメモリであることを特徴とする請求項1に記載のメモリシステム。

**【発明の詳細な説明】**

**【技術分野】**

**【0001】**

本発明は、不揮発性半導体メモリを備えたメモリシステムに関する。

**【背景技術】**

**【0002】**

コンピュータシステムに用いられる外部記憶装置として、NAND型フラッシュメモリなどの不揮発性半導体メモリを搭載したSSD (Solid State Drive) が注目されている。フラッシュメモリは、磁気ディスク装置に比べ、高速、軽量などの利点を有している。

**【0003】**

SSD内には、複数のフラッシュメモリチップ、ホスト装置からの要求に応じて各フラッシュメモリチップのリード/ライト制御を行うコントローラ、各フラッシュメモリチップとホスト装置との間でデータ転送を行うためのバッファメモリ、電源回路、ホスト装置に対する接続インターフェースなどを備えている（例えは、特許文献1）。

**【0004】**

不揮発性半導体メモリには、NAND型フラッシュメモリのように、データを記憶させ

10

20

30

40

50

る場合にブロック単位で一度データを消去してからその後に書き込みを行うもの、ページ単位で書き込み／読み出しを行うものなど、消去／書き込み／読み出しの単位が固定されているものがある。

#### 【0005】

一方、パーソナルコンピュータなどのホスト機器がハードディスクをはじめとする2次記憶装置に対してデータの書き込み／読み出しを行う単位は、セクタと呼ばれる。セクタは、半導体記憶装置の消去／書き込み／読み出しの単位とは独立に定められる。

#### 【0006】

例えば、不揮発性半導体メモリのブロックの大きさ（ブロックサイズ）は、512 kB、ページの大きさ（ページサイズ）は、4 kBであるのに対して、ホスト機器のセクタの大きさ（セクタサイズ）は、512 Bのように定められている。10

#### 【0007】

このように、不揮発性半導体メモリの消去／書き込み／読み出しの単位は、ホスト機器の書き込み／読み出しの単位よりも大きい場合がある。

#### 【0008】

そこで、不揮発性半導体メモリを用いてハードディスクのようなパーソナルコンピュータの2次記憶装置を構成する場合、ホスト機器としてのパーソナルコンピュータからの小さなサイズのデータは、不揮発性半導体メモリのブロックサイズ、ページサイズに適合させて書き込みを行う必要がある。

#### 【0009】

また、パーソナルコンピュータなどのホスト機器が記録するデータは、時間的局所性、及び領域的局所性を兼ね備えている（例えば、非特許文献1参照。）。そのため、データを記録する際に外部から指定されたアドレスにそのまま記録していくと、特定の領域に短時間に書き換え、すなわち消去処理が集中し、消去回数の偏りが大きくなる。そのため、NAND型フラッシュメモリでは、データ更新箇所を均等に分散させるウェアレベリングと呼ばれる処理が行われる。20

#### 【0010】

ウェアレベリング処理では、例えば、ホスト機器から指定される論理アドレスを、データ更新箇所が均等に分散された不揮発性半導体メモリの物理アドレスにアドレス変換している。30

#### 【0011】

NAND型フラッシュメモリを用いて大容量の2次記憶装置を構成する場合においては、上記アドレス変換を行う場合に、データ管理の単位が小さいサイズ（例えば、ページサイズ）であると、管理テーブルのサイズが大きくなつて、2次記憶装置のコントローラの主記憶メモリに納まらなくなり、アドレス変換が高速にできなくなるという問題がある。このように、2次記憶装置としてのNAND型フラッシュメモリの大容量化に伴い管理テーブルのサイズは必然的に大きくなるため、管理テーブルをできるだけ小容量にするための手法が求められている。

#### 【0012】

また、上述したように、データの消去単位（ブロック）と、データの管理単位が異なる場合、フラッシュメモリの書き換えが進むと、無効な（最新ではない）データによって、ブロックは穴あき状態になる。このような穴あき状態のブロックが増えると、実質的に使用可能なブロックが少なくなり、フラッシュメモリの記憶領域を有効利用できないので、有効な最新のデータを集めて、違うブロックに書き直すコンパクションと呼ばれる処理が行われる。このコンパクション処理においては、その手法によっては処理時間が長くなるので、コンパクションの処理時間を短かくするための手法が求められている。40

#### 【先行技術文献】

#### 【特許文献】

#### 【0013】

【特許文献1】特許第3688835号公報

10

20

30

40

50

## 【非特許文献】

## 【0014】

【非特許文献1】David A. Patterson and John L. Hennessy, "Computer Organization and Design: The Hardware/Software Interface", Morgan Kaufmann Pub, 2004/8/31

## 【発明の概要】

## 【発明が解決しようとする課題】

## 【0015】

本発明は、コンパクションの処理時間を短縮化することが可能なメモリシステムを提供する。

## 【課題を解決するための手段】

10

## 【0016】

本願発明の一態様によれば、揮発性半導体メモリから構成されるキャッシュメモリとしての第1の記憶エリアと、ページ単位で読み出し及び書き込みが行われ、前記ページ単位の2以上の自然数倍の大きさであるブロック単位で消去が行われる不揮発性半導体メモリから構成される第2、第3及び第4の記憶エリアと、前記不揮発性半導体メモリの記憶領域を、1以上の前記ブロックに対応付けられた論理ブロック単位で前記第2、第3および第4の記憶エリアに割り当てるコントローラと、を具備し、前記コントローラは、前記第1の記憶エリアに書き込まれたセクタ単位の複数のデータを第1の管理単位のデータとして前記第2の記憶エリアに追い出す第1の処理と、前記第1の記憶エリアに書き込まれた複数のデータを前記第1の管理単位の2以上の自然数倍の大きさである第2の管理単位のデータとして第3の記憶エリアに追い出す第2の処理と、前記第2の記憶エリアに記憶された複数のデータを前記第2の管理単位のデータとして前記第3の記憶エリアに追い出す第3の処理と、前記第3の処理の実行後、前記第2の記憶エリアに記憶された複数のデータを論理ブロック単位で前記第4の記憶エリアに移動する第4の処理と、前記第4の記憶エリアに記憶された前記第1の管理単位の有効データを複数選択して新たな論理ブロック内に書き直す第5の処理と、第5の処理を実行する前に、前記第4の記憶エリアに書き込まれた複数のデータを前記論理ブロック単位に前記第3の記憶エリアに追い出す第6の処理とを実行することを特徴とする。

20

## 【発明の効果】

## 【0017】

30

本発明によれば、コンパクションの処理時間を短縮化することが可能なメモリシステムを提供できる。

## 【図面の簡単な説明】

## 【0018】

【図1】SSDの構成例を示すブロック図。

【図2】NANDメモリチップに含まれる1個のブロックの構成例と、4値データ記憶方式でのしきい値分布を示す図。

【図3】ドライブ制御回路のハードウェア的な内部構成例を示すブロック図。

【図4】プロセッサの機能構成例を示すブロック図。

【図5】NANDメモリおよびDRAM内に形成された機能構成を示すブロック図。

40

【図6】WCからNANDメモリへの書き込み処理に係わるより詳細な機能ブロック図。

【図7】LBA論理アドレスを示す図。

【図8】データ管理部内の管理テーブルの構成例を示す図。

【図9】RCクラスタ管理テーブルの一例を示す図。

【図10】WCクラスタ管理テーブルの一例を示す図。

【図11】WCトラック管理テーブルの一例を示す図。

【図12】トラック管理テーブルの一例を示す図。

【図13】FS/IS管理テーブルの一例を示す図。

【図14】MS論理ブロック管理テーブルの一例を示す図。

【図15】FS/IS論理ブロック管理テーブルの一例を示す図。

50

【図16】F S / I S内クラスタ管理テーブルの一例を示す図。

【図17】論物変換テーブルの一例を示す図。

【図18】読み出し処理の動作例を示すフローチャート。

【図19】書き込み処理の動作例を示すフローチャート。

【図20】各構成要素間のデータの流れにおける入力と出力の組み合わおよびその発生要因を示す図。

【図21】W CからN A N Dメモリへの書き込み処理に係わるさらにより詳細な機能プロック図。

【図22】データ管理部内の管理テーブルの他の構成例を示す図。

【図23】並列動作要素とプレーンとチャネルの関係を示す図。

10

【図24】論物変換テーブルの他の例を示す図。

【図25】B B管理テーブルの一例を示す図。

【図26】F B管理テーブルの内部構成例を示す図。

【図27】N A N Dメモリの論理ブロックと物理ブロックとの対応関係を示す図。

【図28】M S構造管理テーブルの一例を示す図。

【図29】F S / I S構造管理テーブルの一例を示す図。

【図30】書き込み処理の動作例を示す詳細なフローチャート。

【図31】I Sの追い出し動作例を示すフローチャート。

【発明を実施するための形態】

【0019】

20

以下に添付図面を参照して、この発明にかかるメモリシステムの最良な実施の形態を詳細に説明する。

【0020】

(実施の形態)

以下、本発明の実施の形態について図面を参照して説明する。なお、以下の説明において、同一の機能および構成を有する要素については、同一符号を付し、重複説明は必要な場合にのみ行う。

【0021】

先ず、本明細書で用いる用語について定義しておく。

・物理ページ：N A N Dメモリチップ内部において一括して書き込み／読み出しが可能な単位のこと。物理ページサイズは、例えば4 k B。ただし、主データ（ユーザデータなど）に対してS S D内で付加される誤り訂正符号などの冗長ビットは含まないものとする。通常、4 k B + 冗長ビット（例えば、数10 B）が同時にメモリセルに書き込まれる単位となるが、説明の便宜上、上記のように定義する。

30

・論理ページ：S S D内で設定される書き込み／読み出し単位であり、1以上の物理ページに対応付けられている。論理ページサイズは、例えば8ビットノーマルモードでは、4 k B、32ビット倍速モードでは、32 k B。ただし、冗長ビットは含まないものとする。

・物理ブロック：N A N Dメモリチップ内部において独立して消去可能な最小単位のことであり、複数の物理ページから構成される。物理ブロックサイズは、例えば512 k B。ただし、主データに対してS S D内で付加される誤り訂正符号などの冗長ビットは含まないものとする。通常、512 k B + 冗長ビット（例えば、数10 k B）が同時に消去される単位となるが、説明の便宜上、上記のように定義する。

40

・論理ブロック：S S D内で設定される消去単位であり、1以上の物理ブロックに対応付けられている。論理ブロックサイズは、例えば8ビットノーマルモードでは、512 k B、32ビット倍速モードでは、4 M B。ただし、冗長ビットは含まないものとする。

・セクタ：ホストからの最小アクセス単位のこと。セクタサイズは、例えば512 B。

・クラスタ：S S D内で「小さなデータ」を管理する管理単位。クラスタサイズはセクタサイズ以上であり、クラスタサイズの2以上の自然数倍が論理ページサイズとなるように定められる。

50

・トラック：S S D 内で「大きなデータ」を管理する管理単位。クラスタサイズの2以上の自然数倍がトラックサイズに、かつ、トラックサイズの2以上の自然数倍が論理ブロックサイズとなるように定められる。

・フリーブロック（F B）：用途未割り当てのN A N D型フラッシュメモリ上の論理ブロックのこと。用途を割り当てる際に消去してから使用する。

・バッドブロック（B B）：N A N D型フラッシュメモリ上の、誤りが多いなど記憶領域として使用できない物理ブロックのこと。例えば、消去動作が正常に終了しなかった物理ブロックがバッドブロックB Bとして登録される。

・書き込み効率：所定期間内における、ホストから書き込んだデータ量に対する、論理ブロックの消去量の統計値のこと。小さいほどN A N D型フラッシュメモリの消耗度が小さい。  
10

- ・有効クラスタ：最新のデータを保持しているクラスタ。
- ・無効クラスタ：最新ではないデータを保持しているクラスタ。
- ・有効トラック：最新のデータを保持しているトラック。
- ・無効トラック：最新ではないデータを保持しているトラック。
- ・コンパクション：管理対象内の論理ブロックから、有効クラスタや有効トラックのみを取り出して、新しい論理ブロックに書き直すこと。

#### [第1の実施形態]

##### 【0022】

図1は、S S D (Solid State Drive) 100の構成例を示すブロック図である。S S D 100は、A T A インタフェース（A T A I / F）2などのメモリ接続インターフェースを介してパーソナルコンピュータあるいはC P U コアなどのホスト装置1と接続され、ホスト装置1の外部メモリとして機能する。また、S S D 100は、R S 2 3 2 C インタフェース（R S 2 3 2 C I / F）などの通信インターフェース3を介して、デバッグ用/製造検査用機器200との間でデータを送受信することができる。S S D 100は、不揮発性半導体メモリとしてのN A N D型フラッシュメモリ（以下、N A N Dメモリと略す）10と、コントローラとしてのドライブ制御回路4と、揮発性半導体メモリとしてのD R A M 2 0と、電源回路5と、状態表示用のL E D 6と、ドライブ内部の温度を検出する温度センサ7と、フューズ8とを備えている。  
20

##### 【0023】

電源回路5は、ホスト装置1側の電源回路から供給される外部直流電源から複数の異なる内部直流電源電圧を生成し、これら内部直流電源電圧をS S D 100内の各回路に供給する。また、電源回路5は、外部電源の立ち上がりまたは立ち下がりを検知し、パワーオンリセット信号を生成して、ドライブ制御回路4に供給する。フューズ8は、ホスト装置1側の電源回路とS S D 100内部の電源回路5との間に設けられている。外部電源回路から過電流が供給された場合フューズ8が切断され、内部回路の誤動作を防止する。  
30

##### 【0024】

N A N Dメモリ10は、この場合、4並列動作を行う4つの並列動作要素10a～10dを有し、1つの並列動作要素は、2つのN A N Dメモリパッケージを有する。各N A N Dメモリパッケージは、積層された複数のN A N Dメモリチップ（例えば、1チップ=2 G B）によって構成されている。図1の場合は、各N A N Dメモリパッケージは、積層された4枚のN A N Dメモリチップによって構成されており、N A N Dメモリ10は64 G Bの容量を有する。各N A N Dメモリパッケージが、積層された8枚のN A N Dメモリチップによって構成されている場合は、N A N Dメモリ10は128 G Bの容量を有することになる。  
40

##### 【0025】

D R A M 2 0は、ホスト装置1とN A N Dメモリ10間でのデータ転送用キャッシュおよび作業領域用メモリとして機能する。また、D R A M 2 0の代わりに、F e R A Mを使用しても良い。ドライブ制御回路4は、ホスト装置1とN A N Dメモリ10との間でD R A M 2 0を介してデータ転送制御を行うとともに、S S D 100内の各構成要素を制御す  
50

る。また、ドライブ制御回路4は、状態表示用LED6にステータス表示用信号を供給するとともに、電源回路5からのパワーオンリセット信号を受けて、リセット信号およびクロック信号を自回路内およびSSD100内の各部に供給する機能も有している。

【0026】

各NANDメモリチップは、データ消去の単位である物理ブロックを複数配列して構成されている。図2(a)は、NANDメモリチップに含まれる1個の物理ブロックの構成例を示す回路図である。各物理ブロックは、X方向に沿って順に配列された( $p+1$ )個のNANDストリングを備えている( $p$ は、0以上の整数)。 $(p+1)$ 個のNANDストリングにそれぞれ含まれる選択トランジスタST1は、ドレインがビット線BL0~BLpに接続され、ゲートが選択ゲート線SGDに共通接続されている。また、選択トランジスタST2は、ソースがソース線SLに共通接続され、ゲートが選択ゲート線SGSに共通接続されている。

【0027】

各メモリセルトランジスタMTは、半導体基板上に形成された積層ゲート構造を備えたMOSFET(Metal Oxide Semiconductor Field Effect Transistor)から構成される。積層ゲート構造は、半導体基板上にゲート絶縁膜を介在して形成された電荷蓄積層(浮遊ゲート電極)、および電荷蓄積層上にゲート間絶縁膜を介在して形成された制御ゲート電極を含んでいる。メモリセルトランジスタMTは、浮遊ゲート電極に蓄えられる電子の数に応じて閾値電圧が変化し、この閾値電圧の違いに応じてデータを記憶する。メモリセルトランジスタMTは、1ビットを記憶するように構成されていてもよいし、多値(2ビット以上のデータ)を記憶するように構成されていてもよい。

【0028】

また、メモリセルトランジスタMTは、浮遊ゲート電極を有する構造に限らず、MONOS(Metal-Oxide-Nitride-Oxide-Silicon)型など、電荷蓄積層としての窒化膜界面に電子をトラップさせることでしきい値調整可能な構造であってもよい。MONOS構造のメモリセルトランジスタMTについても同様に、1ビットを記憶するように構成されていてもよいし、多値(2ビット以上のデータ)を記憶するように構成されていてもよい。

【0029】

各NANDストリングにおいて、( $q+1$ )個のメモリセルトランジスタMTは、選択トランジスタST1のソースと選択トランジスタST2のドレインとの間に、それぞれの電流経路が直列接続されるように配置されている。すなわち、複数のメモリセルトランジスタMTは、隣接するもの同士で拡散領域(ソース領域若しくはドレイン領域)を共有するような形でY方向に直列接続される。

【0030】

そして、最もドレイン側に位置するメモリセルトランジスタMTから順に、制御ゲート電極がワード線WL0~WLqにそれぞれ接続されている。従って、ワード線WL0に接続されたメモリセルトランジスタMTのドレインは選択トランジスタST1のソースに接続され、ワード線WLqに接続されたメモリセルトランジスタMTのソースは選択トランジスタST2のドレインに接続されている。

【0031】

ワード線WL0~WLqは、物理ブロック内のNANDストリング間で、メモリセルトランジスタMTの制御ゲート電極を共通に接続している。つまり、ブロック内において同一行にあるメモリセルトランジスタMTの制御ゲート電極は、同一のワード線WLに接続される。この同一のワード線WLに接続される( $p+1$ )個のメモリセルトランジスタMTは1ページ(物理ページ)として取り扱われ、この物理ページごとにデータの書き込みおよびデータの読み出しが行われる。

【0032】

また、ビット線BL0~BLpは、ブロック間で、選択トランジスタST1のドレインを共通に接続している。つまり、複数のブロック内において同一列にあるNANDストリングは、同一のビット線BLに接続される。

10

20

30

40

50

## 【0033】

図2(b)は、例えば、1個のメモリセルトランジスタMTに2ビットの記憶を行う4値データ記憶方式でのしきい値分布を示す模式図である。4値データ記憶方式では、上位ページデータ“x”と下位ページデータ“y”で定義される4値データ“xy”的何れか1つをメモリセルトランジスタMTに保持可能である。

## 【0034】

この、4値データ“xy”は、メモリセルトランジスタMTのしきい値電圧の順に、例えば、データ“11”、“01”、“00”、“10”が割り当てられる。データ“11”は、メモリセルトランジスタMTのしきい値電圧が負の消去状態である。

## 【0035】

下位ページ書き込み動作においては、データ“11”(消去状態)のメモリセルトランジスタMTに対して選択的に、下位ビットデータ“y”的書き込みによって、データ“10”が書き込まれる。上位ページ書き込み前のデータ“10”的しきい値分布は、上位ページ書き込み後のデータ“01”とデータ“00”的しきい値分布の中間程度に位置しており、上位ページ書き込み後のしきい値分布よりブロードであってもよい。上位ページ書き込み動作においては、データ“11”的メモリセルと、データ“10”的メモリセルに対して、それぞれ選択的に上位ビットデータ“x”的書き込みが行われて、データ“01”およびデータ“00”が書き込まれる。

## 【0036】

図3は、ドライブ制御回路4のハードウェア的な内部構成例を示すブロック図である。ドライブ制御回路4は、データアクセス用バス101、第1の回路制御用バス102、および第2の回路制御用バス103を備えている。第1の回路制御用バス102には、ドライブ制御回路4全体を制御するプロセッサ104が接続されている。第1の回路制御用バス102には、NANDメモリ10に記憶された各管理プログラム(FW:ファームウェア)をブートするブート用プログラムが格納されたブートROM105がROMコントローラ106を介して接続されている。また、第1の回路制御用バス102には、図1に示した電源回路5からのパワーオンリセット信号を受けて、リセット信号およびクロック信号を各部に供給するクロックコントローラ107が接続されている。

## 【0037】

第2の回路制御用バス103は、第1の回路制御用バス102に接続されている。第2の回路制御用バス103には、図1に示した温度センサ7からのデータを受けるためのI<sup>2</sup>C回路108、状態表示用LED6にステータス表示用信号を供給するパラレルIO(PIO)回路109、RS232C I/F3を制御するシリアルIO(SIO)回路110が接続されている。

## 【0038】

ATAインターフェースコントローラ(ATACコントローラ)111、第1のECC(Error Checking and Correction)回路112、NANDコントローラ113、およびDRAMコントローラ114は、データアクセス用バス101と第1の回路制御用バス102との両方に接続されている。ATACコントローラ111は、ATAインターフェース2を介してホスト装置1との間でデータを送受信する。データアクセス用バス101には、データ作業領域作業領域およびファームウェア展開領域として使用されるSRAM115がSRAMコントローラ116を介して接続されている。NANDメモリ10に記憶されているファームウェアは起動時、ブートROM105に記憶されたブート用プログラムによってSRAM115に転送される。

## 【0039】

NANDコントローラ113は、NANDメモリ10とのインターフェース処理を行うNAND I/F117、第2のECC回路118、およびNANDメモリ10-DRAM20間のアクセス制御を行うDMA転送制御用DMAコントローラ119を備えている。第2のECC回路118は第2の訂正符号のエンコードを行い、また、第1の誤り訂正符号のエンコードおよびデコードを行う。第1のECC回路112は、第2の誤り訂正符号

10

20

30

40

50

のデコードを行う。第1の誤り訂正符号、第2の誤り訂正符号は、例えば、ハミング符号、B C H (Bose Chaudhuri Hocqenghem) 符号、R S (Reed Solomon) 符号、或いは L D P C (Low Density Parity Check) 符号等であり、第2の誤り訂正符号の訂正能力は、第1の誤り訂正符号の訂正能力よりも高いとする。

#### 【0040】

図1および図3に示したように、N A N Dメモリ10においては、4つの並列動作要素10a～10dが各8ビットの4チャネル(4c h)を介して、ドライブ制御回路4内部のN A N Dコントローラ112に並列接続されている。4つの並列動作要素10a～10dを単独動作させるか、並列動作させるか、N A N Dメモリチップの備える倍速モード(Multi Page Program / Multi Page Read / Multi Block Erase)を使用するか否か、という組み合わせにより、下記3種類のアクセスモードが提供される。  
10

##### (1) 8ビットノーマルモード

1c hだけ動作させ、8ビット単位でデータ転送を行うモードである。物理ページサイズ(4 kB)で書き込み/読み出しが行われる。また、物理ブロックサイズ(512 kB)で消去が行われる。1つの物理ブロックに対して1つの論理ブロックが対応付けられ、論理ブロックサイズは512 kBとなる。

##### (2) 32ビットノーマルモード

4c h並列で動作させ、32ビット単位でデータ転送を行うモードである。物理ページサイズ×4(16 kB)で書き込み/読み出しが行われる。また、物理ブロックサイズ×4(2 MB)で消去が行われる。4つの物理ブロックに対して1つの論理ブロックが対応付けられ、論理ブロックサイズは2 MBとなる。  
20

##### (3) 32ビット倍速モード

4c h並列で動作させ、更に、N A N Dメモリチップの倍速モードを利用して書き込み/読み出しが行われるモードである。物理ページサイズ×4×2(32 kB)で書き込み/読み出しが行われる。また、物理ブロックサイズ×4×2(4 MB)で消去が行われる。8つの物理ブロックに対して1つの論理ブロックが対応付けられ、論理ブロックサイズは4 MBとなる。

#### 【0041】

4c h並列動作する32ビットノーマルモードまたは32ビット倍速モードでは、並列動作する4または8物理ブロックが、N A N Dメモリ10としての消去単位となり、並列動作する4または8物理ページが、N A N Dメモリ10としての書き込み単位および読み出し単位となる。以下の動作では、基本的に32ビット倍速モードを使用し、例えば、1論理ブロック=4 MB=2<sup>i</sup> トラック=2<sup>j</sup> ページ=2<sup>k</sup> クラスタ=2<sup>l</sup> セクタとして説明する(i、j、k、lは自然数、かつ、i < j < k < lの関係が成立する)。  
30

#### 【0042】

32ビット倍速モードでアクセスされる論理ブロックは4 MB単位であり、8個(2×4c h)の物理ブロック(1物理ブロック=512 KB)が対応付けられている。物理ブロック単位で管理されるバッドブロックB Bが発生すると、そのバッドブロックB Bは使用不可になるので、そのようなときには、論理ブロックに対応付けられた8個の物理ブロックの組み合わせが、バッドブロックB Bを含まないように変更される。  
40

#### 【0043】

図4は、プロセッサ104により実現されるファームウェアの機能構成例を示すプロック図である。プロセッサ104により実現されるファームウェアの各機能は、大きく、データ管理部120、A T Aコマンド処理部121、セキュリティ管理部122、ブートローダ123、初期化管理部124、デバッグサポート部125に分類される。

#### 【0044】

データ管理部120は、N A N Dコントローラ112、第1のE C C回路114を介して、N A N Dメモリ10-D R A M20間のデータ転送、N A N Dメモリ10に関する各種機能を制御する。A T Aコマンド処理部121は、A T Aコントローラ110、およびD R A Mコントローラ113を介して、データ管理部120と協動してD R A M20-ホ  
50

スト装置 1 間のデータ転送処理を行う。セキュリティ管理部 122 は、データ管理部 120 および ATA コマンド処理部 121 と協動して各種のセキュリティ情報を管理する。

#### 【0045】

ブートローダ 123 は、パワーオン時、各管理プログラム（ファームウェア）を NAND メモリ 10 から SRAM 120 にロードする。初期化管理部 124 は、ドライブ制御回路 4 内の各コントローラ / 回路の初期化を行う。デバッグサポート部 125 は、外部から RS232C インタフェースを介して供給されたデバッグ用データを処理する。主に、データ管理部 120、ATA コマンド処理部 121、およびセキュリティ管理部 122 が、SRAM 114 に記憶される各管理プログラムをプロセッサ 104 が実行することによって実現される機能部である。

10

#### 【0046】

本実施形態では、主としてデータ管理部 120 が実現する機能について説明する。データ管理部 120 は、ATA コマンド処理部 121 が記憶デバイスである NAND メモリ 10 や DRAM 20 に対して要求する機能の提供（ホスト装置からの Write 要求、Cache Flush 要求、Read 要求等の各種コマンドへの応答）と、アドレス領域と NAND メモリ 10 との対応関係の管理および管理情報の保護と、DRAM 10 および NAND メモリ 10 を利用した高速で効率の良いデータ読み出し / 書き込み機能の提供、NAND メモリ 10 の信頼性の確保などを行う。

#### 【0047】

図 5 は、NAND メモリ 10 および DRAM 20 内に形成された機能ブロックを示すものである。ホスト 1 と NAND メモリ 10 との間には、DRAM 20 上に構成されたライトキャッシュ (WC) 21 およびリードキャッシュ (RC) 22 が介在している。WC 21 はホスト装置 1 からの Write データを一時保存し、RC 22 は NAND メモリ 10 からの Read データを一時保存する。NAND メモリ 10 内の論理ブロックは、書き込み時の NAND メモリ 10 に対する消去の量を減らすために、データ管理部 120 により、前段ストレージ領域 (FS : Front Storage) 12、中段ストレージ領域 (IS : Intermediate Storage) 13 およびメインストレージ領域 (MS : Main Storage) 11 という各管理領域に割り当てられている。FS 12 は、WC 21 からのデータを「小さな単位」であるクラスタ単位に管理するものであり、小データを短期間保存する。IS 13 は、FS 12 から溢れたデータを「小さな単位」であるクラスタ単位に管理するものであり、小データを長期間保存する。MS 11 は、WC 21、FS 12、IS 13 からのデータを「大きな単位」であるトラック単位で長期間記憶する。例えば、記憶容量は、MS > IS、FS > WC の関係となる。

20

30

30

#### 【0048】

小さな管理単位を、NAND メモリ 10 の記憶領域全てに適用すると、後述する管理テーブルのサイズが肥大化し、DRAM 20 に収まらないので、小さな管理単位で管理するのは、最近書き込まれたばかりのデータと、NAND メモリ 10 への書き込み効率が悪い小さなデータのみとするように NAND メモリ 10 の各ストレージを構成している。

#### 【0049】

図 6 は、WC 21 から NAND メモリ 10 への書き込み処理 (WR 処理) に係わるより詳細な機能ブロック図を示すものである。FS 12 の前段には、WC 21 からのデータをバッファリングする FS インプットバッファ (FSIB) 12a が設けられている。また、MS 11 の前段には、WC 21、FS 12、または IS 13 からのデータをバッファリングする MS インプットバッファ (MSIB) 11a が設けられている。また、MS 11 には、トラック前段ストレージ領域 (TFS) 11b が設けられている。TFS 11b は、MSIB 11a と MS 11 の間に介在する FIFO (First in First out) 構造を有するバッファであり、TFS 11b に記録されたデータは、MSIB 11a から直接 MS 11 に書き込まれるデータよりも更新頻度が高いデータである。MS 11、MSIB 11a、TFS 11b、FS 12、FSIB 12a、および IS 13 には、NAND メモリ 10 内の各論理ブロックの何れかが割り当てられている。

40

50

## 【0050】

つぎに、図5、図6の各構成要素の具体的な機能構成について詳述する。ホスト装置1はSSD100に対し、ReadまたはWriteする際には、ATAインターフェースを介して論理アドレスとしてのLBA(Logical Block Addressing)を入力する。LBAは、図7に示すように、セクタ(サイズ:512B)に対して0からの通し番号をつけた論理アドレスである。本実施の形態においては、図5の各構成要素であるWC21、RC22、FS12、IS13、MS11の管理単位として、LBAの下位( $1 - k + 1$ )ビット目から上位のビット列で構成される論理クラスタアドレスと、LBAの下位( $1 - i + 1$ )ビットから上位のビット列で構成される論理トラックアドレスとを定義する。1クラスタ =  $2^{1 - k}$ セクタで、1トラック =  $2^{(k - i)}$ クラスタである。

10

## 【0051】

## ・リードキャッシュ( RC )22

RC22について説明する。RC22は、ATAコマンド処理部121からのRead要求に対して、NANDメモリ10(FS12、IS13、MS11)からのReadデータを一時的に保存するための領域である。RC22は、本実施形態では例えば、m-line、n-way(mは $2^{(k - i)}$ 以上の自然数、nは2以上の自然数)セットアソシティブ方式で管理されており、1エントリに1クラスタ分のデータを保持できる。論理クラスタアドレスの LSB( $k - i$ )ビットでlineが決定される。なお、RC22は、フルアソシティブ方式で管理されていても良いし、単純な FIFO方式で管理されていてもよい。

20

## 【0052】

## ・ライトキャッシュ( WC )21

WC21について説明する。WC21は、ATAコマンド処理部121からのWrite要求に対して、ホスト装置1からのWriteデータを一時的に保存するための領域である。m-line、n-way(mは $2^{(k - i)}$ 以上の自然数、nは2以上の自然数)セットアソシティブ方式で管理されており、1エントリに1クラスタ分のデータを保持できる。論理クラスタアドレスの LSB( $k - i$ )ビットでlineが決定される。例えば、way1 ~ waynの順で書き込み可能なwayが検索される。また、WC21に登録されているトラックは最も古く更新された順が分かるように後述するWCトラック管理テーブル24の FIFO構造によってLRU(Least Recently Used)で管理される。なお、WC21は、フルアソシティブ方式で管理されていても良い。また、WC21は、RC22とline数、way数が互いに異なっていてもよい。

30

## 【0053】

Write要求により書き込まれたデータは、一旦WC21上に格納される。WC21からNANDメモリ10へ追い出すデータの決定方法は以下のルールに従う。

(i) タグによって決定されたlineの書き込み可能なwayが最後の(本実施形態では、n個目の)空きwayだった場合、則ち最後の空きwayが使用される場合は、そのlineに登録されたトラックのうち、LRUに基づいて最も古く更新されたトラックを追い出し確定する。

(ii) WC21に登録されている異なるトラックの個数が所定数を超えた場合、LRU順で、当該トラックに属するWC中のクラスタ数が所定数未満のトラックの追い出しを確定する。

40

## 【0054】

以上の方針で追い出すトラックを決定する。その際、追い出すのは同一トラックに含まれる全てのデータであり、追い出されるデータ量が、例えばトラックサイズの50%を超えていればMS11へ、超えていなければFS12へ追い出す。

## 【0055】

さらに(i)の条件でトラック追い出しが発生した場合で、MS11へ追い出す場合は、追い出されるトラック数が $2^i$ 個(もともと $2^i$ 個以上のときは $2^{i+1}$ 個)になるまで、WC21内のトラックのうち上記追い出されるデータ量がトラックサイズの50%を超えるという条件を満たすトラックを上記(i)のポリシーで選択して追い出し候補に追加

50

する。別言すれば、追い出されるトラックが $2^i$ 個未満の場合、WC中のトラックの古いものから $2^i$ 個になるまで、 $2^{(k-i-1)}$ 個以上有効クラスタをもつトラックを選択して追い出し候補に追加する。

#### 【0056】

また、(i)の条件でトラック追い出しが発生した場合で、FS12に追い出す場合は、追い出されるクラスタ数が $2^k$ 個になるまでWC21内のトラックのうちLRU順に上記追い出されるデータ量がトラックサイズの50%未満であるという条件を満たすトラックを探してそのクラスタを追い出し候補に追加する。別言すれば、WC中のトラックを古い順に辿って $2^{(k-i-1)}$ 個未満の有効クラスタしかもたないトラックからクラスタを取り出していき、有効クラスタ数が $2^{(k-i-1)}$ 個になったら、それらクラスタをFSIB12aに論理ブロック単位で追い出しそる。ただし、 $2^{(k-i-1)}$ 個見つからなかつた場合は、FSIB12aに論理ページ単位で追い出しそる。なお、FS12への追い出しを論理ブロック単位とするか、論理ページ単位とするかの有効クラスタ数の閾値は、 $2^{(k-i-1)}$ 個という1論理ブロック分の値にかぎるわけではなく、1論理ブロック分より若干少ない値であつてもよい。

10

#### 【0057】

また、ATAコマンド処理部121からのCache Flush要求では、WC21の内容が全て、上記と同じ条件(追い出されるデータ量がトラックサイズの50%を超えていればMS11へ、超えていなければFS12へ)で、FS12もしくはMS11に対して追い出される。

20

#### 【0058】

##### ・前段ストレージ領域(FS)12

つぎに、FS12について説明する。FS12はクラスタ単位でデータを管理される FIFOである。FS12は、ここを通過しているデータは、後段のIS13よりも更新頻度が高いとみなすためのバッファである。すなわち、FS12のFIFO構造においては、FIFO中を通過中の有効クラスタ(最新クラスタ)は、ホストからの同じアドレスに対する再書き込みがあった場合無効化されるので、FS12を通過中のクラスタは、FS12からIS13やMS11に追い出されたクラスタよりも、更新頻度が高いとみなすことができる。

30

#### 【0059】

FS12を設けることで、後段のIS13におけるコンパクション処理に更新頻度の高いデータが紛れ込む可能性を低減している。無効化によって古いクラスタを保持していた論理ブロック自体の持つ有効クラスタ数が0となった場合、その論理ブロックは開放され、フリーブロックFBに割り当たられる。また、論理ブロックが無効化された場合、新たなフリーブロックFBを取得し、FS12に割り当てる。

#### 【0060】

WC21からFS12に対してクラスタデータの移動が発生すると、そのクラスタはFSIB12aに割り当たられた論理ブロックに対して書き込まれる。FSIB12a中に全てのページの書き込みが完了したブロックが存在する場合、後述するCIB処理によってそれらのブロックはFSIB12aからFS12にMoveされる。このFSIB12aからFS12へのMoveの際に、FS12のブロック数がFS12として許容される所定の上限値を超えると、最も古いブロックがFS12からIS13またはMS11に追い出されることになる。例えば、トラック内の有効クラスタの割合が50%以上のトラックは、MS11(TFS11b)への書き込みを行い、有効クラスタが残ったブロックを、IS13へMoveする。

40

#### 【0061】

NANDメモリ10内の構成要素間のデータ移動には、MoveとCopyの二通りがある。Moveは、後述する管理テーブルのポインタの付け替えを行うだけで、実際のデータの書き換えは行わない方法である。Copyは、一方の構成要素に格納されているデータを、ページ単位、トラック単位、ブロック単位で他方の構成要素に実際に書き換える

50

方法である。

【0062】

・中段ストレージ領域 (IS) 13

つぎに、IS13について説明する。IS13は、FS13と同様にクラスタ単位でデータの管理が行われる。前述したように、IS13に格納されたデータは、更新頻度が低いデータとみなすことができる。FS12からIS13に対して論理ブロックの移動 (Move)、すなわちFS12からの追い出しが発生すると、以前FS12の管理対象であった追い出し対象の論理ブロックはポインタの付け替えによりIS13の管理対象ブロックとなる。このFS12からIS13への論理ブロックの移動により、IS13のブロック数がIS13として許容される所定の上限値を超えると、すなわちIS内の書き込み可能なフリーブロックFBの数が閾値を下回ると、IS13からMS11へのデータ追い出しありコンパクション処理が実行され、IS13のブロック数は規定値に戻される。

【0063】

IS13では、トラック内の有効クラスタ数を使って以下のような、追い出し処理およびコンパクション処理を、実行する。

・トラックをトラック内の有効クラスタ数 × 有効クラスタ係数(トラックがMS11内で無効トラックが存在する論理ブロックに存在するか否かによって重み付けされる数であり、存在したほうが存在しない場合より数が大きい)順にソートし、積の値が大きいトラック  $2^{i+1}$  個 (2論理ブロック分)を集めて論理ブロックサイズの自然数倍にしてMSIB11aに追い出す。

・有効クラスタ数が最も少ない2つの論理ブロックの合計有効クラスタ数が例えば、所定の設定値である  $2^k$  個 (1論理ブロック分) 以上ある場合は、上のステップを繰り返す (IS内の2つの論理ブロックから、フリーブロックFBを作れるようになるまで行うため)。

・有効クラスタ数の少ない論理ブロックから順にクラスタを  $2^k$  個集め、IS13内でコンパクションを行う。

なお、ここでは有効クラスタ数が最も少ない2つの論理ブロックを選択するが、この数は2つに限定されず、2つ以上の数であればよい。また、所定の設定値は、選択する論路ブロック数よりも1つ少ない論理ブロック数に収容可能なクラスタ数以下であればよい。

【0064】

・メインストレージ領域 (MS) 11

つぎに、MS11について説明する。MS11はトラック単位でデータの管理を行う。MS11に格納されたデータは、更新頻度が低いとみなすことができる。WC21、FS12、IS13からMS11に対してトラックデータのCopyまたはMoveが発生すると、そのトラックはMSIS11aに割り当てられた論理ブロックに対して書き込まれる。一方で、トラック中の一部のデータ(クラスタ)のみがWC等から書き込まれる場合には、既存のMS中のトラックデータと新しいデータをマージして新しいトラックデータを作った上でMSIB11aに書き込む、後述する受動マージが行われる。MS11内に無効トラックが蓄積し、MS11に割り当てられている論理ブロックの個数がMS11として許容されるブロック数の上限値を超えるような状況が発生すると、コンパクション処理を行って、無効なフリーブロックFBを作る。

【0065】

MS11のコンパクション処理は、例えば、論理ブロック内の有効トラック数のみに注目した以下の方法を実施する。

・有効トラックが少ない論理ブロックから順番に、無効トラックを合わせることによって無効なフリーブロックFBが作れるようになるまで選択する。

・選択した論理ブロックに収容されたトラックを、WC21、FS12、IS13内のデータと統合する受動マージを行いながらコンパクションを実行する。

・ $2^i$  トラック統合できた論理ブロックは、TFS11bに出力し ( $2^i$  トラック MS

10

20

30

40

50

コンパクション)、 $2^i$  トラックに満たない個数のトラックは、MSIB11aに出力して( $2^i$  トラック未満コンパクション)、より多くの無効なフリープロックFBを作る。

【0066】

TFSS11bは、トラック単位でデータを管理される FIFOである。TFSS11bは、ここを通過しているデータは、後段のMS11よりも更新頻度が高いとみなすためのバッファである。すなわち、TFSS11bのFIFO構造においては、FIFO中を通過中の有効トラック(最新トラック)は、ホストからの同じアドレスに対する再書き込みがあった場合無効化されるので、TFSS11bを通過中のトラックは、TFSS11bからMS11に追い出されたトラックよりも、更新頻度が高いとみなすことができる。

【0067】

図8は、データ管理部120が図5および図6に示した各構成要素を制御管理するための管理テーブルを示すものである。データ管理部120は、前述したように、ATAコマンド処理部121とNANDメモリ10とをブリッジする機能を有し、DRAM20に記憶したデータの管理を行うDRAM層管理部120aと、NANDメモリ10に記憶したデータの管理を行う論理NAND層管理部120bと、NANDメモリ10を物理記憶デバイスとして管理する物理NAND層管理部120cとから構成される。RCクラスタ管理テーブル23、WCトラック管理テーブル24、WCクラスタ管理テーブル25は、DRAM層管理部120aにより制御される。トラック管理テーブル30、FS/IS管理テーブル40、MS論理ロック管理テーブル35、FS/IS論理ロック管理テーブル42、FS/IS内クラスタ管理テーブル44は、論理NAND層管理部120bにより管理される。論物変換テーブル50は、物理NAND層管理部120cにより管理される。

10

【0068】

RC22は、逆引きテーブルであるRCクラスタ管理テーブル23によって管理される。逆引きテーブルでは、記憶デバイスの位置からその位置に記憶されている論理アドレスを検索することができる。WC21は、逆引きテーブルであるWCクラスタ管理テーブル25および正引きテーブルであるWCトラック管理テーブル24によって管理される。正引きテーブルでは、論理アドレスからその論理アドレスに対応するデータが存在する記憶デバイス位置を検索することができる。

20

【0069】

30

NANDメモリ10内のFS12(FSIB12a)、IS13、MS11(TFSS11b、MSIB11a)は、トラック管理テーブル30、FS/IS管理テーブル40、MS論理ロック管理テーブル35、FS/IS論理ロック管理テーブル42、FS/IS内クラスタ管理テーブル44によってその論理アドレスが管理される。また、NANDメモリ10内のFS12(FSIB12a)、IS13、MS11(TFSS11b、MSIB11a)は、論物変換テーブル50によって論理アドレスと物理アドレスとの変換が行われる。これらの各管理テーブルは、NANDメモリ10上の領域に記憶されており、SSD100の初期化時にNANDメモリ10からDRAM20上に読み込まれて、使用される。

【0070】

40

・RCクラスタ管理テーブル23(逆引き)

まず、図9を用いてRCクラスタ管理テーブル23について説明する。RC22は、前述したように、論理クラスタアドレスLSB(k-i)ビットでインデックスされるn-wayセットアソシティブ方式で管理されている。RCクラスタ管理テーブル23は、RC(クラスタサイズ×m-line×n-way)22の各エントリのタグを管理するためのテーブルであり、各タグは、複数ビットの状態フラグ23aと、論理トラックアドレス23bによって構成されている。状態フラグ23aには、当該エントリを使用しても良いか否か(有効/無効)を示すValidビットの他に、当該エントリがNANDメモリ10からの読み出し待ちか否かを示すビット、当該エントリがATAコマンド処理部121への読み出し待ちか否かを示すビットなどが含まれる。RCクラスタ管理テーブル23は、DRAM2

50

0上のタグ記憶位置からLBAに一致する論理トラックアドレスを検索する逆引きテーブルとして機能する。

#### 【0071】

##### ・WCクラスタ管理テーブル25(逆引き)

つぎに、図10を用いてWCクラスタ管理テーブル25について説明する。WC21は、前述したように、論理クラスタアドレスLSB(k-i)ビットでインデックスされるn-wayセットアソシアティブ方式で管理されている。WCクラスタ管理テーブル25は、WC(クラスタサイズ×m-line×n-way)21の各エントリのタグを管理するためのテーブルであり、各タグは、複数ビットの状態フラグ25aと、セクタ位置ビットマップ25bと、論理トラックアドレス25cによって構成されている。

10

#### 【0072】

状態フラグ25aには、当該エントリを使用しても良いか否か(有効/無効)を示すValidビットの他に、当該エントリがNANDメモリ10への追い出し待ちか否かを示すビット、当該エントリがATAコマンド処理部からの書き込み待ちか否かを示すビットなどが含まれる。セクタ位置ビットマップ25bは、1クラスタに含まれる $2^{(1-k)}$ セクタのうちのどのセクタに有効なデータを保持しているかを $2^{(1-k)}$ ビットに展開して示すものである。このセクタ位置ビットマップ25bによって、WC21において、LBAと同じセクタ単位の管理を行うことができる。WCクラスタ管理テーブル25は、DRAM20上のタグ記憶位置からLBAに一致する論理トラックアドレスを検索する逆引きテーブルとして機能する。

20

#### 【0073】

##### ・WCトラック管理テーブル24(正引き)

つぎに、図11を用いてWCトラック管理テーブル24について説明する。WCトラック管理テーブル24は、WC21上に格納されているクラスタをトラック単位でまとめた情報を管理するものであり、FIIFO的な機能を有するリンクリスト構造によってトラック間のWC21に登録された順序(LRU)を表現している。なお、WC21で最後に更新された順序によってLRUを表現するようにしてもよい。各リストのエントリは、論理トラックアドレス24a、当該論理トラックアドレスに含まれるWC21中の有効クラスタ数24b、way-lineビットマップ24cおよび次のエントリへのポインタを示すnextポインタ24dから構成されている。WCトラック管理テーブル24は、論理トラックアドレス24aから所要情報を得るので、正引きテーブルとして機能する。

30

#### 【0074】

way-lineビットマップ24cは、WC21中で当該論理トラックアドレスに含まれる有効クラスタがWC21中のm×nのエントリ中のどのエントリに格納されているか示すマップ情報であり、有効クラスタが格納されているエントリではValidビットが”1”になっている。このway-lineビットマップ24cは、例えば、(1ビット(Valid) +  $\log_2 n$ ビット(n-way)) × mビット(m-line)で構成されている。WCトラック管理テーブル24はリンクリスト構造を有しており、WC21中に存在する論理トラックアドレスに関する情報のみがエントリされている。

40

#### 【0075】

##### ・トラック管理テーブル30(正引き)

つぎに、図12を用いてトラック管理テーブル30について説明する。トラック管理テーブル30は、論理トラックアドレス単位でMS11上の論理的なデータ位置を管理するためのテーブルであり、クラスタ単位でFS12やIS13にデータが保持されている場合には、それらに関する基本情報と、詳細情報へのポインタも保持している。論理トラックアドレス30aをインデックスとした配列形式で構成される。論理トラックアドレス30aをインデックスとした各エントリは、クラスタビットマップ30b、論理ブロックID30c + 論理ブロック内トラック位置30d、クラスタテーブルポインタ30e、FSクラスタ数30f、ISクラスタ数30gなどの情報で構成されている。トラック管理テーブル30は、論理トラックアドレスをインデックスとして、その論理トラックアドレス

50

に対応する論理トラックが記憶されている論理ブロックID（記憶デバイス位置に対応）などの所要情報を得るので、正引きテーブルとして機能する。

#### 【0076】

クラスタビットマップ30bは、1つの論理トラックアドレス範囲に属する $2^{(k-i)}$ 個のクラスタをクラスタアドレス昇順に例えれば8分割したビットマップであり、8個の各ビットは、 $2^{(k-i-3)}$ 個のクラスタアドレスに対応するクラスタがMS11に存在するか、FS12もしくはIS13に存在するかを示している。ビットが“0”的場合は、その検索対象のクラスタは確実にMS11内に存在することを示し、ビットが“1”的場合は、そのクラスタはFS12もしくはIS13に存在する可能性があることを示している。

10

#### 【0077】

論理ブロックID30cは、当該論理トラックアドレスに対応する論理トラックが記憶されている論理ブロックIDを識別するための情報である。論理ブロック内トラック位置30dは、論理ブロックID30cで指定された論理ブロック中における当該論理トラックアドレス(30a)に対応するトラックの記憶位置を示すものである。1論理ブロックは最大 $2^i$ 個の有効トラックで構成されるので、論理ブロック内トラック位置30dは、iビットで $2^i$ 個のトラック位置を識別する。

#### 【0078】

クラスタテーブルポインタ30eは、リンクリスト構造を有するFS/IS管理テーブル40の各リストの先頭エントリへのポインタである。クラスタビットマップ30bの検索で、当該クラスタがFS12/IS13に存在する可能性があることを示していた場合、クラスタテーブルポインタ30eを用いてFS/IS管理テーブル40の検索を実行する。FSクラスタ数30fは、FS12内に存在する有効クラスタ数を示している。ISクラスタ数30gは、IS13内に存在する有効クラスタ数を示している。

20

#### 【0079】

##### ・FS/IS管理テーブル40（正引き）

つぎに、図13を用いてFS/IS管理テーブル40について説明する。FS/IS管理テーブル40は、論理クラスタ単位でFS12(FSIB12aも含む)もしくはIS13に保持されているデータの位置を管理するためのテーブルである。図13に示すように、論理トラックアドレス毎に独立したリンクリスト形式で構成され、各リストの先頭エントリへのポインタは、前述したように、トラック管理テーブル30のクラスタテーブルポインタ30eのフィールドに保持されている。図13では、2つの論理トラックアドレス分のリンクリストが示されている。各エントリは、論理クラスタアドレス40a、論理ブロックID40b、論理ブロック内クラスタ位置40c、FS/ISブロックID40d、nextポインタ40eから構成されている。FS/IS管理テーブル40は、論理クラスタアドレス40aから、その論理クラスタアドレスに対応する論理クラスタが記憶されている論理ブロックID40b、論理ブロック内クラスタ位置40c（記憶デバイス位置に対応）などの所要情報を得るので、正引きテーブルとして機能する。

30

#### 【0080】

論理ブロックID40bは、当該論理クラスタアドレス40aに対応する論理クラスタが記憶されている論理ブロックIDを識別するための情報である。論理ブロック内クラスタ位置40cは、論理ブロックID40bで指定された論理ブロック中における当該論理クラスタアドレス40aに対応するクラスタの記憶位置を示すものである。1論理ブロックは最大 $2^k$ 個の有効クラスタで構成されるので、論理ブロック内クラスタ位置40cは、kビットで $2^k$ 位置を識別する。FS/ISブロックID40dは、後述するFS/IS論理ブロック管理テーブル42のインデックスであるFS/ISブロックIDが登録されている。FS/ISブロックIDは、FS12またはIS13に所属する論理ブロックを識別するための情報であり、このFS/IS管理テーブル40でのFS/ISブロックID40dは、後述するFS/IS論理ブロック管理テーブル42とのリンクのために登録されている。nextポインタ40eは、論理トラックアドレス毎にリンクされる同じリス

40

50

ト内の次のエントリへのポインタを示している。

【0081】

・MS論理ブロック管理テーブル35(逆引き)

つぎに、図14を用いてMS論理ブロック管理テーブル35について説明する。MS論理ブロック管理テーブル35は、MS11に用いられている論理ブロックに関する情報(どの論理トラックが記憶されているか、追記可能か等)を一元管理するためのテーブルである。なお、MS論理ブロック管理テーブル35には、FS12(FSIB12も含む)、IS13に所属する論理ブロックに関する情報も登録されている。MS論理ブロック管理テーブル35は、論理ブロックID35aをインデックスとした配列形式で構成され、エントリ数は128GBのNANDメモリ10の場合は、32Kエントリまで持つことができる。各エントリは、 $2^i$ トラック分のトラック管理ポインタ35b、有効トラック数35c、書き込み可能先頭トラック35d、Validフラグ35eから構成されている。このMS論理ブロック管理テーブル35は、記憶デバイス位置に対応する論理ブロックID35aから、この論理ブロックに記憶されている論理トラックアドレスなどの所要情報を得るので、逆引きテーブルとして機能する。

【0082】

トラック管理ポインタ35bは、論理ブロックID35aで指定される当該論理ブロック内の $2^i$ 個のトラック位置毎に対応する論理トラックアドレスを保持する。この論理トラックアドレスを用いて、論理トラックアドレスをインデックスとするトラック管理テーブル30を検索することができる。有効トラック数35cは、論理ブロックID35aで指定される当該論理ブロックに記憶されているトラックのうちの有効なものの個数(最大 $2^i$ 個)を示している。書き込み可能先頭トラック位置35dは、論理ブロックID35aで指定される当該論理ブロックが追記中のブロックであった場合における追記可能なトラック先頭位置(0~ $2^i$ -1、追記終了時は $2^i$ )を示している。Validフラグ35eは、当該論理ブロックエントリがMS11(MSIB11aも含む)として管理されている場合に“1”である。

【0083】

・FS/IS論理ブロック管理テーブル42(逆引き)

つぎに、図15を用いてFS/IS論理ブロック管理テーブル42について説明する。FS/IS論理ブロック管理テーブル42は、FS/ISブロックID42aをインデックスとした配列形式で構成され、FS12またはIS13として利用されている論理ブロックに関する情報(論理ブロックIDとの対応、FS/IS内クラスタ管理テーブル44へのインデックス、追記可能か等)を管理するためのテーブルである。FS/IS論理ブロック管理テーブル42は、主にFS/IS管理テーブル40中のFS/ISブロックID40dを用いてアクセスされる。各エントリは、論理ブロックID42b、ブロック内クラスタテーブル42c、有効クラスタ数42d、書き込み可能先頭ページ42e、Validフラグ42fから構成されている。このMS論理ブロック管理テーブル35は、記憶デバイス位置に対応するFS/ISブロックID42aから、この論理ブロックに記憶されている論理クラスタなどの所要情報を得るので、逆引きテーブルとして機能する。

【0084】

論理ブロックID42bには、MS論理ブロック管理テーブル35に登録された論理ブロックの中で、FS12(FSIB12も含む)、IS13に所属している論理ブロックに対応する論理ブロックIDが登録される。ブロック内クラスタテーブル42cには、論理ブロック中の各クラスタ位置にどの論理クラスタアドレスで指定される論理クラスタが記録されているかを示す後述するFS/IS内クラスタ管理テーブル44へのインデックスが登録される。有効クラスタ数42dは、FS/ISブロックID42aで指定される当該論理ブロックに記憶されているクラスタのうちの有効なものの個数(最大 $2^k$ 個)を示している。書き込み可能先頭ページ位置42eは、FS/ISブロックID42aで指定される当該論理ブロックが追記中のブロックであった場合における追記可能な先頭ページ位置(0~ $2^j$ -1、追記終了時は $2^j$ )を示している。Validフラグ42fは、この

論理ブロックエントリがFS12 (FSIB12も含む) またはIS13として管理されている場合に“1”である。

#### 【0085】

##### ・FS/IS内クラスタ管理テーブル44 (逆引き)

つぎに、図16を用いてFS/IS内クラスタ管理テーブル44について説明する。FS/IS内クラスタ管理テーブル44は、FS12もしくはIS13として利用されている論理ブロック中の各クラスタ位置にどの論理クラスタが記録されているのかを示すテーブルである。1論理ブロックあたり、 $2^j$ ページ× $2^{(k-j)}$ クラスタ =  $2^k$ 個のエントリを持ち、当該論理ブロック内のクラスタ位置の0番目～ $2^k - 1$ 番目に対応する情報が連続領域に配置される。さらにこの $2^k$ 個の情報を含むテーブルがFS12およびIS13に所属する論理ブロック数 (P個) 分だけ保持されており、FS/IS論理ブロック管理テーブル42のブロック内クラスタテーブル42cは、このP個のテーブルに対する位置情報 (ポインタ) となっている。連続領域に配される各エントリ44aの位置は、1論理ブロック中のクラスタ位置を示し、また各エントリ44aの内容は、当該クラスタ位置にどの論理クラスタが記憶されているかが識別できるように、FS/IS管理テーブル40で管理される該当論理クラスタアドレスを含むリストへのポインタが登録されている。すなわち、エントリ44aは、リンクリストの先頭を指示するのではなく、リンクリスト中の該当論理クラスタアドレスを含む1つのリストへのポインタが登録されている。

10

#### 【0086】

##### ・論物変換テーブル50 (正引き)

つぎに、図17を用いて論物変換テーブル50について説明する。論物変換テーブル50は、論理ブロックID50aをインデックスとした配列形式で構成され、エントリ数は、128GBのNANDメモリ10の場合は、最大32Kエントリまで持つことができる。論物変換テーブル50は、論理ブロックIDと物理ブロックIDとの変換、寿命に関する情報を管理するためのテーブルである。各エントリは、物理ブロックアドレス50b、消去回数50c、読み出し回数50dから構成される。この論物変換テーブル50は、論理ブロックIDから物理ブロックID (物理ブロックアドレス) などの所要情報を得るので、正引きテーブルとして機能する。

20

#### 【0087】

物理ブロックアドレス50bは、1つの論理ブロックID50aに所属する8個の物理ブロックID (物理ブロックアドレス) を示している。消去回数50cは、当該論理ブロックIDの消去回数を示している。バッドブロック (BB) 管理は、物理ブロック (512KB) 単位に行われるが、消去回数の管理は、32ビット倍速モードによる1論理ブロック (4MB) 単位に管理される。読み出し回数50dは、当該論理ブロックIDの読み出し回数を示している。消去回数50cは、例えば、NAND型フラッシュメモリの書き換え回数を平準化するウェアアレベリング処理で利用することが可能である。読み出し回数50dは、リテンション特性の劣化した物理ブロックに保持されるデータの再書き込みを行うリフレッシュ処理で利用することが可能である。

30

#### 【0088】

図8に示した管理テーブルを管理対象毎にまとめると次のようになる。

RC管理 : RCクラスタ管理テーブル

WC管理 : WCクラスタ管理テーブル、WCトラック管理テーブル

MS管理 : トラック管理テーブル30、MS論理ブロック管理テーブル35

FS/IS管理 : トラック管理テーブル30、FS/IS管理テーブル40、MS論理ブロック管理テーブル35、FS/IS論理ブロック管理テーブル42、FS/IS内クラスタ管理テーブル44

40

#### 【0089】

なお、MS構造管理テーブル (図示せず)において、MS11, MSIB11a、TF S11bを含めたMS領域の構造を管理しており、具体的には、MS11、MSIB11

50

a、TFS11bに割り当てた論理ブロックなどを管理している。また、FS/IS構造管理テーブル(図示せず)において、FS12、FSIB12a、IS13を含めたFS/IS領域の構造を管理しており、具体的には、FS12、FSIB12a、IS13に割り当てた論理ブロックなどを管理している。

#### 【0090】

##### ・Read処理

つぎに、図18に示すフローチャートを参照して、読み出し処理について説明する。ATAコマンド処理部121から、Readコマンドおよび読み出しアドレスとしてのLBAが入力されると、データ管理部120は、図9に示したRCクラスタ管理テーブル23と図10に示したWCクラスタ管理テーブル25を検索する(ステップS100)。具体的には、LBAのクラスタアドレスのLSB(k-i)ビット(図7参照)に対応するlineをRCクラスタ管理テーブル23とWCクラスタ管理テーブル25から選択し、選択したlineの各wayにエントリされている論理トラックアドレス23b、25cをLBAのトラックアドレスと比較し(ステップS110)、一致したwayが存在している場合は、キャッシュヒットとし、ヒットしたRCクラスタ管理テーブル23またはWCクラスタ管理テーブル25の該当line、該当wayに対応するWC21またはRC22のデータを読み出して、ATAコマンド処理部121に送る(ステップS115)。

#### 【0091】

データ管理部120は、RC22またはWC21でヒットしなかった場合は(ステップS110)、検索対象のクラスタがNANDメモリ10のどこに格納されているかを検索する。データ管理部120は、まず、図12に示したトラック管理テーブル30を検索する(ステップS120)。トラック管理テーブル30は、論理トラックアドレス30aでインデックスされているため、LBAで指定された論理トラックアドレスに一致する論理トラックアドレス30aのエントリだけをチェックする。

#### 【0092】

まず、チェックしたいLBAの論理クラスタアドレスに基づいてクラスタビットマップ30bから対応するビットを選択する。対応するビットが“0”を示していれば、そのクラスタは確実にMS内に最新のデータが存在していることを意味する(ステップS130)。この場合は、このトラックが存在する論理ブロックIDおよびトラック位置を、同じ論理トラックアドレス30aのエントリ中の論理ブロックID30cと論理ブロック内トラック位置30dから得て、さらにLBAのクラスタアドレスのLSB(k-i)ビットを利用して、トラック位置からのオフセットを算出することで、NANDメモリ10内の当該クラスタアドレスに対応するクラスタデータが格納されている位置を算出することができる。具体的には、論理NAND層管理部120bでは、上記のようにしてトラック管理テーブル30から取得した論理ブロックID30cと論理ブロック内トラック位置30dと、LBAの論理クラスタアドレスのLSB(k-i)ビットを物理NAND層管理部120cに与える。

#### 【0093】

物理NAND層管理部120cでは、論理ブロックID30cに対応する物理ブロックアドレス(物理ブロックID)を、論理ブロックIDをインデックスとしている図17に示す論物変換テーブル50から取得し(ステップS160)、さらに取得した物理ブロックID中のトラック位置(トラック先頭位置)を論理ブロック内トラック位置30dから算出し、さらにLBAのクラスタアドレスのLSB(k-i)ビットから、前記算出した物理ブロックID中のトラック先頭位置からのオフセットを算出することで、物理ブロック中のクラスタデータを取得することができる。NANDメモリ10のMS11から取得されたクラスタデータは、RC22を介してATAコマンド処理部121に送られる(ステップS180)。

#### 【0094】

一方、LBAのクラスタアドレスに基づくクラスタビットマップ30bの検索で、対応するビットが“1”を示していた場合は、そのクラスタがFS12またはIS13に格納

されている可能性がある（ステップS130）。この場合は、トラック管理テーブル30の該当する論理トラックアドレス30aのエントリ中のクラスタテーブルポインタ30eのエントリを取り出し、このポインタを用いてFS/IS管理テーブル40の該当する論理トラックアドレスに対応するリンクリストを順次検索する（ステップS140）。具体的には、該当する論理トラックアドレスのリンクリスト中のLBAの論理クラスタアドレスに一致する論理クラスタアドレス40aのエントリを検索し、一致する論理クラスタアドレス40aのエントリが存在した場合は（ステップS150）、一致したリスト中の論理ブロックID40bおよび論理ブロック内クラスタ位置40cを取得し、前述と同様にして、論物変換テーブル50を用いて物理ブロック中のクラスタデータを取得する（ステップS160、S180）。具体的には、取得した論理ブロックIDに対応する物理ブロックアドレス（物理ブロックID）を、論物変換テーブル50から取得し（ステップS160）、さらに取得した物理ブロックID中のクラスタ位置を、論理ブロック内クラスタ位置40cのエントリから取得した論理ブロック内クラスタ位置から算出することで、物理ブロック中のクラスタデータを取得することができる。NANDメモリ10のFS12またはIS13から取得されたクラスタデータは、RC22を介してATAコマンド処理部121に送られる（ステップS180）。

#### 【0095】

このFS/IS管理テーブル40の検索によって、検索対象のクラスタが存在しなかつた場合は（ステップS150）、再度トラック管理テーブル30のエントリを検索してMS11上の位置を確定する（ステップS170）。

#### 【0096】

##### ・Write処理

つぎに、図19に示すフローチャートを参照して、書き込み処理について説明する。FUA（DRAMキャッシュをバイパスしてNANDへの直接書き込みを行う）でないWriteコマンドにより書き込まれたデータは必ず一旦WC21上に格納され、その後条件に応じてNANDメモリ10に対して書き込まれることになる。書き込み処理では、追い出し処理、コンパクション処理が発生する可能性がある。この実施の形態では、書き込み処理を、ライトキャッシュフラッシュ処理（以下WCF処理）と、クリーンインプットバッファ処理（以下CIB処理）との2ステージに大きく分割している。ステップS300からステップS320までは、ATAコマンド処理部121からのWrite要求からWCFL処理までを示しており、ステップS330～最終ステップまでがCIB処理を示している。

#### 【0097】

WCFL処理は、WC21にあるデータをNANDメモリ10（FS12のFSIB12aまたはMS11のMSIB11a）にcopyする処理であり、ATAコマンド処理部121からのWrite要求もしくはCache Flush要求単体は、この処理のみで完結することができる。これにより処理が開始されたATAコマンド処理部121のWrite要求の処理遅延を最大でもWC21の容量分のNANDメモリ10への書き込み時間に限定することができるようになる。

#### 【0098】

CIB処理は、WCFL処理によって書き込まれたFSIB12aのデータをFS12にMoveする処理と、WCFL処理によって書き込まれたMSIB11aのデータをMS11にMoveする処理とを含む。CIB処理を開始すると、連鎖的にNANDメモリ10内の各構成要素（FS12、IS13、MS11など）間のデータ移動やコンパクション処理が発生する可能性があり、処理全体に要する時間は状態によって大きく変化する。

#### 【0099】

まず、WCFL処理の詳細について説明する。ATAコマンド処理部121から、Writeコマンドおよび書き込みアドレスとしてのLBAが入力されると、DRAM層管理部120は、図10に示したWCクラスタ管理テーブル25を検索する（ステップS300、S305）。WC21の状態は、図10に示したWCクラスタ管理テーブル25の状態フラグ25a（例えば3ビット）によって規定されている。状態フラグ25aは、最も典型的

には、Invalid(使用可能) ATAからの書き込み待ち Valid(使用不可) NANDへの追い出し待ち Invalid(使用可能) という順に状態が遷移していく。まず、LBAのクラスタアドレス LSB(k-i) ビットから書き込み先のlineを決定し、決定したlineのn個のwayを検索する。決定したlineのn個のway中に、入力されたLBAと同じ論理トラックアドレス 25c が格納されている場合は(ステップ S305)、このエントリに上書きするのでこのエントリをクラスタ書き込み用に確保する(Valid(使用不可) ATAからの書き込み待ち)。

#### 【0100】

そして、DRAM層管理部 120a は、該当エントリに対応するDRAMアドレスをATAコマンド処理部 121 に通知する。ATAコマンド処理部 121 による書き込みが終了すると、WCクラスタ管理テーブル 25 の該当エントリの状態フラグ 25a をValid(使用不可) にし、さらにセクタ位置ビットマップ 25b および論理トラックアドレス 25c の欄に所要のデータを登録する。また、WCトラック管理テーブル 24 を更新する。具体的には、WCトラック管理テーブル 24 の各リスト中に既に登録済みの論理トラックアドレス 24a と同じ LBA アドレスが入力された場合は、該当するリストのWCクラスタ数 24b、way-lineビットマップ 24c を更新するとともに、当該リストが最新のリストとなるようにnextポインタ 24d を変更する。また、WCトラック管理テーブル 24 の各リスト中に登録済みの論理トラックアドレス 24a と異なる LBA アドレスが入力された場合は、新たに新しい論理トラックアドレス 24a、WCクラスタ数 24b、way-lineビットマップ 24c、nextポインタ 24d の各エントリを有するリストを作成し、最新のリストとして登録する。以上のようなテーブル更新を行って、書き込み処理が完了する(ステップ S320)。

#### 【0101】

一方、決定したlineのn個のway中に、入力されたLBAと同じ論理トラックアドレス 25c が格納されていない場合は、NANDメモリへの追い出しが必要であるか否かを判断する(ステップ S305)。すなわち、まず、決定したline中の書き込み可能なwayが最後のn個目のwayであるか否かを判断する。書き込み可能なwayとは、Invalid(使用可能) の状態フラグ 25a をもつwayがある場合はValid(使用不可) でかつNANDへの追い出し待ちの状態フラグ 25a を持つwayである。状態フラグ 25a が、NANDへの追い出し待ちであるとは、追い出しが開始されて追い出しの終了待ちであることを意味する。そして、書き込み可能なwayが最後のn個目のwayでない場合であって、かつ書き込み可能なwayが、Invalid(使用可能) の状態フラグ 25a をもつwayである場合は、このエントリをクラスタ書き込み用に確保する(Invalid(使用可能) ATAからの書き込み待ち)。そして、該当エントリに対応するDRAMアドレスをATAコマンド処理部 121 に通知し、ATAコマンド処理部 121 によって書き込みを実行させる。そして、前記同様、WCクラスタ管理テーブル 25 およびWCトラック管理テーブル 24 を更新する(ステップ S320)。

#### 【0102】

また、書き込み可能なwayが最後のn個目のwayでない場合であって、かつ書き込み可能なwayが、Valid(使用不可) でかつNANDへの追い出し待ちの状態フラグ 25a を持つwayである場合は、このエントリをクラスタ書き込み用に確保する(Valid(使用不可) でかつNANDへの追い出し待ち Valid(使用不可) でかつNANDへの追い出し待ちかつATAからの書き込み待ち)。そして、追い出しが終了すると、状態フラグ 25a をATAからの書き込み待ちにし、さらに、該当エントリに対応するDRAMアドレスをATAコマンド処理部 121 に通知し、ATAコマンド処理部 121 によって書き込みを実行させる。そして、前記同様、WCクラスタ管理テーブル 25 およびWCトラック管理テーブル 24 を更新する(ステップ S320)。

#### 【0103】

以上の処理は、ATAコマンド処理部 121 からからの書き込み要求が入力された際に、追い出し処理をトリガしなくてもよい場合である。一方、この後の説明は、書き込み要

求が入力された時点後に、追い出し処理をトリガする場合である。ステップS305において、決定したline中の書き込み可能なwayが最後のn個目のwayである場合は、前述したWC21からNANDメモリ10へ追い出すデータの決定方法の(i)の箇所で説明した条件、すなわち、

(i) タグによって決定されたlineの書き込み可能なwayが最後の(本実施形態では、n個目の)空きwayだった場合、則ち最後の空きwayが使用される場合は、そのlineに登録されたトラックのうちLRUに基づいて最も古く更新されたトラックを追い出し確定するに基づいて追い出すトラックすなわちWC21内エントリを選択する。

#### 【0104】

DRAM層管理部120aは、以上の方針で追い出すトラックを決定すると、前述したように、その際追い出すのは同一トラックに含まれるWC21中の全クラスタであり、追い出されるクラスタ量がトラックサイズの50%を超えていれば、すなわち追い出し確定トラックのうちWC中に有効クラスタ数が $2^{(k-i-1)}$ 個以上ある場合は、MSIB11aへ追い出しを行い(ステップS310)、超えていなければ、すなわち追い出し確定トラックのうちWC中に有効クラスタ数が $2^{(k-i-1)}$ 個未満である場合は、FSIB12aへと追い出す(ステップS315)。WC21からMSIB11aへの追い出し、WC21からFSIB12aへの追い出しの詳細は、後述する。選択された追い出しエントリの状態フラグ25aは、Valid(使用不可)からNANDメモリ10への追い出し待ちに移行される。

#### 【0105】

この追い出し先の判定は、WCトラック管理テーブル24を用いて実行される。すなわち、WCトラック管理テーブル24には、論理トラックアドレス毎に、有効なクラスタ数を示すWCクラスタ数24bのエントリが登録されており、このWCクラスタ数24bのエントリを参照することでWC21からの追い出し先を、FSIB12a、MSIB11aの何れにするかを決定する。また、way-lineビットマップ24cに、当該論理トラックアドレスに所属する全てのクラスタがビットマップ形式で登録されているので、追い出しを行う際には、このway-lineビットマップ24cを参照することで、容易に、追い出すべき各クラスタのWC21での記憶位置を知ることができる。

#### 【0106】

また、上記書き込み処理中または書き込み処理後、前述の下記条件、  
(ii) WC21に登録されているトラックの数が所定数を超えた場合、  
が成立した場合も、上記同様にしてNANDメモリ10への追い出し処理を実行する。

#### 【0107】

##### WC MSIB(Copy)

つぎに、上記有効クラスタ数(有効クラスタ数が $2^{(k-i-1)}$ 個以上)に基づく判定によりWC21からMSIB11aへの追い出しが発生したときは、前述したように、次のような手順を実行する(ステップS310)。

1. WCクラスタ管理テーブル25を参照し、追い出しを行うクラスタに対応するタグ中のセクタ位置ビットマップ25bを参照し、セクタ位置ビットマップ25bが全て“1”でない場合は、NANDメモリ10に含まれる同一クラスタ中のセクタとマージする、後述のトラック内セクタ穴埋めを行う。また、トラック中のWC21内に存在しないクラスタについてはNANDメモリ10から読み出してマージする、受動マージ処理を実行する。

2. 追い出し確定トラックが $2^i$ 個未満の場合、WC21中のトラックの古いものから $2^i$ 個になるまで $2^{(k-i-1)}$ 個以上有効クラスタを持つ追い出し確定トラックを追加する。

3. Copyされるトラックが $2^i$ 個以上あれば、 $2^i$ 個ずつを組として、MSIB11aに対して論理ブロック単位に書き込みを行う。

4.  $2^i$ 個組みに出来なかったトラックをMSIB11aに対してトラック単位に書き込みを行う。

10

20

30

40

50

5. Copy 終了後に既に FS、IS、MS 上に存在していたクラスタ、トラックのうちコピーされたトラックに属するものを無効化する。

#### 【0108】

このような WC21 から MSIB11a への Copy 处理に伴う各管理テーブルの更新処理について説明する。WC クラスタ管理テーブル 25 中の追い出されたトラックに所属する WC21 中の全クラスタに対応するエントリ中の状態フラグ 25a は Invalid とされ、この後これらエントリに対する書き込みが可能となる。また、WC トラック管理テーブル 24 中の追い出されたトラックに対応するリストについては、例えば直前のリストの next ポインタ 24d が変更または削除されて、無効化される。

#### 【0109】

一方、WC21 から MSIB11a に対するトラック移動が発生すると、これに伴いトラック管理テーブル 30 および MS 論理ブロック管理テーブル 35 が更新される。まず、トラック管理テーブル 30 のインデックスである論理トラックアドレス 30a を検索することで、移動されたトラックに対応する論理トラックアドレス 30a が既に登録されているか否かを判定する。既に登録されている場合は、該当インデックスのクラスタビットマップ 30b (MS11 側への移動であるので、該当ビットを全て “0” にする)、論理ブロック ID 30c + 論理ブロック内トラック位置 30d のフィールドを更新する。移動されたトラックに対応する論理トラックアドレス 30a が未登録の場合は、該当する論理トラックアドレス 30a のエントリに対し、クラスタビットマップ 30b、論理ブロック ID 30c + 論理ブロック内トラック位置 30d を登録する。また、トラック管理テーブル 30 の変更に応じて、MS 論理ブロック管理テーブル 35 における、論理ブロック ID 35a、該当トラック管理ポインタ 35b、有効トラック数 35c、書き込み可能先頭トラック 35d などのエントリを必要に応じて更新する。

#### 【0110】

なお、他の領域 (FS12 や IS13) 等から MS11 に対してトラック書き込みが発生した場合、もしくは MS11 内部のコンパクション処理による MS 内トラック書き込みが発生した場合、書き込み対象のトラックに含まれる WC21 内有効クラスタも同時に MS に書き込まれる。WC21 から MS11 への書き込みとしてこのような受動的マージも存在する。そのような受動的マージが行われた場合は、それらのクラスタは WC21 上から削除 (無効化) されることになる。

#### 【0111】

##### WC FSIB (Copy)

つぎに、上記有効クラスタ数 (有効クラスタ数が  $2^{(k-i-1)}$  個未満) に基づく判定により WC21 から FSIB12a への追い出しが発生したときは、前述したように、次のような手順を実行する。

1. WC クラスタ管理テーブル 25 における追い出しを行うクラスタに対応するタグ中のセクタ位置ビットマップ 25b を参照し、セクタ位置ビットマップ 25b が全て “1” でない場合は、NAND メモリ 10 に含まれる同一クラスタ中のセクタとマージする、クラスタ内セクタ穴埋めを行う。

2. WC 内のトラックを古い順に辿って  $2^{(k-i-1)}$  個未満の有効クラスタしか持たないトラックからクラスタを取り出して行き、有効クラスタ数が  $2^k$  個になったらそれら全クラスタを FSIB12a に論理ブロック単位に書き込む。

3.  $2^k$  個見つからなかった場合には、有効クラスタ数が  $2^{(k-i-1)}$  個未満の全てのトラックを必要な論理ページ数分だけ FSIB12a に書き込む。

4. Copy 終了後に既に FS、IS 上に存在していたクラスタのうちコピーされたのと同じものを無効化する。

#### 【0112】

このような WC21 から FSIB12a への Copy 处理に伴う各管理テーブルの更新処理について説明する。WC クラスタ管理テーブル 25 中の追い出されたトラックに所属する WC21 中の全クラスタに対応するエントリ中の状態フラグ 25a は Invalid とされ

10

20

30

40

50

、この後これらエントリに対する書き込みが可能となる。また、W C トラック管理テーブル 2 4 中の追い出されたトラックに対するリストについては、例えば直前のリストのnext ポインタ 2 4 d が変更または削除されて、無効化される。一方、W C 2 1 から F S I B 1 2 a に対するクラスタ移動が発生すると、これに伴いトラック管理テーブル 3 0 のクラスタテーブルポインタ 3 0 e、F S クラスタ数 3 0 f などを更新するとともに、F S / I S 管理テーブル 4 0 の論理ロック I D 4 0 b、論理ロック内クラスタ位置 4 0 c などを更新する。なお、もともと F S 1 2 に存在していなかったクラスタについては、F S / I S 管理テーブル 4 0 のリンクリストへのリストが追加される。この更新に伴い、M S 論理ロック管理テーブル 3 5 、F S / I S 論理ロック管理テーブル 4 2 、および F S / I S 内クラスタ管理テーブル 4 4 の該当個所を更新する。

10

#### 【 0 1 1 3 】

##### C I B 処理

上記のようなW C F 処理が終了すると、つぎに、論理N A N D層管理部 1 2 0 b は、W C F 処理によって書き込まれたF S I B 1 2 a のデータをF S 1 2 にMove する処理と、W C F 処理によって書き込まれたM S I B 1 1 a のデータをM S 1 1 にMove する処理などを含むC I B 処理を実行する。C I B 処理を開始すると、前述したように、連鎖的に各ブロック間のデータ移動やコンパクション処理が発生する可能性があり、処理全体に要する時間は状態によって大きく変化する。このC I B 処理においては、基本的には、先ずM S 1 1 でのC I B 処理が行われ（ステップS 3 3 0 ）、つぎに、F S 1 2 でのC I B 処理が行われ（ステップS 3 4 0 ）、つぎに再びM S 1 1 でのC I B 処理が行われ（ステップS 3 5 0 ）、つぎにI S 1 3 でのC I B 処理が行われ（ステップS 3 6 0 ）、最後に再びM S 1 1 でのC I B 処理が行われる（ステップS 3 7 0 ）。なお、F S 1 2 からM S I B 1 1 a への追い出し処理、あるいはF S 1 2 からI S 1 3 への追い出し処理、あるいはI S 1 3 からM S I B 1 1 a への追い出し処理の際に、手順にループが発生した場合は、上記順番通りにならない場合もある。M S 1 1 、F S 1 2 およびI S 1 3 でのC I B 処理を別々に説明する。

20

#### 【 0 1 1 4 】

##### M S 1 1 のC I B 処理

まず、M S 1 1 でのC I B 処理について説明する（ステップS 3 3 0 ）。W C 2 1 、F S 1 2 、I S 1 3 からM S 1 1 に対してトラックデータの移動が発生すると、そのトラックデータはM S I B 1 1 a に書き込まれる。M S I B 1 1 a への書き込み完了後は、前述したように、トラック管理テーブル 3 0 を更新してトラックが配置される論理ロック I D 3 0 c とブロック内トラック位置 3 0 d などを変更する（Move）。M S I B 1 1 a に新たなトラックデータが書き込まれた場合、もともとM S 1 1 もしくはT F S 1 1 b に存在していたトラックデータは無効化される。この無効化処理は、M S 論理ロック管理テーブル 3 5 における古いトラック情報が保存されていた論理ロックのエントリからトラックを無効化することで実現する。具体的には、M S 論理ロック管理テーブル 3 5 の該当エントリ中のトラック管理ポインタ 3 5 b のフィールド中の該当トラックのポインタが削除され、有効トラック数が - 1 される。このトラック無効化によって 1 論理ロック中の全てのトラックが無効になった場合は、Validフラグ 3 5 e が無効化される。このような無効化などにより、M S 1 1 のブロックは無効なトラックを含んだものが発生し、これが繰り返されるとブロックの利用効率が低下して、使用可能な論理ロックに不足が生じることがある。

30

#### 【 0 1 1 5 】

データ管理部 1 2 0 は、このような事態が発生して、M S 1 1 に割り当てられている論理ロックの個数がM S 1 1 として許容されるブロック数の上限値を越えるような状況が発生すると、コンパクション処理を行って、無効なフリーブロック F B を作る。無効なフリーブロック F B は、物理N A N D層管理部 1 2 0 c に返却される。そして、論理N A N D層管理部 1 2 0 b は、M S 1 1 に割り当てられている論理ロックの個数を減らした後、新たに書き込み可能なフリーブロック F B を物理N A N D層管理部 1 2 0 c から取得す

40

50

る。コンパクション処理とは、コンパクション対象の論理ブロックが持つ有効クラスタを新しい論理ブロックに集めたり、あるいはコンパクション対象の論理ブロック中の有効トラックを他の論理ブロックにCopyしたりすることで、物理NAND層管理部120cに返却する無効なフリーブロックFBを作り、論理ブロックの利用効率を向上させるための処理である。なお、コンパクションを行う際には、コンパクション対象となったトラック領域に対して、WC、FS、IS上の有効なクラスタが存在する場合、それらを全てマージする受動マージを実行する。また、TFS11bに登録されている論理ブロックについては、コンパクション対象に含めない。

#### 【0116】

以下に、MSIB11aにフルに成了したブロックが存在する場合を発生条件とした、MSIB11aからMS11またはTFS11bへの追い出しとコンパクション処理の一例について具体的に説明する。 10

1. MS論理ブロック管理テーブル35のValidフラグ35eを参照することにより、MS11内に無効となった論理ブロックが存在する場合、そのブロックを無効なフリーブロックFBとする。

2. MSIB11aでフルに成了した論理ブロックをMS11に追い出す。具体的には、前述したMS構造管理テーブル(図示せず)を更新して、該当論理ブロックをMSIB管理下からMS管理下に移し変える。

3. MS11に割り当てられている論理ブロックの個数がMS11として許容されるブロック数の上限値を越えるような状況が発生するか否かを判断し、発生している場合に、以下のMSコンパクションを実行する。 20

4. MS論理ブロック管理テーブル35の有効トラック数35cのフィールドなどを参照することにより、TFS11bに含まれない論理ブロックのうち無効にされたトラックを持つものを、有効トラック数でソートする。

5. 有効トラック数の少ない論理ブロックから、トラックを集めてコンパクションを実施する。この際にまず、1論理ブロック分(2<sup>i</sup>トラック)ずつCopyしてコンパクションを実施する。なお、コンパクション対象のトラックがWC21、FS12、IS13に有効クラスタを持つ場合にはそれらもマージする。

6. コンパクション元の論理ブロックを無効なフリーブロックFBとする。

7. コンパクションして有効な2<sup>i</sup>トラックで構成された1論理ブロックができたら、TFS11bの先頭にMoveする。 30

8. 論理ブロック内の有効トラックを他の論理ブロックにCopyして、無効なフリーブロックFBが作れる場合は、2<sup>i</sup>トラック未満の個数の有効トラックをMSIB11aに対し、トラック単位で追記書き込みする。

9. コンパクション元の論理ブロックを無効なフリーブロックFBとする。

10. MS11に割り当てられている論理ブロックの個数がMS11として許容されるブロック数の上限値を下回ると、MSコンパクション処理を終了する。

#### 【0117】

##### FS12のCIB処理

つぎに、FS12でのCIB処理について説明する(ステップS340)。WC21からFSIB12aへのクラスタ書き込み処理によって全ページ書き込み済みの論理ブロックがFSIB12a中に作られた場合、FSIB12a中のそれらのブロックは、FSIB12aからFS12に対してMoveされる。このMoveにともなって複数の論理ブロックで構成されるFIFO構造のFS12から古い論理ブロックが追い出される状況が発生する。 40

#### 【0118】

FSIB12aからFS12に対する追い出しおよびFS12からのブロック追い出しありは、具体的には、次のように実現される。

1. FS/IS論理ブロック管理テーブル42のValidフラグ35eなどを参照することにより、FS12内に無効となった論理ブロックが存在する場合、そのブロックを無効 50

なフリー ブロック F B とする。

2. F S I B 1 2 a でフルに成ったブロックを F S 1 2 に追い出す。具体的には、前述した F S / I S 構造管理テーブル（図示せず）を更新して、該当ブロックを F S I B 管理下から F S 管理下に移し変える。

3. F S 1 2 に割り当てられている論理ブロックの個数が F S 1 2 として許容されるブロック数の上限値を越えるような状況が発生するか否かを判断し、発生している場合に、以下の追い出しを実行する。

4. まず追い出し対象の最古の論理ブロック中のクラスタデータのうち I S 1 3 に移動せずに、直接 M S 1 1 に移動すべきものを決定する（実際には、M S の管理単位がトラックであるので、トラック単位での決定）。

（ア）追い出し対象の論理ブロック中の有効クラスタをページの先頭から順にスキヤンする。

（イ）クラスタが属するトラックが F S 中に何個の有効クラスタを保有しているか、トラック管理テーブル 3 0 の F S クラスタ数 3 0 f のフィールドを参照して検索する。

（ウ）トラック内有効クラスタ数が所定の閾値（例えば  $2^{k-i}$  個の 50%）以上だった場合、そのトラックを M S への追い出し候補とする。

5. M S 1 1 に追い出すべきトラックを M S I B 1 1 a に対して書き込む。

6. 追い出しトラックが残っている場合、さらに M S I B 1 1 への追い出しを実行する。

7. 上記 2 ~ 4 の処理の後も追い出し対象の論理ブロックに有効なクラスタが存在している場合、この論理ブロックを I S 1 3 に M o v e する。

なお、F S 1 2 から M S I B 1 1 a への追い出しが発生したときには、その直後、M S 1 1 での前述した C I B 処理が実行される（ステップ S 3 5 0）。

#### 【0119】

##### I S 1 3 の C I B 処理

つぎに、I S 1 3 での C I B 処理について説明する（ステップ S 3 6 0）。上記した F S 1 2 から I S 1 3 へのブロック移動によって論理ブロックが I S 1 3 に追加されるが、これにともなって複数個の論理ブロックで構成される I S 1 3 に対して管理可能なブロック数の上限を超ってしまう状況が発生する。このような状況が発生した場合、I S 1 3 では、まず M S 1 1 への 1 ~ 複数個の論理ブロックの追い出しを行った後、I S コンパクションを実行する。具体的には、次のような手順を実行する。

1. I S 1 3 に含まれるトラックをトラック内の有効クラスタ数 × 有効クラスタ係数でソートし、積の値が大きいトラック  $2^{i+1}$  個（2 論理ブロック分）を集めて M S I B 1 1 a に追い出す。

2. 有効クラスタ数が最も少ない  $2^{i+1}$  個の論理ブロックの合計有効クラスタ数が例えば、所定の設定値である  $2^k$  個（1 論理ブロック分）以上ある場合は、上のステップを繰り返す。

3. 上記の追い出しが行った後、有効クラスタ数の少ない論理ブロックから順にクラスタを  $2^k$  個集め、I S 1 3 内でコンパクションを行う。

4. コンパクション元の論理ブロックのうち有効クラスタがなくなったものを無効なフリー ブロック F B として返還する。

なお、I S 1 3 から M S I B 1 1 a への追い出しが発生したときには、その直後、M S 1 1 での前述した C I B 処理が実行される（ステップ S 3 7 0）。

#### 【0120】

図 2 0 は、各構成要素間のデータの流れにおける入力と出力の組み合わせ、およびそのデータの流れが何をトリガとして発生するかを示すものである。F S 1 2 は、基本的には、W C 2 1 からのクラスタ追い出しによってデータが書き込まれるが、W C 2 1 から F S 1 2 への追い出しに付随してクラスタ内セクタ穴埋め（クラスタ穴埋め）が必要な場合は、F S 1 2 、 I S 1 3 、 M S 1 1 からのデータがコピーされる。W C 2 1 では、W C クラスタ管理テーブル 2 5 のタグ中のセクタ位置ビットマップ 2 5 b によって当該クラスタア

10

20

30

40

50

ドレス中の $2^{(1-k)}$ 個のセクタの有無を識別させることによってセクタ(512B)単位の管理をすることが可能である。これに対し、NANDメモリ10での機能要素であるFS12、IS13の管理単位はクラスタであり、MS11の管理単位は、トラックである。このように、NANDメモリ10での管理単位は、セクタより大きいため、WC21からNANDメモリ10に対して、データを書き込む際に、書き込まれるデータと同一クラスタアドレスのデータがNANDメモリ10中に存在する場合、WC21からNANDメモリ10に書き込まれるクラスタ中のセクタと、NANDメモリ10中に存在する同一クラスタアドレス内のセクタとをマージしてから、NANDメモリ10に書き込む必要がある。

## 【0121】

10

この処理が、図20に示したクラスタ内セクタ穴埋め処理(クラスタ穴埋め)と、トラック内セクタ穴埋め(トラック穴埋め)であり、これらの処理を行わないと、正しいデータが読み出せなくなる。そこで、WC21からFSIB12aまたはMSIB11aにデータを追い出す際には、WCクラスタ管理テーブル25を参照し、追い出しを行うクラスタに対応するタグ中のセクタ位置ビットマップ25bを参照し、セクタ位置ビットマップ25bが全て“1”でない場合は、NANDメモリ10に含まれる同一クラスタまたは同一トラック中のセクタとマージする、クラスタ内セクタ穴埋めまたはトラック内セクタ穴埋めを行う。この処理には、DRAM20の作業領域が使用され、DRAM20の作業領域からMSIB11aに書き込まれたり、FSIB12aに書き込まれたりする。

## 【0122】

20

IS13は、基本的には、FS12からのブロック追い出しによってデータが書き込まれる(Move)か、IS内部のコンパクションによってデータが書き込まれる。MS11は、全ての箇所からデータが書き込まれ得る。その際、MS11は、トラック単位にしかデータを書き込めないために、MS自身のデータによる穴埋めが発生しうる。また、トラック単位の書き込みを行う際には、他のブロックにある断片化されたデータも受動マージによって書き込まれることになる。さらにMS11は、MSコンパクションによる書き込みもある。なお、受動マージにおいては、WC21、FS12またはIS13の3つの構成要素のうちの1つの構成要素からMS11へのトラック追い出しありは論理ブロック追い出し(2<sup>i</sup>トラック分の追い出し)が発生した際、1つの構成要素での追い出し対象のトラック(または論理ブロック)に含まれる他の2つの構成要素内の有効クラスタおよびMS11内の有効クラスタが、DRAM20の作業領域に集められて、DRAM20の作業領域から1トラック分のデータとしてMSIB11aに書き込まれる。

30

## 【0123】

つぎに、本実施形態をより詳細に説明する。図21は、図6に示したNANDメモリ10の書き込み処理に係わるより詳細な機能構成を示すものである。重複する説明は、省略する。

## 【0124】

## ・FS構成

FS部12Qは、FSIB12aとFS12によって構成されている。FS12は、多数の論理ブロック分の容量を有し、論理ブロック単位でFIFO構造が管理されている。FS12の前段には、WC21から追い出されたデータが入力されるFSインプットバッファ(FSIB)12aが設けられている。FSIB12aは、FSフルブロックバッファ(FSFB)12aaと、FS追記バッファ(FS追記IB)12abとを備えている。FSFB12aaは、1～複数個の論理ブロック分の容量を有し、またFS追記IB12abも1～複数個の論理ブロック分の容量を有する。WC21からの追い出しデータが1論理ブロック分あればFSFB12aaに対する論理ブロック単位のデータコピーが行われ、そうでなければFS追記IB12abに対して論理ページ単位の追記書き込みが行われる。

40

## 【0125】

## ・IS構成

50

I S 部 1 3 Q は、 I S 1 3 と、 I S インプットバッファ ( I S I B ) 1 3 a と、 I S コンパクションバッファ 1 3 c によって構成されている。 I S I B 1 3 a は、 1 ~ 複数個の論理ブロック分の容量を有し、 I S コンパクションバッファ 1 3 c は例えば 1 論理ブロック分の容量を有し、 I S 1 3 は、 多数の論理ブロック分の容量を有する。 I S 1 3 は、 例えば、 論理ブロック単位で、 F S 1 2 と同様、 F I F O 構造が管理されている。 I S コンパクションバッファ 1 3 c は、 I S 部 1 3 Q でのコンパクションを行うためのバッファである。

#### 【 0 1 2 6 】

前述したように、 I S 部 1 3 Q は、 F S 部 1 2 Q と同様クラスタ単位でデータの管理を行う。 F S 部 1 2 Q から I S 部 1 3 Q に対して論理ブロックの移動、 すなわち F S 1 2 からの追い出しが発生すると、 以前 F S 部 1 2 Q の管理対象であった追い出し対象の論理ブロックはポインタの付け替えにより I S 部 1 3 ( 詳細には、 I S I B 1 3 a ) の管理対象ブロックとなる。 この F S 部 1 2 Q から I S 部 1 3 Q への論理ブロックの移動により、 I S 1 3 のブロック数が所定の上限値を超えると、 I S 1 3 から M S 部 1 1 Q へのデータ追い出しおよび I S コンパクション処理が実行され、 I S 部 1 3 Q のブロック数は規定値に戻される。

#### 【 0 1 2 7 】

##### ・ M S 構成

M S 部 1 1 Q は、 M S I B 1 1 a と、 トランク前段バッファ ( T F S ) 1 1 b と、 M S 1 1 によって構成されている。 M S I B 1 1 a は、 1 ~ 複数個 ( この実施の形態では 4 個 ) の M S フルブロックインプットバッファ ( 以下 M S F B ) 1 1 a a と、 1 ~ 複数個 ( この実施の形態では 2 個 ) の追記インプットバッファ ( 以下 M S 追記 I B ) 1 1 a b とを備えている。 1 つの M S F B 1 1 a a は、 1 論理ブロック分の容量を有する。 M S F B 1 1 a a は、 論理ブロック単位の書き込み時に用いられる。 1 つの M S 追記 I B 1 1 a b は、 論理ブロック分の容量を有する。 M S 追記 I B 1 1 a b は、 トランク単位の追記書き込み時に用いられる。

#### 【 0 1 2 8 】

M S F B 1 1 a a には、 W C 2 1 から追い出された論理ブロック、 または F S 1 2 から追い出された論理ブロック、 または I S 1 3 から追い出された論理ブロックが C o p y される。 1 つの M S F B 1 1 a a に C o p y された論理ブロックは、 T F S 1 1 b を経ることなく M S 1 1 に直接 M o v e される。 この M S 1 1 への M o v e 後は、 フリーブロック F B が M S F B 1 1 a a として割り当てられる。

#### 【 0 1 2 9 】

M S 追記 I B 1 1 a b には、 W C 2 1 から追い出されたトランク、 または F S 1 2 から追い出されたトランクが追記的に C o p y される。 このようなトランク単位で追記書き込みされる M S 追記 I B 1 1 a b のうちでフルになった論理ブロックは、 T F S 1 1 b に M o v e される。 この T F S 1 1 b への M o v e 後は、 フリーブロック F B が M S 追記 I B 1 1 a b として割り当てられる。

#### 【 0 1 3 0 】

T F S 1 1 b は、 前述したように、 多数の論理ブロック分の容量を有し、 M S 追記 I B 1 1 a b と M S 1 1 との間に介在する F I F O 構造を有するバッファである。 F I F O 構造を持つ T F S 1 1 b の入力側には、 トランク単位で追記書き込みされる M S 追記 I B 1 1 a b のうちでフルになった論理ブロックが M o v e され、 また M S 1 1 内のコンパクション処理によって形成された論理ブロックが、 M S コンパクションバッファ 1 1 c から M o v e される。 M S コンパクションバッファ 1 1 c は、 M S 1 1 でのコンパクションを行うためのバッファである。 なお、 M S 1 1 内部のコンパクション処理によって、 M S 内トランクが M S コンパクションバッファ 1 1 c に書き込まれる際には、 書き込み対象のトランクに含まれる W C 2 1 、 F S 部 1 2 Q 、 I S 部 1 3 Q 内の有効クラスタが D R A M 2 0 の作業領域を介して M S コンパクションバッファ 1 1 c に書き込まれる、 受動マージが行われる。 本実施の形態においては、 M S I B 1 1 a および T F S 1 1 b に登録されている

10

20

30

40

50

論理ブロックについては、コンパクション対象に含めない。

#### 【0131】

図22は、データ管理部120のより詳細な機能構成を示すものである。データ管理部120は、前述したように、DRAM20に記憶したデータの管理を行うDRAM層管理部120aと、NANDメモリ10に記憶したデータの管理を行う論理NAND層管理部120bと、NANDメモリ10を物理記憶デバイスとして管理する物理NAND層管理部120cとから構成される。

#### 【0132】

DRAM層管理部120aは、RCクラスタ管理テーブル23、WCクラスタ管理テーブル25、WCトラック管理テーブル24を備え、これら管理テーブルに基づいてDRAM層の管理を行う。論理NAND層管理部120bは、トラック管理テーブル30、MSブロック管理テーブル35、FS/IS管理テーブル40、FS/IS論理ブロック管理テーブル42、FS/IS内クラスタ管理テーブル44の他に、MS構造管理テーブル60、FS/IS構造管理テーブル65を備え、これらの管理テーブルに基づいてNANDメモリ10の論理NAND層の管理を行う。物理NAND層管理部120cは、論物変換テーブル50の他に、バッドブロック管理テーブル(BB管理テーブル)200、予約ブロック管理テーブル(RBブロック管理テーブル)210、フリーブロック管理テーブル(FB管理テーブル)220、アクティブブロック管理テーブル(AB管理テーブル)230を備え、これらの管理テーブルを用いてNANDメモリ10の物理NAND層の管理を行う。

10

20

#### 【0133】

##### ・物理NAND層

まず、物理NAND層について説明する。前述したように、32ビット倍速モードでは、4ch(ch0、ch1、ch2、ch3)を並列で動作させ、更に、NANDメモリチップの備える倍速モードを利用して消去/書き込み/読み出しを行う。図23に示すように、4つの並列動作要素10a～10d内の各NANDメモリチップは、例えば、プレーン0、プレーン1の2つの領域(District)に分割されている。なお、分割数は2に限定されるものではない。プレーン0およびプレーン1は、互いに独立した周辺回路(例えば、ロウデコーダ、カラムデコーダ、ページバッファ、データキャッシュ等)を備えており、NANDコントローラ112から入力されるコマンドに基づき、同時に消去/書き込み/読み出しを行うことが可能である。NANDメモリチップの倍速モードでは、上記プレーン0およびプレーン1を並列制御することにより、高速書き込みを実現している。

30

#### 【0134】

物理ブロックサイズは512kBであるので、32ビット倍速モードでは、4chの並列動作および2つのプレーンに対する同時アクセスにより、その消去単位は $512kB \times 4 \times 2 = 4MB$ となる。すなわち、この32ビット倍速モードでは、結果的に、8プレーンが並列動作することになる。

#### 【0135】

図24は、論物変換テーブル50の他の例を示すものである。図24に示す論物変換テーブル50は、図17に示した論物変換テーブル50に対し、論理ブロックID50aに対応する論理ブロックが消去された時刻を示す消去時刻50eのフィールドが更に追加されている。消去時刻50eとしては、例えば、NANDメモリチップ内の論理ブロックに対して消去動作が行われた回数を計測することで得られる値、或いは、NANDコントローラ112の通電時間等を利用すればよい。消去時刻50eは、後述するFB管理テーブル220でのフリーブロックFB管理に利用される。

40

#### 【0136】

BB管理テーブル200は、物理ブロック(512kB)単位でバッドブロックBBを管理するためのテーブルである。BB管理テーブル200は、図25に示すように、例えば、4(チャネル)×2(プレーン/チャネル)個のチャネル内プレーン毎に、(物理ブロック数/プレーン)×(NANDメモリチップ数/1並列動作要素)個数分の物理ブロック

50

に関する情報をもつ二次元配列形式で構成されており、各エントリには、各物理ブロックに対する物理ブロックID 200aが保持されている。

【0137】

本実施形態の場合、1 NANDメモリチップは2 GBサイズであり、第1番目のチップのプレーン0には、「0」～「2047」の物理ブロックIDが割り当てられ、第1番目のチップのプレーン1には、「2048」～「4095」の物理ブロックIDが割り当てられる。物理NAND層管理部120cは、使用中に発生したバッドブロックBBをBB管理テーブル200に登録する際には、ソートはせずに対応するチャネル内プレーンID(ID#0～ID#7)の最後尾の有効エントリの直後に順に追加する。

【0138】

RB管理テーブル210は、8個の物理ブロック単位(512 kB)で4 MB論理ブロックを形成する際に余ったブロック(予約ブロックRB)を管理するためのテーブルであり、BB管理テーブル200と同様のフォーマットで管理される。対応するチャネル内プレーンIDごとにFIFO管理ということで、最も古く登録された予約ブロックから優先して利用する。

【0139】

FB管理テーブル220は、4 MB論理ブロック単位で現在用途未割り当てのフリーブロックFBを管理するためのテーブルであり、フリーブロックFBとなった順にソートされたFIFO形式のリストである。各エントリは、論理ブロックIDを保持する。コンパクション処理などにより、FB管理テーブル220に返却されたフリーブロックFBは、リストの最後尾に追加され、フリーブロックFB割り当ては、リストの先頭ブロックを返すことを行う。

【0140】

FB管理テーブルは、図26に示すように、返却FIFOリスト220aと、割り当てリスト220bとの2段構成になっている。返却FIFOリスト220aは、消去時刻50e順に整列しており、割り当てリスト220bは、消去回数50cの少ない論理ブロックほどリストの先頭に位置する。これは、短い時間間隔で消去動作を繰り返すことを防ぐための構成である。不要になり、FB管理テーブル220に返却された論理ブロックは、返却FIFOリスト220aの最後尾に追加され、一定の期間にここに保持される。

【0141】

返却FIFOリスト220aから押し出された論理ブロックは、その消去回数50cに応じて割り当てリスト220bの途中に挿入される。論理NAND層管理部120bからフリーブロックFBの割り当てを要求されると、論理NAND層管理部120cは、割り当てリスト220bの先頭から取り出し、割り当てを行う。

【0142】

上記FB管理テーブルにより、全ての論理ブロックの消去回数、消去間隔が概ね等しくなるように、消去する論理ブロックを均等に分散させる(ウェアアレベリング処理)ことが可能となる。NAND型フラッシュメモリの寿命は、消去回数の他に、消去処理の間隔にも依存しており、その間隔が長いほどリテンション特性が良く、寿命が伸びることが知られている。これは、消去間隔が短いとリテンション特性が悪く、寿命が損なわれることも示している。また、短い間隔で書き込みを行ったとしても、相応の長期間消去を行わなければリテンション特性が回復することも知られている。

【0143】

AB管理テーブル230は、フリーブロックFBから割り当てられた、用途が割り当てられた論理ブロック(アクティブブロックAB)のリストであり、FB管理テーブル220と同様に、各エントリは、論理ブロックIDを保持する。登録順序が古い論理ブロックほど先頭に位置することになる。AB管理テーブルは、例えば、リフレッシュ処理に使用される。

【0144】

リフレッシュ処理とは、書き込んだデータの経年変化や読み出し処理に伴うデータ破損

10

20

20

30

40

50

であるリードディスターブの影響で、SSD100の誤り訂正能力を超える誤りが発生することを防止するための技術である。具体的には、例えば、誤り訂正能力を超える誤りが発生する前に、記憶してあるデータを読み出して誤り訂正を行い、その後再びNAND型フラッシュメモリにデータを書き直すという処理を行う。例えば、読み出し回数50dの多いブロック、AB管理テーブル230の先頭ブロックなどをリフレッシュ処理の監視対象とすることができます。

#### 【0145】

物理NAND層管理部120cは、以下のような論理ブロック - 物理ブロック管理を行う。先ず、図27を用いて論物変換テーブル50を用いた、論理ブロックIDと8個の物理ブロックIDとの対応関係について説明する。

10

#### 【0146】

前述したように、論物変換テーブル50の物理ブロックID50bのフィールドには、論物変換テーブル50のインデックスである論理ブロックID50aに対応付けられた8個の物理ブロックIDが登録されている。図27は、NANDメモリ10の論理ブロックIDと物理ブロックIDとの対応関係を示すものであり、1つの区画が1物理ブロックを表している。各物理ブロックに物理ブロックIDが割り当てられている。論理ブロックL0は、例えば、1行3列、2行2列、3行2列、4行2列、5行2列、6行2列、7行2列、8行3列の8個の物理ブロックで構成されている。また、破線BL1で囲まれた論理ブロックL1は、例えば、1行4列、2行3列、3行3列、4行3列、5行3列、6行3列、7行3列、8行4列の8個の物理ブロックで構成されているとする。

20

#### 【0147】

この後、例えば、論理ブロックL1の4行3列の物理ブロックが、記憶領域として使用できないバッドブロックBBとして、BB管理テーブル200に登録されたとする。これを検知した物理NAND層管理部120cは、RB管理テーブル210から、このバッドブロックBBとして登録された物理ブロックと同一チャネルで同一プレーンの予約ブロックRBを当該バッドブロックBBに対する入れ替え候補として選択する。図27の場合は、隣接する4行4列の物理ブロック(予約ブロックRB)が4行3列のBBに対する入れ替え候補として選択されている。

#### 【0148】

物理NAND層管理部120cは、論物変換テーブル50の論理ブロックL1に対応する論理ブロックID50aのエントリを検索し、このエントリ中の物理ブロックID50bのフィールドに含まれる8個の物理ブロックIDのうちの4行3列に対応するバッドブロックBBの物理ブロックIDを、RB管理テーブル210から選択した4行4列のRBに対応する物理アドレスIDに変更する。これにより、この後、論理ブロックL1は、一点鎖線で囲まれた1行4列、2行3列、3行3列、4行4列、5行3列、6行3列、7行3列、8行4列の8個の新たな物理ブロックの組み合わせで構成されることになる。この論理ブロックL1の論理ブロックIDが「L1」であるとする。

30

#### 【0149】

その後、物理NAND層管理部120cは、FB管理テーブル220から新たなフリー ブロックFBを確保する。この確保したフリー ブロックFBの論理ブロックIDが「L3」であるとする。物理NAND層管理部120cは、論物変換テーブル50を用いて論理ブロックIDの入れ替えを実行する。具体的には、論理ブロックID「L1」に対し、論理ブロックIDが「L3」である新たなフリー ブロックFBに対応付けられた8個の物理ブロックを対応付け、さらに論理ブロックID「L3」に対し、前述の物理ブロックの組み合わせが変更された一点鎖線で囲まれた1行4列、2行3列、3行3列、4行4列、5行3列、6行3列、7行3列、8行4列の8個の物理ブロックを対応付ける。消去回数50c、読み出し回数50d、消去時刻50eも論理ブロックID入れ替えに伴い入れ替える。その後、論理ブロックID「L3」を、FB管理テーブル220に登録する。

40

#### 【0150】

一方、バッドブロックBBに対して入れ替え可能な予約ブロックRBが存在しない場合

50

には以下のような処理を行う。例えば、論理ブロック L 1 の 4 行 3 列の物理ブロックがバッドブロック B B として B B 管理テーブル 2 0 0 に登録されたとし、さらに、このバッドブロック B B に対しては同一チャネルかつ同一プレーン内に予約ブロック R B が存在しない場合には、まず、論理ブロック L 1 内の 4 行 3 列を除く、1 行 4 列、2 行 3 列、3 行 3 列、5 行 3 列、6 行 3 列、7 行 3 列、8 行 4 列の 7 個の物理ブロックを R B 管理テーブル 2 1 0 に登録する。その後は、前記同様、F B 管理テーブル 2 2 0 から新たなフリーブロック F B を確保し、前記同様の論理ブロック I D の入れ替えを実行した後、F B 管理テーブル 2 2 0 から取得した論理ブロック I D を使用不可とする。

#### 【0151】

このように、物理 N A N D 層管理部 1 2 0 c は、バッドブロック B B が発生した場合でも、論理ブロック I D の入れ替えを実行しているので、論理 N A N D 層管理部 1 2 0 b で使用する論理ブロック I D は、バッドブロック B B の発生の前後で変化しない。したがって、複数の物理ブロックの少なくとも 1 つをバッドブロックとして登録する場合であっても、L B A 論理アドレスと論理ブロックとの対応関係は変更されず、論理 N A N D 層管理部 1 2 0 b での管理テーブルの書き換えのオーバーヘッドを回避することができる。

#### 【0152】

つぎに、32 ビット倍速モードでの消去処理について説明する。物理 N A N D 層管理部 1 2 0 c は、N A N D メモリ 1 0 のデータが論理ブロック単位で消去されるごとに、図 2 4 に示す論物変換テーブル 5 0 の消去された論理ブロックに対応する論理ブロック I D 中の消去回数 5 0 c のフィールドを 1 カウントアップするとともに、消去時刻 5 0 e を最新のデータに更新する。

#### 【0153】

##### ・論理 N A N D 層

つぎに、図 2 8、図 2 9 を用いて論理 N A N D 層での管理に使用される M S 構造管理テーブル 6 0 および F S / I S 構造管理テーブル 6 5 について説明する。図 2 8 に示す M S 構造管理テーブル 6 0 は、M S 部 1 1 Q の構造を管理するための領域と、状態情報を保存するための領域とを有する。M S 構造管理テーブル 6 0 は、M S F B 1 1 a a、M S 追記 I B 1 1 a b、T F S 1 1 b として割り当てられた論理ブロック I D を管理する M S バッファ管理テーブル 6 1 と、M S コンパクション時のソート処理を高速化するために、有効トラック数が少なくなった論理ブロック I D を保持する有効トラック数別論理ブロック I D リスト 6 2 と、状態情報としての最大論理ブロック数 M B L および有効論理ブロック数 V B L を管理する領域 6 3、6 4 とを備える。

#### 【0154】

M S 構造管理テーブル 6 0 では、M S F B 1 1 a a 用、M S 追記 I B 1 1 a b 用、T F S 1 1 b 用に、それぞれ所要エントリ数の固定フィールド 6 1 a ~ 6 1 c が用意され、各固定フィールド 6 1 a ~ 6 1 c に論理ブロック I D が記録される。T F S 1 1 b 用のフィールド 6 1 c は、リンクドリスト構造を有し、F I F O 構造を有する T F S 1 1 b に対する F I F O 的な管理が行われている。

#### 【0155】

有効トラック数別論理ブロック I D リスト 6 2 では、有効トラック数が 1 個の論理ブロック用として所要数のエントリが用意され、有効トラック数が 2 個の論理ブロック用として所要数のエントリが用意され、…、有効トラック数が  $2^i - 1$  の論理ブロック用として所要数のエントリが用意されており、各エントリには、論理ブロック I D が記録される。M S 論理ブロック管理テーブル 3 5 の有効トラック数 3 5 c のフィールドがサーチされることによって有効トラック数別論理ブロック I D リスト 6 2 は、常に最新の状態に更新される。なお、有効トラック数別論理ブロック I D リスト 6 2 には、M S I B 1 1 a、T F S 1 1 b として M S バッファ管理テーブル 6 1 に登録されている論理ブロックについては、エントリされない。

#### 【0156】

状態情報としての最大論理ブロック数 M B L 用の固定フィールド 6 3 には、M S 部 1 1

10

20

30

40

50

Qが取得するのを許容されている論理ブロック数である最大論理ブロック数M B Lが記録される。状態情報としての有効論理ブロック数V B L用の固定フィールド6 4には、MS部1 1 Qとして現在管理されている論理ブロック数としての有効論理ブロック数V B Lが記録される。

【0 1 5 7】

図2 9に示すFS / IS構造管理テーブル6 5は、FS部1 2 QおよびIS部1 3 Qの構造を管理するための領域を有する。FS / IS構造管理テーブル6 5は、FSIB1 2 aおよびFS追記IB1 2 a bとして割り当てられた論理ブロックIDを管理するFS入力バッファ管理テーブル6 6と、FS1 2のFIFO構造を管理するFSFIFO管理テーブル6 7と、ISIB1 3 aとして割り当てられた論理ブロックIDを管理するIS入力バッファ管理テーブル6 8と、IS1 3のFIFO構造を管理するISFIFO管理テーブル6 9とを備える。

【0 1 5 8】

FS入力バッファ管理テーブル6 6は、FSFB1 2 a a用、FS追記IB1 2 a b用に、それぞれ所要エントリ数の固定フィールド6 6 a、6 6 bが用意され、各固定フィールド6 6 a、6 6 bにFS / IS論理ブロック管理テーブル4 2のインデックスであるFS / ISブロックID4 2 aが登録される。IS入力バッファ管理テーブル6 8は、ISIB1 3 a用に所要エントリ数の固定フィールドが用意され、各固定フィールドに、FS / ISブロックID4 2 aが登録される。FSFIFO管理テーブル6 7には、FS1 2のFIFO構造を形成する論理ブロック数分のエントリが固定フィールドに用意され、FSFIFO管理テーブル6 7の各固定フィールドには、FS / ISブロックID4 2 aが登録される。ISFIFO管理テーブル6 9には、IS1 3のFIFO構造を形成する論理ブロック数分のエントリが固定フィールドに用意され、各固定フィールドには、FS / ISブロックID4 2 aが登録される。

【0 1 5 9】

つぎに、先の図1 9を用いて説明した、2ステージ(WCF処理およびCIB処理)に分割された書き込み処理が実行されるときの、WC2 1からMSIB1 1 aへのCopy処理に伴う各管理テーブルの更新処理を説明する。なお、ここでは、WC2 1からMS追記IB1 1 a bへのトラック単位のCopyが発生した場合について説明する。DRAM層管理部1 2 0 aでは、WCトラック管理テーブル2 4を先頭から順にチェックし、追い出し確定トラックに対応する論理トラックアドレス2 4 aが登録されたトラックエントリ中のway - lineビットマップ2 4 cを参照し、way - lineビットマップ2 4 cのm × nのエントリ中のValidビットが“1”のエントリに対応するWCクラスタ管理テーブル2 5中のエントリにおける状態フラグ2 5 aをValidからNANDへの追い出し待ちにし、論理NAND層管理部1 2 0 bに対し追い出し要求を通知する。

【0 1 6 0】

一方、論理NAND層管理部1 2 0 bでは、図2 8に示すMS構造管理テーブル6 0のMSバッファ管理テーブル6 1および図1 4に示すMS論理ブロック管理テーブル3 5を参照し、MS追記IB1 1 a bの状態をチェックする。すなわち、MSバッファ管理テーブル6 1のMS追記IB用のフィールド6 1 bからMS追記IB1 1 a bが既に存在していると判断されたときは、MS追記IB用のフィールド6 1 bに登録されている論理ブロックIDについての書き込み可能トラック数に関する情報をMS論理ブロック管理テーブル3 5の有効トラック数3 5 cのフィールドから取得し、該取得した書き込み可能トラック数をDRAM層管理部1 2 0 aに通知する。

【0 1 6 1】

また、論理NAND層管理部1 2 0 bは、MSバッファ管理テーブル6 1のMS追記IB用のフィールド6 1 bからMS追記IB1 1 a bが存在していないと判断されたときは、物理NAND層管理部1 2 0 cに対し、フリーブロックFBの獲得要求を出して、フリーブロックFBを該FBとして割り当てられた論理ブロックIDと共に取得する。そして、取得したフリーブロックFBの書き込み可能トラック数2<sup>i</sup>をDRAM層管理部1 2 0

10

20

30

40

50

a に通知する。

【 0 1 6 2 】

D R A M 層管理部 1 2 0 a では、論理 N A N D 層管理部 1 2 0 b から通知された書き込み可能トラック数だけ、W C トラック管理テーブル 2 4 からトラックを選択し、さらに前述のトラック内セクタ穴埋めと受動マージを行うか否かを判断する。ここでは、トラック内セクタ穴埋めを行う必要はないとする。D R A M 層管理部 1 2 0 a は、追い出すトラックがN A N D メモリ 1 0 に存在しているか否かをチェックして受動マージを行うか否かを調べるために、論理 N A N D 層管理部 1 2 0 b に対し追い出しを行う論理トラックアドレスなどの所要の情報を通知する。

【 0 1 6 3 】

10

この通知を受けると、論理 N A N D 層管理部 1 2 0 b は、トラック管理テーブル 3 0 のインデックスである論理トラックアドレス 3 0 a、必要な場合はさらに F S / I S 管理テーブル 4 0 を検索し、N A N D メモリ 1 0 側に追い出しを行う論理トラックアドレスと同一の論理トラックが存在しているかをサーチし、このサーチ結果を物理 N A N D 層管理部 1 2 0 c に通知する。これによって、物理 N A N D 層管理部 1 2 0 c によって、受動マージを伴うあるいは受動マージを伴わない W C 2 1 から M S 追記 I B 1 1 a b への追い出しが行われる。

【 0 1 6 4 】

物理 N A N D 層管理部 1 2 0 c から、W C 2 1 M S 追記 I B 1 1 a b の追い出し終了が通知されると、論理 N A N D 層管理部 1 2 0 b は、M S 追記 I B 1 1 a b としてあらたなフリーブロック F B を物理 N A N D 層管理部 1 2 0 c から取得した場合は、物理 N A N D 層管理部 1 2 0 c から与えられたフリーブロック F B の論理ブロック I D に対応する M S 論理ブロック管理テーブル 3 5 のエントリの Valid フラグ 3 5 e を Valid にし、M S バッファ管理テーブル 6 1 の M S 追記 I B 用のフィールド 6 1 b に論理ブロック I D を登録し、M S 構造管理テーブル 6 0 の有効論理ブロック数 V B L をインクリメントする。

20

【 0 1 6 5 】

また、論理 N A N D 層管理部 1 2 0 b は、トラック管理テーブル 3 0 を更新する。すなわち、W C 2 1 から M S 追記 I B 1 1 a b へ追い出されたトラックに対応する論理トラックアドレス 3 0 a のエントリに対し、クラスタビットマップ 3 0 b 、論理ブロック I D 3 0 c および論理ブロック内トラック位置 3 0 d などの所要情報を登録する。

30

【 0 1 6 6 】

受動マージが行われていない場合は、前述のように、トラック管理テーブル 3 0 の対応する論理トラックエントリに所要情報を登録する。また、W C 2 1 から追い出された新しいトラックに関するデータを M S 論理ブロック管理テーブル 3 5 の書き込みを行った論理ブロック I D に対応するエントリに対し登録する。M S 論理ブロック管理テーブル 3 5 への登録としては、M S 論理ブロックに格納されたトラックに対応するトラック管理テーブル 3 0 のインデックスとしての論理トラックアドレス（トラック管理ポインタ 3 5 b ）の更新と、有効トラック数 3 5 c の更新と、書き込み可能先頭トラック 3 5 d の更新などがある。

【 0 1 6 7 】

40

W C 2 1 と M S 1 1 との受動マージが行われたとすると、トラック管理テーブル 3 0 中のマージ元トラックに対応する論理トラックアドレス 3 0 a のエントリ中の論理ブロック I D 3 0 c および論理ブロック内トラック位置 3 0 d などの所要情報が更新される。具体的には、論理ブロック I D 3 0 c が M S 1 1 に存在していたときの論理ブロック I D から M S 追記 I B 1 1 a b に対応する論理ブロック I D に変更され、論理ブロック内トラック位置 3 0 d が追記書き込み状態に応じて変更される。

【 0 1 6 8 】

さらに、M S 論理ブロック管理テーブル 3 5 中のマージ元の論理ブロックに対応するエントリにおけるトラック管理ポインタ 3 5 b のフィールドの該当箇所を削除し、有効トラック数 3 5 c をデクリメントし、さらに M S 構造管理テーブル 6 0 の有効トラック数別論

50

理ブロックIDリスト62を更新する。マージ元の論理ブロックに対応するエントリにおける有効トラック数35cがデクリメントにより0になった場合は、MS構造管理テーブル60の有効論理ブロック数VBLをデクリメントし、物理NAND層管理部120cに対しこの書き込み不可能な無効なフリーブロックFBを返却する。そして、この返却した論理ブロックに対応するエントリのValidフラグ35eをInvalidにする。さらに、前述と同様にして、WC21から追い出された新しいトラックに関するデータをMS論理ブロック管理テーブル35に登録する。

#### 【0169】

また、物理NAND層管理部120cから、WC21 MS追記IB11abの追い出し終了が通知されたとき、論理NAND層管理部120bは、DRAM層管理部120aに対し追い出し終了を通知する。この通知を受けたDRAM層管理部120aでは、WCクラスタ管理テーブル25中の追い出されたトラックに所属する全クラスタに対するエントリ中の状態フラグ25aはInvalid(使用可能)とされ、この後これらエントリに対する書き込みが可能となる。また、WCトラック管理テーブル24中の追い出されたトラックに対応するリストについては、例えば直前リストのnextポインタ24dが変更または削除されて、無効化される。

#### 【0170】

つぎに、CIB処理について説明する。WCF処理が終了すると、WCF処理によって書き込まれたFSIB12aのデータをFS12にMoveする処理と、WCF処理によって書き込まれたMSIB11aのデータをMS11またはTFS11bにMoveする処理などを含むCIB処理が実行される。以下、図30のフローチャートを用いてCIB処理の詳細手順について説明する。

#### 【0171】

##### ・MS部11QのCIB処理

まず、図19のステップS330で説明したMS部11Qでの第1回目のCIB処理について詳述する。論理NAND層管理部120bは、MS構造管理テーブル60のMSバッファ管理テーブル61のMSFB用フィールド61a、MS追記IB用のフィールド61bに登録されている論理ブロックIDについての有効トラック数の情報をMS論理ブロック管理テーブル35の有効トラック数35cのフィールドから取得し、MSIB11aのMSFB11aaまたはMS追記IB11abに全トラック書き込み済みのフルになったブロックが一つ以上存在するか否かを調べ(ステップS400)、MSIB11aにフルになったブロックが一つ以上存在する場合に、以下の処理を行う。ステップS400の判定がNOである場合は、手順はステップS440に移行する。

#### 【0172】

ステップS400の判断がYESの場合、論理NAND層管理部120bは、MS論理ブロック管理テーブル35の有効トラック数35cを参照することにより、MS内に有効トラック数35cが0となった無効論理ブロックが存在するか否かを調べ、MS内に無効論理ブロックが存在する場合、該無効論理ブロックを物理NAND層管理部120cに返却する(ステップS405)。返却された無効論理ブロックに対応するMS論理ブロック管理テーブル35のエントリはValidフラグ35eがInvalidにされ、MS構造管理テーブル60の有効論理ブロック数VBLがデクリメントされる。つぎに、MSFB11aa中のフルになった論理ブロックは、直接MS11にMoveされ、MS追記IB11ab中のフルになった論理ブロックはTFS11bにMoveされる(ステップS407)。このMove処理は、具体的には、MS構造管理テーブル60のMSバッファ管理テーブル61のMSFB用フィールド61a、MS追記IB用のフィールド61bに登録されている該当する論理ブロックIDを削除するのみである。

#### 【0173】

つぎに、論理NAND層管理部120bは、MS構造管理テーブル60の状態情報としての有効論理ブロック数VBLを最大論理ブロック数MBLと比較する(ステップS410)。この比較の結果、有効論理ブロック数VBLが最大論理ブロック数MBLを越えて

10

20

30

40

50

いる場合、論理NAND層管理部120bは、書き込み可能なフリーブロックFBが不足していると判断し、以下のMSコンパクション処理を1ブロックずつ実行して、全て無効なトラックで構成された物理NAND層管理部120cに返却するべき無効論理ブロックを増やし、有効論理ブロック数VBLを最大ブロック数未満MBLとする(ステップS420)。なお、ステップS410の判定において、書き込み可能なFBが不足していない場合は、手順はステップS440に移行される。

#### 【0174】

MSコンパクション処理には、前述したように、 $2^i$ トラックMSコンパクションと、 $2^i$ トラック未満MSコンパクションとの2種類がある。 $2^i$ トラックMSコンパクションでは、MSコンパクションバッファ11cが使用されて、コンパクション後の論理ブロックは、TFS11bの先頭にMoveされる。 $2^i$ トラック未満MSコンパクションでは、トラック単位に、MS追記IB11abにCopyされる。

#### 【0175】

まず、論理NAND層管理部120bは、MS構造管理テーブル60の有効トラック数別論理ブロックIDリスト62を参照することで、有効トラック数の少ない論理ブロックから、トラックを $2^i$ 個集めて、集めたトラックを $2^i$ 個ずつ、書き込み可能なフリーブロックFBとして物理NAND層管理部120cから取得したMSコンパクションバッファ11cに対しCopyする、 $2^i$ トラックMSコンパクションを実行する。

#### 【0176】

具体的には、論理NAND層管理部120bは、物理NAND層管理部120cに対し、フリーブロックFBの獲得要求を出して、フリーブロックFBを該フリーブロックFBとして割り当てられた論理ブロックIDと共に取得する。そして、コンパクション対象として選択した複数のトラックをこのフリーブロックFBにCopyするよう、物理NAND層管理部120cに対し、要求する。なお、このコンパクション対象のトラックがWC21、FS部12Q、IS部13Qに有効クラスタを持つ場合にはそれらもマージしてMSコンパクションバッファ11cに集められる、前述の受動マージが実行される。

#### 【0177】

物理NAND層管理部120cからコンパクションの終了が通知されると、論理NAND層管理部120bは、トラック管理テーブル30のコンパクションが行われたトラックに対応する論理トラックアドレス30aを持つエントリにおける、論理ブロックID30cを物理NAND層管理部120cから取得したフリーブロックFBの論理ブロックIDに更新し、さらに論理ブロック内トラック位置30dを更新する。

#### 【0178】

また、MSコンパクションバッファ11cとして使用した、物理NAND層管理部120cから取得したフリーブロックFBの論理ブロックIDをMS論理ブロック管理テーブル35に新たなエントリとして登録し、エントリ中の各フィールドに所要の情報を登録する。この登録としては、トラック管理ポインタ35bの更新と、有効トラック数35cの更新と、書き込み可能先頭トラック35dの更新などがある。

#### 【0179】

また、MS構造管理バッファ60のMSバッファ管理テーブル61のTFS用フィールド61cの FIFO構造(リンクリスト)の先頭に、MSコンパクションバッファ11cとして使用した論理ブロックIDを登録することで、MSコンパクションの結果、有効な $2^i$ 個のトラックを含む1論理ブロックで構成されたMSコンパクションバッファ11cを、TFS11bの先頭(最も古い位置)にMoveする。なお、TFS11bがフルになつたら、最も古い先頭のブロックがMS11にMoveされる。

#### 【0180】

つぎに、MS11中のコンパクション元の古いトラックデータを無効化する。具体的には、MS論理ブロック管理テーブル35中のコンパクション元の論理ブロックに対応するエントリにおけるトラック管理ポインタ35bのフィールドの該当箇所を削除し、有効トラック数35cをデクリメントし、さらにMS構造管理テーブル60の有効トラック数別

10

20

30

40

50

論理ブロックIDリスト62を更新する。有効トラック数35cがデクリメントにより0になった場合は、MS構造管理テーブル60の有効論理ブロック数VBLをデクリメントし、物理NAND層管理部120cに対しこの無効論理ブロックを返却する。そして、この返却した論理ブロックに対応するMS論理ブロック管理テーブル35のエントリはValidフラグ35eがInvalidにされる。

#### 【0181】

このようなコンパクション処理および無効論理ブロックFBの返却処理が終了すると、有効論理ブロック数VBLと最大論理ブロック数MBLを比較し、有効論理ブロック数VBLが最大論理ブロック数MBLを越えている場合は、再度、有効トラックを $2^i$ 個集める $2^i$ トラックMSコンパクションを実行する。また、有効論理ブロック数VBLが最大論理ブロック数MBLを越えている状態で、有効トラックを $2^i$ 個集める $2^i$ トラックMSコンパクションが不可能になった場合は、 $2^i$ トラック未満MSコンパクションが実行される。10

#### 【0182】

この $2^i$ トラック未満MSコンパクションでは、コンパクション対象の $2^i$ トラックに満たない個数のトラックをMS追記IB11abにコピーすることで、無効な $2^i$ トラックで構成された無効論理ブロックを生成し、生成した無効論理ブロックを物理NAND層管理部120cに返却することで、有効論理ブロック数VBLを減少させる。 $2^i$ トラック未満MSコンパクションについての、管理テーブルの更新については、その説明を省略する。20

#### 【0183】

##### ・FS12のCIB処理

つぎに、図19のステップS340で説明したFS12でのCIB処理について詳述する。論理NAND層管理部120bは、FS/IS構造管理テーブル65のFS入力バッファ管理テーブル66のFSFB用フィールド66a、FS追記IB用のフィールド66bに登録されている論理ブロックIDについての有効クラスタ数の情報を、FS/IS論理ブロック管理テーブル32の有効クラスタ数42dのフィールドから取得し、FSIB12aのFSFB12aaまたはFS追記IB12abに全ページ(全クラスタ)書き込み済みのフルになった論理ブロックが一つ以上存在するか否かを調べ(ステップS440)、FSIB12aにフルになった論理ブロックが一つ以上存在する場合に、以下の処理を行う。ステップS440の判定がNOである場合は、手順はここで終了する。30

#### 【0184】

ステップS440の判断がYESの場合、論理NAND層管理部120bは、FS/IS構造管理テーブル65およびFS/IS論理ブロック管理テーブル42の有効クラスタ数42dを参照することにより、FS部12Q内に有効クラスタ数42dが0である無効論理ブロックが存在するか否かを調べ、FS部12Q内に無効論理ブロックが存在する場合、該無効論理ブロックを物理NAND層管理部120cに返却する(ステップS445)。

#### 【0185】

返却された論理ブロックのエントリはMS論理ブロック管理テーブル35およびFS/IS論理ブロック管理テーブル42から削除される。つぎに、FSFB12aa中のフルになった論理ブロックは、FS12にMoveされ、FS追記IB12ab中のフルになった論理ブロックもFS12にMoveされる(ステップS447)。このMove処理は、具体的には、FS/IS構造管理テーブル65のFS入力バッファ管理テーブル66のFSFB用フィールド66a、FS追記IB用のフィールド66bに登録されている該当する論理ブロックIDを削除するのみである。40

#### 【0186】

つぎに、論理NAND層管理部120bは、FIFO構造を有するFS12の論理ブロック数が、FS12として許容される所定の最大論理ブロック数BL<sub>fsmax</sub>を越えているか否かを判断する(ステップS450)。具体的には、FSFIFO管理テーブル67か50

ら算出した論理ブロック数が予め設定した最大論理ブロック数  $B_L fsmax$  を越えているか否かを判断する。

#### 【0187】

この比較の結果、算出した論理ブロック数が最大論理ブロック数  $B_L fsmax$  を越えている場合、論理 NAND 層管理部 120b は、書き込み可能なフリーブロック FB が不足していると判断し、そのときの状態に応じて、以下の、MS11への例えは 2 論理ブロック分ずつの追い出し処理（ステップ S460）と、IS13への1論理ブロック分の追い出し処理を実行する（ステップ S500）。なお、ステップ S450 の判定において、FS12 内がフルでない場合は、FS12 から MSIB11aへの追い出し処理と、FS12 から ISIB13aへの追い出し処理を行うことなく、手順をここで終了する。

10

#### 【0188】

FS12 から MSIB11aへの追い出し処理では、まず、FS12 から IS 部 13Q を経ることなく MSIBS11a に直接移動する論理ブロックがあるか否かを判断する（ステップ S455）。具体的には、FS12 の FIFO の先頭にある最古の論理ブロック中のクラスタを順に 1 つずつチェックし、当該クラスタが属するトラックが FS 部 12Q 中に何個の有効クラスタを保有しているか、トラック管理テーブル 30 の FS クラスタ数 30f のフィールドを参照して検索する。そして、トラック内有効クラスタ数が所定の閾値（例えは  $2^{k-i-1}$  個）以上だった場合、その論理トラックを MSIB11aへの追い出し確定トラックとする。

#### 【0189】

20

上記の検索は、以下のルートを経る。

1. FS / IS 構造管理テーブル 65 の FSFIFO 管理テーブル 65 から FIFO の先頭にある最古の FS / IS ブロック ID を得る。

2. この FS / IS ブロック ID に対応する FS / IS 論理ブロック管理テーブル 42 のエントリ中のブロック内クラスタテーブル 42c のフィールドから FS / IS 内クラスタ管理テーブル 44 へのインデックスを得る。

3. FS / IS 内クラスタ管理テーブル 44 において、取得したインデックスで指定された 1 論理ブロック内の各エントリから FS / IS 管理テーブル 40 へのポインタを 1 つ取得して、FS / IS 管理テーブル 40 の該当リンクに飛ぶ。

4. 飛び先の該当リンクが所属する該当論理トラックアドレスを得る。

30

5. 取得した論理トラックアドレスを使ってトラック管理テーブル 30 の該当エントリ中の FS クラスタ数 30f のフィールドをチェックする。

6. 3 ~ 5 が繰り返される。

#### 【0190】

FS12 から MS11への追い出しは、例えは 2 論理ブロックずつ行われる。すなわち、論理 NAND 層管理部 120b は、上記トラック内有効クラスタ数が所定の閾値（例えは  $2^{k-i-1}$  個）以上のトラックを、2 論理ブロック分集め、該集めた 2 論理ブロック分のトラックを MSIB11a の MSFB11aa に追い出す（ステップ S460）。この追い出しの際、追い出しトラック中の FS12 内に存在しないクラスタについては、WC21、IS 部 13Q、および MS11 から読み出してマージする前述の受動マージが実行される。

40

#### 【0191】

ただし、MSIB11aへの追い出し確定トラックが、2 論理ブロック分存在しない場合は、1 論理ブロックを MSIB11a の MSFB11aa に追い出し、1 論理ブロック分に満たない個数のトラックを MS 追記 IB11ab に対してトラック単位に追記書き込みする（ステップ S460）。同様に、MSIB11aへの追い出し確定トラックが、1 論理ブロック分存在しない場合は、1 論理ブロック分に満たない個数のトラックを MS 追記 IB11ab に対してトラック単位に追記書き込みする（ステップ S460）。その後、FIFO 構造の FS12 の先頭論理ブロックに有効なクラスタが残っていない場合には、先頭論理ブロックを無効論理ブロックとして、物理 NAND 層管理部 120c に返却す

50

る。

【0192】

・MS11のCIB処理(図19:ステップS350)

このようにして、FSからMSIB11aへの追い出しが発生すると、つぎに、MS部11QのCIB処理が再び実行される(ステップS480)。このステップS480のMS部11QのCIB処理は、先の第1回目のMS部11QでのCIB処理(ステップS400～S420)と同様なので、重複する説明は省略する。このMS部11QでのCIB処理の後、論理NAND層管理部120bは、FS12からMSIB11aへの追い出し条件が成立するか否かを、前記同様にして調べる(ステップS455)。この追い出し条件が成立すると、前述した、FS12からMSIB11aへの2論理ブロックの追い出し、およびMS11でのCIB処理が、再度実行される。このような処理が、ステップS455の判断がNOになるまで繰り返される。

【0193】

・FS12のCIB処理

ステップS455の判断がNOになると、論理NAND層管理部120bは、つぎに、FS12からISIB13aへの追い出し条件が、成立するか否かを判断する(ステップS490)。具体的には、上記FS12からMSIB11aへの追い出し処理の際に、チェックされたFIPO構造を有するフル状態のFS12の先頭論理ブロックに有効なクラスタが残っている場合に、ステップS490でのFS12からIS13への追い出し条件が成立したとして、FS12からISIB13aへの追い出しを実行する。

【0194】

すなわち、ステップS490で条件が成立した場合は、MSIB11aへの追い出しトラックに含まれないクラスタだけを含む先頭論理ブロックをISIB13aへMoveする(ステップS500)。このステップS500においては、例えば1論理ブロックの追い出しが実行される。そして、状態によっては、その後、ステップS520～S585の手順を経た後、ステップS590の判断により、ステップS500でのFS12からISIB13aへの追い出しが再度発生することもある。

【0195】

ステップS500での再追い出しがある状態とは、例えば、FSIB12aに複数のフルになった論理ブロックを有するバッファ(FSFB12aaまたはFS追記IB12ab)が存在する状態において、FIPO構造を有するFS12がフルであった場合には、FSIB12aからFS12へのフルになったブロックのMoveに伴い、FS12からMSIB11aまたはISIB13aへの複数のブロックの追い出しが発生する状態である。このような条件下で、FS12からISIB13aへの複数の論理ブロックの追い出しが発生する可能性がある。

【0196】

・ISのCIB処理(図19ステップS360)

つぎに、ステップS490での条件が成立したときに、IS13で行われる追い出し処理およびコンパクション処理の詳細について、図30の他に、図31のフローチャートを参照して説明する。まず、論理NAND層管理部120bは、前記と同様にして、IS部13Q内に無効論理ブロックが存在するか否かを調べ、IS部13Q内に無効論理ブロックが存在する場合、該無効論理ブロックを物理NAND層管理部120cに返却する(ステップS520)。返却された論理ブロックのエントリに対応するMS論理ブロック管理テーブル35およびFS/IS論理ブロック管理テーブル42のエントリはValidフラグ35eおよび42fがそれぞれInvalidにされる。

【0197】

つぎに、論理NAND層管理部120bは、FIPO構造を有するIS13の論理ブロック数が、IS13として許容される所定の最大論理ブロック数BLismaxを越えているか否かを判断する(ステップS530)。具体的には、ISFIFO管理テーブル69から算出した論理ブロック数が予め設定した最大論理ブロック数BLismaxを越えているか

否かを判断する。

【0198】

この比較の結果、算出した論理ブロック数が最大論理ブロック数  $B_{Lismax}$  を越えている場合、論理 N A N D 層管理部 120b は、書き込み可能なフリーブロック F\_B が不足していると判断し、IS13 から例えば 2 論理ブロック分のトラックを M S I B 11a の M SFB11aa に追い出す（ステップ S540）。なお、ステップ S530 の判定において、IS13 がフルでない場合は、MSIB11a への追い出し処理などを行うことなく、ISIB13a 中のフルになった論理ブロックを、IS13b へ Move する（ステップ S585）。

【0199】

ステップ S540 の追い出しの際には、図 12 に示したトラック管理テーブル 30 などを用いて、図 31 に示す追い出しトラックの選別処理を実行する。図 31 において、論理 N A N D 層管理部 120b は、選別処理（サイクリックサーチ処理、以下単にサーチ処理という）を開始すると（ステップ S700）、前回のサーチの際に検索済み最終トラックとしてステップ S740 において記憶したトラック管理テーブル 30 のインデックスである論理トラックアドレス 30a の次の論理トラックアドレスからサーチを開始する（ステップ S710）。

【0200】

サーチが初回（第 1 サイクル）である場合は、トラック管理テーブル 30 の最初のエントリからサーチを開始する（ステップ S710）。また、ステップ S740 で記憶した検索済みトラックがトラック管理テーブル 30 の最終エントリ（図 12 のトラック n）である場合は、ステップ S710 での次のトラック検索では、先頭エントリ（図 12 のトラック 0）に戻る。

【0201】

このサーチにおいては、トラック管理テーブル 30 の当該エントリ中の IS クラスタ数 30g のフィールド（当該論理トラック中の有効クラスタ数）を参照し、当該エントリ IS13 内に有効クラスタを保持している場合は、図示しない新規検索トラックリストに当該エントリの論理トラックアドレスを登録する（ステップ S720）。つぎに、新規検索トラックリストに登録されたトラックの個数を所定の閾値 L と比較し、登録数が閾値 L より少ない場合は、手順をステップ S710 に移行し、トラック管理テーブル 30 の次のエントリを前述と同様にして調べる。

【0202】

このような処理を繰り返すことにより、新規検索トラックリストに閾値 L 個分の論理トラックアドレスを登録する（ステップ S730 Yes）。そして、最後に新規検索トラックリストに登録した論理トラックアドレスに対応するトラック管理テーブル 30 のエントリ（インデックス）を検索済み最終トラックとして記憶して、今回サイクルの検索を終了する（ステップ S740）。

【0203】

つぎに、論理 N A N D 層管理部 120b は、前回落選の論理トラック（図示せず）がリストされている落選トラックリストがあるか否かを判断する（ステップ S750）。初回サイクルの際は、落選トラックリストが存在しないので、新規検索トラックリストと新規追加ブロック内トラックリスト（図示せず）との 2 つのリストに基づいて  $2^{i+1}$  個の論理トラックを選出する（ステップ S760）。新規追加ブロック内トラックリストとは、図 30 のステップ S500 で、FS12 から IS 部 13Q に追い出されたブロック（FS / IS 構造管理テーブル 65 の IS 入力バッファ管理テーブル 68 にエントリされている）に含まれるトラックに関するリストである。

【0204】

初回サイクルの際は、このような 2 つのリストを用いて、追い出し候補の  $2^{i+1}$  個のトラックを選出する。この選出には、前述したように、トラック内の有効クラスタ数と、有効クラスタ係数とを用いた選出基準（スコア値） S が用いられる。

10

20

30

40

50

スコア値  $S =$  トランク内の有効クラスタ数  $\times$  有効クラスタ係数

有効クラスタ係数は、トランクが MS 部 11Q 内で無効トランクが存在する論理ブロックに存在するか否かによって重み付けされる数であり、存在したほうが存在しない場合より数が大きいとする。

#### 【0205】

有効クラスタ数は、トランク管理テーブル 30 の IS クラスタ数 30g のフィールドを見ることで取得することができる。また、有効クラスタ係数は、トランク管理テーブル 30 とトランク管理ポインタ 35b のフィールドでリンクしている MS 論理ブロック管理テーブル 35 の有効トランク数 35c のフィールドを見ることで取得することができる。

#### 【0206】

論理 NAND 層管理部 120b は、新規追加ブロック内トランクリストに含まれる複数のトランクから、上記スコア値  $S$  が上位の  $M$  個（所定の設定値）のトランクを選択する。選択された  $M$  個のトランクに、先のサーチによって新規検索トランクリストに登録された  $L$  個のトランクを加え、これら  $L + M$  個のトランク中から、スコア値  $S$  が高い  $2^{i+1}$  個のトランクを、MS11への追い出しを行うトランクとして選出する。そして、 $L + M$  個のトランクのなかで、選出された  $2^{i+1}$  個のトランク以外のトランクを、前述の落選トランクリストに登録する。

#### 【0207】

2 回目以降のサイクルの際は、落選トランクリストと、新規検索トランクリストと、新規追加ブロック内トランクリストとの 3 つのリストに基づいて  $2^{i+1}$  個のトランクを選出する（ステップ S770）。なお、2 回目以降の、追い出しを行うか否かは、後述する図 30 のステップ S570 の判断に応じて決められる。3 つのリストを用いた選出処理では、落選トランクリストに含まれる複数のトランクから、スコア値  $S$  が上位の  $N$  個（所定の設定値）のトランクを選択し、新規追加ブロック内トランクリストに含まれる複数のトランクから、スコア値  $S$  が上位の  $M$  個（所定の設定値）のトランクを選択し、これら  $N + M$  個のトランクに、さらに今回 2 回目以降のサイクルの際に得られた新規検索トランクリストに登録された  $L$  個のトランクを加え、これら  $L + M + N$  個のトランク中から、スコア値  $S$  が高い  $2^{i+1}$  個のトランクを、MS11への追い出しを行うトランクとして選出する。そして、 $L + M + N$  個の論理トランクのなかで、選出された  $2^{i+1}$  個のトランク以外のトランクを、次回サイクルに使用する落選トランクリストに登録する。

#### 【0208】

つぎに、図 30 のステップ S540 に戻って説明する。前述のようにして、2 論理ブロック分のトランクの追い出し候補が選出されると、論理 NAND 層管理部 120b は、該選出された 2 論理ブロック分のトランク（すなわち  $2^{i+1}$  個のトランク）を MSIB11a の MSFB11aa に追い出す（ステップ S540）。この追い出しの際、追い出しひトランク中の IS 部 13Q 内に存在しないクラスタについては、WC21 および FS 部 12、および MS11 から読み出してマージする前述の受動マージが実行される。なお、上記では、有効クラスタ数と MS に穴あきブロックが存在しているか否かの係数とに基づくスコア値  $S$  によって追い出しひトランクを選出するようにしているが、有効クラスタ数のみによって追い出しひトランクを選出するようにしてもよい。

#### 【0209】

- MS の CIB 处理（図 19 ステップ S370）

このようにして、IS13 から MSIB11a への追い出しが発生すると、つぎに、MS11 の CIB 处理が再び実行される（ステップ S560）。このステップ S560 の MS11 の CIB 处理は、先の第 1 回目の MS11 での CIB 处理（ステップ S400 ~ S420）と同様なので、重複する説明は省略する。

#### 【0210】

##### IS の CIB 处理

つぎに、論理 NAND 層管理部 120b は、IS13 から MSIB11a に対する追い出しを再度実行するか否かを判断する（ステップ S570）。すなわち、論理 NAND 層

10

20

30

40

50

管理部 120b は、MS 論理ブロック管理テーブル 35 および FS / IS 論理ブロック管理テーブル 42 の有効クラスタ数 42d のフィールドなどを用いて、ステップ S540 での追い出しを行った後の IS13 内の論理ブロックを有効クラスタ数の少ない順にソートし、最も有効クラスタ数の少ない 2 つの論理ブロックの合計有効クラスタ数が、所定の設定値である  $2^k$  個 (1 論理ブロック分) 以上ある場合は、IS13 から MSIB11a への追い出し条件が成立したと判断する (ステップ S570)。

#### 【0211】

IS13 から MSIB11a への追い出し条件が成立した場合は、手順をステップ S540 に移行し、図 31 のステップ S700 ~ S750 および S770 の処理を実行することで、上記の 2 論理ブロック分の追い出し処理を再度実行する。ステップ S570 の判断が YES である限り、IS13 から MSIB11a への 2 論理ブロック分の追い出し処理と、MS11 での CIB 処理が繰り返し実行される。そして、ステップ S570 の判断が NO となった場合は、IS13 でのコンパクション処理が実行される (ステップ S580)。

10

#### 【0212】

IS コンパクション処理では、MS 論理ブロック管理テーブル 35 および FS / IS 論理ブロック管理テーブル 42 の有効クラスタ数 42d のフィールドなどを用いて、IS 部 13Q 内の有効クラスタの少ない論理ブロックから順にクラスタを 1 論理ブロック分、すなわち  $2^k$  個集め、これら  $2^k$  個のクラスタを IS コンパクションバッファ 13c に Copy する。この Copy 処理が終了すると、論理 NAND 層管理部 120b は、コンパクション元 (Copy 元) の論理ブロックのうち有効クラスタがなくなったものを無効論理ブロックとして物理 NAND 層管理部 120c に返却し、コンパクション処理によって有効クラスタが詰まった論理ブロックで構成される IS コンパクションバッファ 13c を IS13 に Move する。

20

#### 【0213】

このコンパクションの後、ISIB13a 中のフルになった論理ブロックは IS13 に Move される (ステップ S585)。この Move 処理は、具体的には、FS / IS 構造管理テーブル 65 の IS 入力バッファ管理テーブル 68 の ISIB 用フィールドに登録されている該当する論理ブロック ID を削除するのみである。

30

#### 【0214】

この後、論理 NAND 層管理部 120b は、前述した FS12 から ISIB13a への追い出し条件が成立しているか否かを判断し (ステップ S590)、この FS12 から ISIB13a への追い出し条件が成立している場合は、手順をステップ S500 に移行し、上述した手順を再度繰り返す。また、論理 NAND 層管理部 120b は、IS コンパクション処理の終了後、FS12 から ISIB13a への追い出し条件が成立していないと判断した場合は、これで今回の書き込み処理を終了する。以上が、書き込み処理の詳細である。

#### 【0215】

以上説明したように本実施の形態においては、IS13 でのコンパクション処理に先立ち、図 30 のステップ S540 で、有効クラスタ数が多くてかつ MS に穴あきブロックが存在していることでソートされる上位の複数のトラックによって構成される複数のブロックを MS11 へ追い出すようにしてあり、これによりコンパクション前に IS13 の状態をコンパクションを実行し易い状態にすることができる。すなわち、IS13 をコンパクションする時点では、有効クラスタ数の少ない論理ブロックが 2 つ以上存在する第 1 の状態と、有効クラスタ数の少ないブロックが 2 つ以上存在しない第 2 の状態が存在する。第 1 の状態は、そのままコンパクション処理が可能な状態であるが、第 2 の状態は、このままでは効率のよいコンパクション処理ができない状態である。そこで、本実施の形態においては、有効クラスタ数が多く、MS に穴あきブロックが存在していることでソートされる上位の複数のトラックによって構成される複数のブロックをコンパクション前に MS11 へ追い出すようにしてあり、これにより IS13 の状態をコンパクションを実行する前

40

50

に、上記の第1の状態に移行させることができるとなる。これにより、一度のコンパクションにかかる時間を平準化かつ高速化することが可能となる。

### 【0216】

また、本実施の形態においては、トラック管理テーブル30の全てのエントリを検索するのではなく、落選トラックリスト中のスコア値Sが上位のN個の論理トラックと、新規追加ブロック内トラックリスト中のスコア値Sが上位のM個の論理トラックと、有効クラスタ数を持つことで選んだ新規検索トラックリスト中のL個の論理トラックとの中から、スコア値Sが高い $2^{i+1}$ 個の論理トラックをMS11への追い出しを行う論理トラックとして選出するようにしてあり、スコア値に基づくサーチ精度を維持しつつサーチ速度を向上させることができる。また、トラック管理テーブル30の検索による新規検索トラックリストの作成時、検索済み最終トラックを記憶し、次回検索時は、この記憶した最終トラックの次のトラックから検索を行うサイクリックサーチを行うようにしているので、サーチ速度の向上を目的としてトラック管理テーブル30の全てのエントリを検索していないにもかかわらず、結果的に検索箇所が片寄ることなく、検索処理の精度を平準化することができる。10

### 【符号の説明】

### 【0218】

10 NANDメモリ、11、メインストレージ領域(MS)、11a MS入力バッファ(MSIB)、11aa フルブロック入力バッファ(MSFB)、11ab MS追記入力バッファ(MS追記IB)、11b トラック中段ストレージ領域(TFS)、20  
12 前段ストレージ領域(FS)、12a FS入力バッファ(FSIB)、13 中段ストレージ領域(INS)、13a INS入力バッファ(INSIB)、20 DRAM、  
21 ライトキャッシュ(WC)、22、リードキャッシュ(RC)。

【図1】



【図2】



【図3】



【図4】



【図5】



【図6】



【図7】



【図8】



【図9】

RCクラスタ管理テーブル23(逆引き): n-way セットアソシアティブ

|        | way 1            | way n |
|--------|------------------|-------|
| Line 1 | 状態フラグ+論理トラックアドレス | ...   |
| :      | :                | ...   |
| Line m | 状態フラグ+論理トラックアドレス | ...   |

23a

23b

【図11】



【図10】

WCクラスタ管理テーブル25(逆引き): n-way セットアソシアティブ

|        | way 1                        | way n |
|--------|------------------------------|-------|
| Line 1 | 状態フラグ+セクタ位置ビットマップ+論理トラックアドレス | ...   |
| Line 2 | 25a 25c ... 25b              | ...   |
| :      | :                            | ...   |
| Line m | ...                          | ...   |

25a

25b

25c

【図12】

| トラック管理テーブル30(正引き)  |     |     |     |     |
|--------------------|-----|-----|-----|-----|
| 論理トラックアドレス         | 30a | 30b | 30c | 30d |
| トラック管理<br>(2トラック分) | 30e | 30f | 30g | 30h |
| 論理ブロックID           | 35a | 35b | 35c | 35d |
| 有効トラック数            | 35e | 35f | 35g | 35h |
| 書込み可能<br>先頭トラック    | 35i | 35j | 35k | 35l |
| Valid              | 35m | 35n | 35o | 35p |

【図14】

| MS論理ブロック管理テーブル35(逆引き) |     |     |     |     |
|-----------------------|-----|-----|-----|-----|
| 論理ブロックID              | 35a | 35b | 35c | 35d |
| トラック管理<br>(2トラック分)    | 35e | 35f | 35g | 35h |
| 有効トラック数               | 35i | 35j | 35k | 35l |
| 書込み可能<br>先頭トラック       | 35m | 35n | 35o | 35p |
| Valid                 | 35q | 35r | 35s | 35t |

【図13】



【図15】



【図16】

【 図 17 】



### 【図18】

【 図 1 9 】



【図20】

| From | WC  | FS                    | IS            | MS                       |
|------|-----|-----------------------|---------------|--------------------------|
| WC   | N/A | クラスタ追い出し              | N/A           | トラック追い出し<br>受動マージ        |
| FS   | N/A | クラスタ穴埋め<br>(ブロック追い出し) |               | トラック追い出し<br>受動マージ        |
| IS   | N/A | クラスタ穴埋め               | IS compaction | トラック追い出し<br>受動マージ        |
| MS   | N/A | クラスタ穴埋め               | N/A           | トラック穴埋め<br>MS compaction |

【図21】



【図22】



【図23】



### 【図24】

【 図 25 】

| 論物変換テーブル50(正引き) |              |     |     |     |     |
|-----------------|--------------|-----|-----|-----|-----|
| 論理ブロックID        | 物理ブロックID × 8 | 50b |     | 50c |     |
|                 |              | 50a | 50d | 50e | 50f |
| ...             | ...          | ... | ... | ... | ... |
| ...             | ...          | ... | ... | ... | ... |
| ...             | ...          | ... | ... | ... | ... |
| ...             | ...          | ... | ... | ... | ... |

【図26】

【図27】



【図28】



【図29】



【図30】



【図31】



---

フロントページの続き

(72)発明者 岡本 渉  
東京都港区芝浦一丁目1番1号 株式会社東芝内  
(72)発明者 加藤 亮一  
東京都港区芝浦一丁目1番1号 株式会社東芝内

審査官 野田 佳邦

(56)参考文献 特開2006-11818 (JP, A)  
特開2008-33788 (JP, A)  
特開2009-211227 (JP, A)  
特開2009-211229 (JP, A)  
特開2009-211220 (JP, A)  
特開2009-211231 (JP, A)

(58)調査した分野(Int.Cl., DB名)

G 06 F 12/00 - 12/06  
G 06 F 12/08