1つの実施の形態では、本発明によるシステムは、小型コンピュータシステムインタフェース(「SCSI」)に基づいた、SAS(「シリアルアタッチドSCSI」)、FC(「ファイバチャンネル」)、及びFC−AL(「ファイバチャネルアービトレーテッドループ)を含む様々なマスストレージプロトコル、並びにシリアルATA(「SATA」)プロトコルで動作するように設計される。当業者はマスストレージプロトコルに精通しているため、これらプロトコルはここで更に説明されない。特定のプロトコルがどこで呼び出されるかを除いて、ここに開示されたシステムと方法は、用いられる特定のプロトコルに依存せず、プロトコルの全てで正確に動作するように設計される。更に、本発明の実施の形態によるシステム及び方法は、エンドユーザ等の他のアプリケーションのためのプロトコルと同様にエンタープライズレベルのアプリケーションのためのプロトコルを含む現在利用しているか又は開発されているいずれかの他の同様のプロトコルの利用のために適しているだろう。ここに説明されたシステムは、フラッシュページ(例えば、メタデータ)に格納されるファームウェアによって利用される暫定的なデータ及び情報等のファームウェアデータのハンドリングのための新規な方法及び/又はアーキテクチャを含む。
図1を参照すると、本発明の実施の形態によるフラッシュメディアコントローラを有して実現されたシステム100のブロック図が示される。一例では、システム(又はアーキテクチャ)100は、ブロック(又は回路)102、複数のブロック(又は回路)104a〜104n、複数のブロック(又は回路)106a〜106n、ブロック(又は回路)108、ブロック(又は回路)110、ブロック(又は回路)112、ブロック(又は回路)114、及びブロック(又は回路)116を備える。回路102〜116は、ハードウェア、ファームウェア、ソフトウェア、ハードウェアの組み合わせ、ファームウェア、及び/又はソフトウェア、又は他の実装として実現されたモジュール及び/又はブロックを表わす。
一例では、ブロック102は、本発明の実施の形態によるフラッシュメディアコントローラ(FMC)を実現する。ブロック104a〜104nは、フラッシュストレージデバイス又はコンポーネントの第1の数として実現される。ブロック104a〜104nは、ブロック102の第1のフラッシュレーンに連結される。ブロック102の第1のフラッシュレーンは、ブロック104a〜104nのそれぞれに独立したチップイネーブル(CE)信号を提供するように構成される。ブロック106a〜106nは、フラッシュストレージデバイス又はコンポーネントの第2の数として実現される。ブロック106a〜106nは、ブロック102の第2のフラッシュレーンに連結される。ブロック102の第2のフラッシュレーンは、ブロック106a〜106nのそれぞれに独立したチップイネーブル(CE)信号を提供するように構成される。FMC102は、2つのフラッシュレーンインスタンスで図示されるが、特定の実施の形態のその設計基準を満たすために、より多くのフラッシュレーンが実現されるであろうことは当業者に明らかである。フラッシュコンポーネント104a〜104n及び106a〜106nは、1つ以上のダイを備える単一のフラッシュパッケージとして実現される。フラッシュコンポーネント104a〜104n及び106a〜106nは、NAND及び/又はNORフラッシュデバイスを用いて実現される。ブロック102は、NANDフラッシュ及び/又はNORフラッシュのための適切なフィジカルレイヤサポート(PHY)を含む。
ブロック108は、ブロック102に連結される外部のFMCプロセッサ(FARM)を実現する。ブロック110は、ブロック102に静的ランダムアクセスメモリ(SRAM)及び/又は動的ランダムアクセスメモリ(DRAM)を連結するように構成されるメモリコントローラを実現する。ブロック112は、1つ以上のSRAMデバイスとして実現される。ブロック114は、1つ以上のDRAMデバイスとして実現される。ブロック116は、ブロック110及びブロック114を連結するダブルデータレートフィジカルレイヤ(PHY)インタフェースを実現する。一例では、ブロック102、108、110、112、114及び116は、チップ(SOC)アーキテクチャのシステムを実現する。
ブロック102は、様々なアプリケーションがフラッシュデバイス104a〜104n及び106a〜106nを用いるのを支援するように構成されたソフトIPブロックとして実現される。ここに用いられたように、用語のソフトIPブロックは、一般に、ソフトウェア(例えば、HDLコード、RTLコード等)で提供される集積回路のビルディングブロックを表わす。ブロック102は、一般に、フラッシュデバイスを有する複数のフラッシュインタフェースをサポートする。ブロック102は、一般に、プロセッサ(例えば、ARM)を含まない。しかしながら、ブロック102は、一例では、外部プロセッサ108にブロック102を連結するように構成されたインタフェース(例えば、32ビットAHB等)を実現する。ブロック102は、一般に、ブロック104a〜104n及び106a〜106nによって構成されたフラッシュメディアマスストレージアレイの管理をハンドリングするように構成される。一例では、ブロック102は、付属する複数の独立したフラッシュコンポーネントを有する単一のフラッシュデータレーンに関連する大部分の管理機能を実行する多数例示されたフラッシュレーンコントローラ(FLC)を利用する。ブロック102の機能は、ブロック102がフラッシュアクセスに関してほとんど理解しないという意味ではいくぶん一般的である。ブロック102は、一般に、フラッシュアウェアレーンをまとめ上げて単一のハードウェアエンティティを作ることに関する。一例では、ブロック102を実現するソフトIPは、アプリケーションのために出来る限り最大のレーンをサポートするためにパラメータ化する。例えば、1つの実施の形態では、レーンの数は2である。別の実施の形態では、その数は8である。
一例では、ブロック102は、以下に含まれる特徴をサポートする:(i)2つのフラッシュレーン;(ii)フラッシュレーンのそれぞれでの8つまでのチップイネーブル信号(CE);(iii)非同期ノーマルモード、非同期拡張モード、トグル1.0、ONFI2.1、ONFI2.3、及びトグル2.0を含むフラッシュインタフェース;(iv)専門のECC又は複数のレーンの間で共有されたECCは、設定可能なハードウェアである(例えば、ブロック102を実現するソフトIPブロックの特徴をパラメータ化する);(v)フラッシュインタフェースでの8ビットデータ;(vi)トグル2.0でのフラッシュインタフェース又はONFI2.3でのフラッシュインタフェースの仕様の200MHzまでのDDRレート;(vii)部分的な読み取りコマンド、(viii)ランダム読み取りコマンド;(ix)フラッシュ書き込み/読み取りのCRCストリップ/インサートオプション;(x)4Kバイトデータのための64ビットまでの訂正;(xi)512、2K、4Kバイトデータでの設定可能なnビット訂正(最大n=64);(xii)レジスタプログラミングのための32ビットAHBインタフェース;(xiii)外部メモリ(例えば、DRAM又はSRAM)でのコンテキストコマンドの記憶;(xiv)フラッシュレーンコントローラのカットスルーバッファ;(xv)優れたパフォーマンスを提供するための独立したフラッシュ読み書きデータパス;(xvi)フラッシュユニットナンバー(FUN)ごとにインオーダ状態の伝達;(xvii)フラッシュレーンごとにデータパスのための1つの読み取り及び1つの書き込みバッファコントローラ(BC)インタフェースのサポート;(xviii)コンテキスト訂正のための読み取りBCインタフェースのサポート;(xix)コンテキストアップデートのための書き込みBCインタフェースのサポート;(xx)コンテキストフリーリソースポインタ(CFRP)のための読み取り/書き込みBCインタフェースのサポート。
図2を参照すると、本発明の実施の形態によるフラッシュメディアコントローラ(FMC)アーキテクチャの一例を図示する図1のブロック102のより多くの個別ブロック線図が示される。一例では、ブロック102は、バッファコントローラ(BC)インタフェース、フラッシュデバイスインタフェース、及びプロセッサインタフェース(例えば、32ビットAHB等)の三大機能インタフェースを実現する。バッファコントローラ(BC)インタフェースは、ブロック図の左側及び左上に図示される。一例では、7つのバッファコントローラインタフェース(例えば、3つの読み取りインタフェースBC_RD_I/F、3つの書き込みインタフェースBC_WR_I/F、及び1つの読み取り/書き込みインタフェースBC_RD/WR_I/F)が実現される。フラッシュデバイスインタフェースは、ブロック図の右側に図示される。一例では、2つのフラッシュレーンインタフェース(例えば、FLASH_I/F_0及びFLASH_I/F_1)が実現される。32ビットAHBインタフェースは、ブロック図の右上に図示される。32ビットAHBインタフェースは、一例では、レジスタのプログラム、状態の読み取り、及びブロック102の内部のレジスタの診断に用いられる。
ブロック102は、一般に、ブロック(又は回路)150、ブロック(又は回路)152、複数のブロック(又は回路)154a〜154n、複数のブロック(又は回路)156a〜156n、複数のブロック(又は回路)158a〜158n、ブロック(又は回路)160、ブロック(又は回路)162、ブロック(又は回路)164、ブロック(又は回路)166、ブロック(又は回路)168、ブロック(又は回路)170、複数のブロック(又は回路)172a〜172n、及び複数のブロック(又は回路)174a〜174nを備える。回路150から174a〜174nは、ハードウェア、ファームウェア、ソフトウェア、ハードウェアの組み合わせ、ファームウェア、及び/又はソフトウェア、又は他の実装として実現されるモジュール及び/又はブロックを表わす。ブロック150は、プロセッサインタフェースロジック(PIL)を実現する。ブロック152は、データDMAマネージャ(DDM)を実現する。ブロック154a〜154nは、フラッシュバスコントローラ(FBC)を実現する。ブロック156a〜156nは、フラッシュレーンコントローラ(FLC)を実現する。ブロック158a〜158nは、データ転送パス(DTP)を実現する。ブロック160は、コンテキストフェッチアービタ(CA)を実現する。ブロック162は、コンテキストフリーポインタリソース(CFPM)を実現する。ブロック164は、消費コンテキストマネージャ(CCM)を実現する。ブロック166は、コンテキスト訂正ポート(CRP)を実現する。ブロック168は、コンテキストアップデートポート(CUP)を実現する。ブロック170は、コンテキストポインタリストポート(CPLP)を実現する。ブロック170は、一般に、オプションである。ブロック172a〜172nは、データDMA読み取りインタフェースポート(DDRIP)を実現する。ブロック174a〜174nは、データDMA書き込みインタフェースポート(DDWIP)を実現する。そして、ブロック172a〜172n及び174a〜174nは、一般に、データDMAインタフェースポート(DDIP)を構成する。
一例では、ブロック150は、ブロック108からブロック102の指定可能なリソースにインタフェースを提供する(例えば、AMBA AHBライトインタフェースを介して)。ブロック150は、構成のために全ての指定可能なリソース、ダイレクトインタフェース、及びブロック156a〜156nの内部に存在しないブロック102のサブモジュールの状態レジスタにインタフェースを提供する。ブロック150は、同様にそれぞれのブロック156a〜156nの内部に存在する指定可能なリソースにインタフェースを提供する。更に、ブロック150は、プロセッサファームウェアはブロック168を介してシステムバッファの中への記憶のためのブロック102に実メディアコンテキストを書き込むコンテキスト構造バッファ(CCB)を含む。一例では、ブロック150は以下の特徴を含む:ブロック108に対する32ビットAMBA AHBライトスレーブインタフェース、入力クロック(例えば、HCLK)のいくらか分割値(又は同じ)システムクロック(例えば、SYS_CLK)、ブロック102の全てのプロセッサ指定可能スペースと同様に全ての構成及び状態レジスタに対するアクセス、システムバッファに格納されるコンテキストを構築するためにプロセッサファームウェアによって用いられるコンテキスト構造バッファ(CCB)、指定可能リソースのアクセスがプロセッサアクセスポート(PAP)によってハンドリングされ、ブロック102で複数のサブモジュールによって用いられるレジスタを含んでいる場合、ブロック156a〜156nのそれぞれに分配されるプロセッサインタフェース。ブロック150は、全てのレジスタの復号化を実行し、ブロック156a〜156nにおいて論理的に格納されない全ての指定可能なリソースのために読み取りデータを多重化する。
ブロック152は、一般に、2つのデータ転送、フラッシュプログラム(例えば、バッファからフラッシュデバイスへのデータトランザクション)のための1つ、及びフラッシュ読み取り(例えば、フラッシュデバイスからバッファへのデータトランザクション)のための別のものを管理する。DMAデータパスは、一般に、ブロック156a〜156nからそれぞれのブロック158a〜158n、データDMAインタフェースポート(DDIP)ブロック172a〜172n及び174a〜174nを通じて別々の32ビットの読み書きデータバスを備える。ブロック158a〜158nは、ECC機能を含む。DMAデータ転送は、一般に、ブロック102の他のサブブロック(又はポートブロック)によって対応するコンテキストに対するマルチプルアクセスを含むイベントのシーケンスを備える。一例では、DMA転送は、FLC要求、検索コンテキスト動作、データ転送、及びFLC完了フェーズを含む。
FLC要求ステップにおいて、データ転送は、それぞれの要求ラインをレイズするブロック156a〜156nの1つから開始する。検索コンテキスト動作では、対応するコンテキストはコンテキスト訂正ポート(CRP)インタフェース166を介してバッファコントローラから検索される。データ転送は、コンテキストがDDIPに送信されると共に返答をし又はしない間に、DDIP、DTP、及びFLCブロックの間で発生する。FLC完了フェーズでは、選択されたブロック156a〜156nに対する完了ラインは転送の終わりを示すためにレイズされる。DDM152は、コンテキストを検索し、データトランザクションを容易にするためにDTPブロックに入力を提供するために作用する。
ブロック154a〜154nは、一般に、フラッシュレーンのそれぞれの1セットのNANDフラッシュデバイスに対するローレベルのインタフェースシグナリングを実行する。一般に、フラッシュレーンコントローラ(FLC)156a〜156nのそれぞれのために1つのフラッシュバスコントローラ(FBC)154a〜154nがある。ブロック154a〜154nは、一般に、与えられたタイプ(例えば、非同期、ONFI2.0同期、ONFI2.3同期、三星トグル1.0、三星トグル2.0等)のための異なるタイミングモードと同様にいくつかのインタフェースタイプのために、フラッシュインタフェースプロトコルのサイクルのそれぞれのタイミングを管理する。サイクルのタイミングは、一例では、内部タイミングレジスタのグループに格納されたタイミングカウントを介して制御される。ブロック154a〜154nのコアロジックは、一般に、ブロック102の残りとは異なるクロックドメインで動作する。一般に、タイミングレジスタセットのみが、ブロック156a〜156nの残りと同一のクロックドメインに属する。同期ロジックは、一般に、FBCが静止しているときに限り(例えば、未解決の動作がない)、レジスタが書き込まれるため、レジスタが静的なものとして扱われるので、これらのレジスタとFBCコアとの間に必要でない。
ブロック156a〜156nは、一般に、ダイのそれぞれに対するコマンドのスケジューリングを実行する。ブロック156a〜156nは、フラッシュレーンのそれぞれでのコマンドのシーケンシングを管理する。ブロック156a〜156nは、ダイをプログラムすると共に状態を監視するファームウェアを通じて制御と状態レジスタを提供する。ブロック156a〜156nのそれぞれは、コンテキスト管理及びダイ管理を含む。ブロック156a〜156nは、一般に、コンテキストの処理のための役割を担う。
ブロック158a〜158nのそれぞれは、データトラフィックを送り、ブロック154a〜154n、オプションの内部ECCエンコーダ/デコーダ、及びデータDMAインタフェースポート(DDIP)のそれぞれの1つの間においてデータフローのためのインタフェースのそれぞれのフロー制御を有効にする。一例では、内部ECCエンコーダ/デコーダは、ブロック158a〜158nの内部で実現される。また、ブロック158a〜158nのそれぞれは、単一のECCエンコーダ/デコーダモジュールを共有するように構成される。ブロック158a〜158nは、データDMAマネージャ(DDM)モジュール152のそれぞれとデータDMAインタフェースポート(DDIP)ブロック172a〜172n及び174a〜174nのそれぞれとの両方によって転送のそれぞれのためにプログラムされる。ブロック158a〜158nのそれぞれは、全二重動作モードで動作する独立したフラッシュ読み書きパスを含む。ブロック158a〜158nは、リージョンのそれぞれの内部の現在のdwordカウントと同様にデータ転送の間に現在のリージョンカウントを保持する。ブロック158a〜158nは、一般に、DDIP、ECCエンコーダ&デコーダ、及びFLCブロックの間のフロー制御変換を実行する。ブロック158a〜158nは、転送のそれぞれのために訂正可能なECCエラー和の動作を保持し、転送の終わりでブロック152に対する終値を送信する。ブロック158a〜158nは、ECCエンコーダ&デコーダのプログラムのために用いられるFMCレジスタを含む。レジスタは、ブロック150からのレジスタインタフェースを介してアクセスされる。ECCモジュールは、一般に、4Kバイト以上のデータの64ビット訂正ができる。しかしながら、他のレベルの訂正は、特定の実施の形態のその設計基準を満たすために実現される。一例では、デコーダゲートカウントは415Kゲートであり、エンコーダゲートカウントは75Kゲートである。
ブロック160は、一般に、ブロック156a〜156nからコンテキストのための要求を受け取り、システムバッファ(例えば、バッファコントローラを介してアクセスされたDRAM)から要求されたコンテキストを検索し、その後、ブロック156a〜156nにコンテキストを伝達するための役割を担う。訂正は、事実上、コンテキスト訂正アクセスポート(CRP)166に対する要求を介して実行される。コンテキストは、FMCの制御の基本ユニットである。コンテキストは、一般に、コマンドを実行するためのFLCによって、及びシステムバッファに又はそのシステムバッファから関連データ転送(DMA)を実行するためのFMCによって必要とされる全ての情報を含む。FLCは、完全に自主的に動く。従って、FLCは、ファームウェアによって構築されたコンテキストのリンクリストを含むシステムバッファへのバッファコントローラを介するアクセスのためのアービトレーションを必要とする。ブロック160は、一般に、ブロック166に対する要求の開始と同様にアービトレーションを提供する。その後、ブロック160は、FLCデスティネーションのそれぞれに検索されたコンテキストを率直に送る。ブロック162は、一般に、フリーポインタがファームウェアに使用可能な単一のポイントを提供するために、ブロック102のサブブロックとして実現される。
ブロック164は、一般に、完了したコンテキストが完了の後にファームウェアによって検査される単一のポイントを提供するために、ブロック102のサブブロックとして実現される。ブロック164は、一般に、複数のFLCソースの間でアービトレーションを実行する。FLCは、コンテキストポインタに関連するパス/フェイルECC状態を提供する。ブロック164は、コンテキストがフェッチされたならば、コンテキスト状態フィールドをアップデートし、その後、ファームウェアに対するコンテキストを送信する。ファームウェアが完了したコンテキストを読み取るためのより長い時間を要し、ブロック164の内部の内部メモリが満たされる場合には、ブロック164は、現在の報告されたコンテキストの後に待ち行列に入れられる完了したコンテキストを格納するためにバッファを用いる。
ブロック166〜174nは、一般に、ポートインタフェースを実現する。ポートインタフェースは、バッファコントローラによって通信するために用いられる。一例では、QBFIFOブロックは、ポートインタフェースの内部で実現される。以下のポートインタフェースもポートインタフェースの一部として実現される:コンテキスト訂正ポート(CRP)166、コンテキストアップデートポート(CUP)168、コンテキストポインタリストインタフェースポート(CPLIP)170(オプション)、データDMA読み取りインタフェースポート(DDRIP)172a〜172n、及びデータDMA書き込みインタフェースポート(DDWIP)174a〜174n。一例では、ブロック102のインタフェース信号は、4大インタフェースにグループ化される:AHBインタフェース、バッファコントローラインタフェース、NAND及び/又はNORフラッシュフィジカルレイヤ(PHY)インタフェース、及びミソレニアス(MISC)インタフェース。バッファコントローラインタフェースは、(i)レーン0&レーン1のためのDDIP BC書き込みインタフェース、(ii)レーン0&レーン1のためのDDIP BC読み取りインタフェース、(iii)CRP BC読み取りインタフェース、(iv)CUP BC書き込みインタフェース、及び(v)CPLIP BC読み取り/書き込みインタフェース。
一例では、ブロック102は、3つのクロックで実現される。ブロック102の大多数のロジックは、システムクロック(例えば、SYS_CLK)と呼ばれるクロックドメインで動作する。システムクロックは、AHBクロックである。システムクロックは、一般に、FMCプロセッサ(FARM)112の動作周波数の2分の1の周波数を有する。第2のクロックは、フラッシュクロック(例えば、FBC_CLK)と呼ばれる。フラッシュバスコントローラ(FBC)154a〜154nは、完全にフラッシュクロックドメインで動作する。一例では、先入れ先出しバッファ(FIFO)は、クロックFBC_CLKとSYS_CLKとの間の周波数を管理するために、ブロック154a〜154nのデータフローマネージャ(DM)モジュールで実現される。第3のクロックは、バッファコントローラクロック(例えばBC_CLK)である。BCを有する全てのインタフェースポートは、バッファコントローラクロックドメインで動作する。バッファリングエレメント(例えば、QBFIFO)は、バッファコントローラクロックBC_CLKとシステムクロックSYS_CLKとの間で実現される。
図3を参照すると、本発明の実施の形態によるフラッシュレーンコントローラアーキテクチャの一例を図示するブロック200の図が示される。ブロック200は、一例では、図2のブロック154a〜154n及び156a〜156nを実現するために用いられる。一例では、ブロック(又は回路)200は、ブロック(又は回路)202、ブロック(又は回路)204、ブロック(又は回路)206、ブロック(又は回路)208、ブロック(又は回路)210、ブロック(又は回路)212、及びブロック(又は回路)214を備える。回路202〜210は、ハードウェア、ファームウェア、ソフトウェア、ハードウェアの組み合わせ、ファームウェア、及び/又はソフトウェア、又は他の実装として実現されるモジュール及び/又はブロックを表わす。ブロック202は、一例では、コンテキスト処理コーディネータ(CPC)を実現する。ブロック204は、一例では、コンテキストマネージャ(CM)を実現する。ブロック206は、一例では、ダイ管理モジュール(DMM)を実現する。ブロック208は、一例では、フラッシュ動作マネージャ(FOM)を実現する。ブロック210は、一例では、プロセッサアクセスポート(PAP)を実現する。ブロック212は、一例では、フラッシュバスコントローラ(FBC)を実現する。ブロック214は、一例では、データフローマネージャ(DFM)を実現する。
ブロック202は、ブロック200に及びそのブロックからのコンテキスト情報のフローをアシストする。コンテキストフローは、ブロック204によって開始される。ブロック202は、コンテキストを取得するか解放するための要求に応えることに主として関する。コンテキストを取得するために、ブロック202は、ブロック204による新規のコンテキストのための要求に応える。最初に、ブロック202は、ブロック206に対する要求を開始する。ブロック200によって管理されたダイの間にアービトレートし、ブロック202に選択されたダイ又は論理装置番号(LUN)のためのコンテキストを転送する。その後、ブロック202は、システムバッファからコンテキストを検索することを試みるコンテキストフェッチアービタ(CFA)(例えば、図2のブロック160)に対するフェッチをもたらす。
フェッチされたならば、コンテキストは、ブロック202に伝達される。ブロック202は、コンテキストでいくらかの解釈を実行し、ブロック204にコンテキストを転送する。ブロック206がコンテキストの実行を開始するために使用可能なダイ(LUN)を有さないならば、ブロック206は、使用可能なダイの不足をブロック202に通知し、ブロック202は、ブロック204に使用可能なダイの不足への返答を通信する。ブロック202は、完了したコンテキストの解放においてもブロック200をアシストする。再び、このフローを開始するのはブロック204であり、消費コンテキストマネージャ(CCM)(例えば、図2のブロック164)を実現するブロックに対する解放メッセージをもたらすのはブロック202である。解放メッセージがCCMによって受信され動作が開始されたとき、ブロック202は、ブロック204に通知し、その後、ブロック204は、コンテキスト処理の実行を保持する。
ブロック202は、一般に、コンテキストのいくらかの解釈を実行する。具体的には、ブロック202は、コンテキストがプロセッサ制御モード(PCM)コンテキストか否かを判断する目的でコンテキストを解釈する。PCMコンテキストが受信されるとき、コンテキストフェッチ(追加)は停止するべきである。その後、ブロック202は、ブロック204がPCMコンテキストを実行し始めることを待ち、プロセッサ制御モードが完了するとき、「スタンダード」動作を再開する。プロセッサ制御モードインターバルの間に、ブロック202は、フェッチされたコンテキストが4つのdwordフラッシュコンテキストの代わりに完全な15のdwordコンテキストか否かを判断し、ブロック202は「スタンダード」動作のブロック204にそれらを送信する。
ブロック204は、一例では、コンテキスト状態マシン(CSM)、コンテキストフェッチマネージャ(CFM)、コンテキスト解放エンジン(CDE)、及びコンテキストインタープリタ(CI)を備える。ブロック204は、一般に、ブロック200によって活動的に処理されるコンテキストを管理する役割を担う。ブロック204は、一般に、アクティブなコンテキストの「ブックキーピング」を実行する。コンテキストは、システムバッファに対するフラッシュトランザクション及びDMAを実行するためにフラッシュメディアコントローラ(FMC)によって必要とされる全ての情報を提供するデータ構造である。ブロック204は、フラッシュレーンコントローラのレベルでコンテキストを管理し、従って、フラッシュトランザクションに関連するように、コンテキスト管理に主として関する。ブロック204は、フラッシュレーンのフラッシュダイに対するコマンド及びデータ転送を実行するために、ブロック208によって用いられる情報を保持する。
ブロック206は、一般に、ブロック200の動作のために必要とされるダイに基づいた情報を保持するための役割を担う。ブロック206は、ダイ管理テーブルのダイごとに情報を管理し、コンテキストテーブルへの待ち行列となるためのアクセスのためにダイの間にアービトレートする。ブロック206は、一例では、ダイ状態をアップデートするためにダイ状態マシンを含む。ブロック206は、マルチダイ動作を実行/モニタリングする。ブロック206は、一般に、READ、COPYBACK READ/COPYBACK WRITE、BLOCK ERASE、PAGE PROGRAMを含み、これらに限定されないフラッシュコマンド、及びREAD ID、READ PARAMETER PAGE、GET FEATURES、SET FEATURES、SYNCHRONOUS RESET、及びRESETを含み、これらに限定されないターゲットレベルコマンドのための役割を担う。
ブロック208は、一般に、フラッシュレーンに適用されたフラッシュ動作のそれぞれのシーケンシングをハンドリングする。1つのブロック208は、一般に、フラッシュメディアコントローラのフラッシュレーンコントローラ(FLC)のそれぞれのために実現される。ブロック208は、ブロック204のコンテキストテーブルのコマンドの間にアービトレートし、ブロック212にコマンドを適用する。一例では、ブロック208は、本来、三星NANDフラッシュデバイスにおいて知られたいくつかの特定の(かつ類似した)コマンドと同様にONFI2.0コマンドリストからの大部分の共通コマンドをサポートする。更に、他の既存の及び将来のコマンドは、ナノシーケンサ(図9〜11に関してより詳細に説明される)を介してサポートされる。本来、サポートされたコマンドは、プロセッサインターベンションなしに実行されるが、一般に他のコマンドはいくらかのレベルのプロセッササポートを用いる。
フラッシュコマンドは、ブロック208によって制御された実際のフラッシュダイに連続的に適用される原子の「サイクル」に分割される。典型的には、フラッシュコマンドが長いウェイト時間(例えば、データがチップから読み取られるために使用可能な前に、ページ読み取りは25μsを要する)を含んでいるので、「コマンドサイクル」は、しばしばフラッシュレーン上の異なるダイに「バックツーバック」実行され、従って、累積的なウェイト時間を効果的に削減できる。ブロック208は、一般に、フラッシュ「サイクル」のそれぞれが適用されるとき、ダイの状態をアップデートすることによってフラッシュダイを管理する。その後、ブロック208は、「サイクル」が次に実行されるべき(又はありうる)であるかを判断するべきための最新のコンテキストテーブルを読み取る。NANDフラッシュ動作は、一般に、1つ以上のフラッシュサイクルで構成される。4つのタイプのフラッシュサイクルが一般にある:コマンド、アドレス、データ出力(フラッシュデバイスについては、例えば、読み取り)、及びデータ入力(フラッシュデバイスについては、例えば、書き込み)。サイクルタイプは、大雑把に言ってブロック208とブロック212との間に定義された動作タイプに解釈する。
ブロック210は、一般に、ブロック200の内部のアドレス可能なリソースにFMC100のAHBライトスレーブインタフェースからのプロセッサアクセスを提供するインタフェースブロックを実現する。ここでアドレスされた大部分のリソースは、全てのコンフィギュレーション信号がグローバルレベル(共有コンフィギュレーションレジスタブロックの一部としての)で送信されるとき、主として診断目的のためのアクセス可能である。例えば、フラッシュレーンデータバッファに対する完全なアクセスは、ブロック210によって使用可能である。アクセスは単に迅速な検証の足がかりとして提供される。しかしながら、フラッシュレーンデータバッファに対するアクセスは、内部テーブルに対する直接アクセスを必要とするファームウェアパッチもサポートする。そのようなアクセスは、ブロック210によって提供される。
ブロック210の特徴は次のものを含む:AHBライトスレーブプロトコルに従い、FMCにおいてプロセッサインタフェースロジック(PIL)によってバッファされるシンプルアクセスインタフェース;リソース、コンテキストテーブル、コンテキストキャッシュ、及びダイ管理テーブルをレジストするために提供される読み取り書き込みアクセス;ブロック214に位置されるフラッシュレーンデータバッファメモリリソースに提供される読み取り書き込みアクセス。大部分のコンフィギュレーションレジスタは、一般に、ブロック200に入力として提供されるが、ブロック210は、一般に、レーンごとにコンフィギュレーションレジスタを追加するための能力をサポートする。同様に、大部分の状態及び割り込みレジスタは、一般に、ブロック200の外部に生成されるが、状態及び割り込みレジスタアクセスはサポートされる。ブロック210の主要なロジックグループは次のものを含む:インタフェースマネージャ(IF_MGR)、データフローマネージャインタフェース(DM_IF)、レジスタブロックデコーダ(REG_DEC)、レジスタブロックマルチプレクサ(REG_MUX)、割り込みハンドラ(INT_HND)、及びFLCグローバルレジスタ(GLOB_REGS)。
図4を参照すると、図3のコンテキストマネージャモジュール204のサブモジュールを図示する図が示される。一例では、ブロック204は、コンテキストテーブル(CT)220、コンテキスト状態マシン(CSM)222、コンテキストキャッシュ(CC)224、及びコンテキスト待ち行列コントローラ(CQC)226を含む。ブロック204は、一般に、フラッシュレーンコントローラに対する動作のフェーズをステージし実行し、フラッシュレーンで全てのアクティブなコンテキストのプライオリティオーダリングを保持し、フラッシュレーンでコンテキストのそれぞれの状態を保持し、完全なトランザクションを実行するために必要とされるコンテキストのテンポラリオンチップストレージの最低量を提供し(例えば、コンテキストキャッシュを介して)、実行が進行中のコンテキストのそれぞれのバッファポインタを保持し、及びコンテキスト状態マシン(CSM)222を用いてコンテキストの次の状態を決定することによって、コンテキストのそれぞれのためにエージェンシーを提供する。最小のコンテキスト情報は、コンテキストテーブル(CT)220に保持される。コンテキストテーブル220は、一般に、現在実行されているコンテキストの優先待ち行列を提供する。コンテキスト待ち行列コントローラ(CQC)226は、コンテキストテーブル220から完了したコンテキストを除去し、かつギャップを削減するためにコンテキストテーブル220を圧縮するように構成される。
図5を参照すると、図3のダイ管理モジュール206のサブモジュールを図示する図が示される。一例では、ブロック206は、ダイ状態マシン230、ダイサービスアービタ232、及びダイ管理テーブル234を備える。
図6を参照すると、図3のフラッシュ動作マネージャ(FOM)208のサブモジュールを図示する図が示される。一例では、ブロック208は、4つのサブモジュール、コマンドアービタ(CA)240、データ転送アービタ(DTA)242、フラッシュ動作フォーマッタ(FOF)244、及びナノシーケンサ246に分割される。コマンドアービタ240は、一般に、適用するためのコマンドのためにコンテキストテーブルをスキャンし、その後、フラッシュバッファコントローラ(FBC)に信号を送信するためにフラッシュ動作フォーマッタ(FOF)244によって通信する。全ての「コマンド」の部分が実行され、フラッシュが「データフェーズ」のための準備ができたならば、データ転送アービタ242は、FBCとデータフローマネージャ(DM)214との間の転送を開始する。最後に、ナノシーケンサ246は、本来、コマンドシーケンスがサポートされてなくても、フラッシュが必要とするあらゆるコマンドシーケンスを適用するために特別の「ソフトコンテキスト」を解釈する。
図7を参照すると、図3のデータフローマネージャ214のサブモジュールを図示する図が示される。データフローマネージャ214は、一般に、フラッシュレーンデータバッファメモリリソースを提供する。一例では、フラッシュレーンデータバッファメモリリソースは、カットスルーバッファ250及び252を備える。一例では、カットスルーバッファ250及び252は、プログラマブルなサイズで実現される。例えば、バッファ250及び252のサイズは、帯域幅仕様とマッチするように調節される。一例では、バッファ250及び252は、静的ランダムアクセスメモリ(SRAM)を備える。しかしながら、他のタイプのメモリは、特定の実施の形態のその設計基準を満たすために実現される。一般に、2つのカットスルーバッファは、フラッシュレーンごとに実現される。
図8を参照すると、図3のコンテキストマネージャ(CM)204の実施の形態の一例を図示する図が示される。コンテキストマネージャ(CM)204は、一般に、フラッシュレーンコントローラ(FLC)のそれぞれによってアクティブに処理されているコンテキストを管理する役割を担う。CM204は、一般に、アクティブなコンテキストの「ブックキーピング」を実行する。先に述べたように、コンテキストは、システムバッファに対するフラッシュトランザクション及びDMAを実行するためにフラッシュメディアコントローラ(FMC)102によって用いられる全ての情報を提供するデータ構造である。CM204は、FLCのレベルでコンテキストを管理し、従って、フラッシュトランザクションに関連するコンテキスト管理に主として関する。CM204は、フラッシュレーンのフラッシュダイに対するコマンド及びデータ転送を実行するためにフラッシュ動作マネージャ(FOM)によって用いられる情報を保持する。
CM204は、一般に、(i)フラッシュレーンコントローラのそれぞれに対する動作のフェーズをステージし実行し、するように構成される。(ii)フラッシュレーンのそれぞれで全てのアクティブなコンテキストのプライオリティオーダリングを保持し、(iii)フラッシュレーンのそれぞれでコンテキストのそれぞれの状態を保持し、(iv)完全なトランザクションを実行するために用いられるコンテキストのテンポラリオンチップストレージ(例えば、コンテキストキャッシュ224を介して)の最低量(又は最小限に抑えた量)を提供し、(v)実行が進行中のコンテキストのそれぞれのバッファポインタを保持し、(vi)コンテキスト状態マシン(CSM)222を用いてコンテキストの次の状態を決定することによって、コンテキストのそれぞれのためにエージェンシーを提供し、及び(vii)現在実行されているコンテキスト(例えば、コンテキストテーブル220)の優先待ち行列に最小のコンテキスト情報を保持する。コンテキスト待ち行列コントローラ226は、一般に、コンテキストテーブル220から完了したコンテキストを除去し、かつギャップを削減するためにコンテキストテーブル224を圧縮するように構成される。
コンテキスト待ち行列コントローラ(CQC)226は、コンテキストテーブル(CT)220で修正を実行するロジックブロックである。CT220は、一例では、待ち行列に入れられたコンテキストごとに1つのエントリに編成されるレジスタのブロックとして実現される。CQC226は、優先待ち行列として編成されるテーブルで動作を実行するブロックである。CQC226は、一般に、コンテキスト処理を開始し実行し、コンテキストテーブルの処理を実行する役割を担う。メイン処理は、一般に、追加、待機、修正、解放、及び圧縮の処理を含む。処理は、CQC226によってステージされ実行される。
追加フェーズは、新規のコンテキストがFMCによってフェッチされ、それらのコンテキストのためのエントリがコンテキストテーブル220に追加されるフェーズである。CQC226は、CPC202によって送信されたフラッシュコンテキスト及びコンテキスト情報の内容を検査し、内容とコンテキスト情報に基づいたエントリを追加し、作成する。一例では、コンテキストテーブルエントリは、コンテキストテーブルエントリがアクティブか否かを示すビット(又はフラグ)、コンテキスト状態を表わす値、コンテキストキャッシュインデックスを表わす値、フラッシュ動作を送信する値、フラッシュダイを表わす値、コンテキストポインタ、データ転送を無効にするべきか否かを示すビット(又はフラグ)、及びプレーンアドレスを表わす値を備える。新規なエントリは、一般に、「アクティブな」ビットセット(例えば、ロジック「1」)によって開始し、「コンテキスト状態」は値「QUEUED」に設定する。フラッシュ動作がイリーガルの場合、初期状態は値「ILLEGAL」に設定され、コンテキストテーブルエントリは解放フェーズの間に除去される。他のフィールドは、一般に、CQC226によって提供されるコンテキストと情報によって決定される。新規なエントリは、一般に、圧縮されたコンテキストテーブル220の末尾に追加される。従って、CQC226は、一般に、コンテキストテーブル220の深度を知っている。
CQC226は、一般に、CQC226がもはや未解決のデータ転送が完了するのを待っておらず、CQC226が与えられたフラッシュ動作サイクルの間に少なくとも1つ追加の動作を試みたとき、「追加」フェーズを完了する。CQC226は、コンテキストテーブル220又はコンテキストキャッシュ224に使用可能なスペースがもはやないときも、「追加」フェーズを完了する。
コンテキストマネージャ204は、完全なフラッシュ動作サイクルの間に待つことを強制されるか、又は強制されない。コンテキストマネージャ204は、一般に、最小のフラッシュ動作期間(例えば、フラッシュ動作期間レジスタを介して)を強制するための能力を有する。そのような最小の期間は、例えば、フラッシュレーンがPROGRAM又はERASEのコマンドの後にポーリングすることを除いて主として使用されていないケースのために望ましい。そのようなインスタンスでは、コンテキストフェーズは、追加又は解放がないとき、実行するべきための非常に短時間を要する。従って、レーンが連続的に使用中であるフラッシュダイをポーリングする状態においてレーンが存在するための傾向があり、その結果としてその消費電力が保証されないときフラッシュインタフェースで電力を消費する。CQC226は、一般に、所定時間が完了する(例えば、時間は「フラッシュ動作タイマー」レジスタにおいて指定される)まで存続する。所定時間が完了したとき、CQC226は「修正」フェーズに入る。
CQCによって開始される次のフェーズは、一般に、「修正」フェーズである。修正フェーズでは、コンテキストテーブル220は、フラッシュ動作マネージャ(FOM)によって及びデータパス転送からの結果によって実行されたフラッシュ動作に基づいて修正される。アップデートは、一般に、コンテキストの状態に関連し、従って、一般に、コンテキスト状態マシン(CSM)222によって開始される。状態アップデートが発生するとき、CSM222はCQC226に最新の状態及びコンテキストテーブルインデックスを送信する。その後、CQC226は、コンテキストテーブル220のエントリをアップデートする。FOMがフラッシュインタフェース処理のサイクルを終えるとき修正フェーズは終わる。FOMは、信号(例えば、FOM_CM_FLASH_PROC_CMPLT)のアサートによって、フラッシュインタフェース処理が終わったことをコンテキストマネージャ204に通知する。修正フェーズが完了したならば、CQC226は、解放、圧縮、及びコンテキストテーブル220のコンテキストの追加を実行する。この時間の間に、コンテキストテーブル220はFOMに対してアクセス不能である。CQC226は、コンテキストテーブルがエントリを読み取ったこと、及びコンテキストキャッシュに読み取られたデータが特定のクロックサイクルの間に有効であることをFOMに示す信号(例えば、CM_FOM_CT_VALID)をデアサートすることによってFOMに対してアクセス不能なコンテキストテーブル220を強制する。
修正フェーズが完了したとき、CPC202は「解放」アクションを開始する。解放アクションは、CQC226が実行を終えたエントリ有産者を捜すコンテキストテーブル220を探索するモードにCQC226を至らせる。CQC226は、エントリがコンテキストの状態の実行を終えたか否かの判断に基づく。コンテキストが「完了」状態であるとき、コンテキストはCQC226によって解放される。一例では、コンテキストは、CQC226がコンテキストの完了状態に関してデータパスからの通知を待つ状態である。例えば、読み取り動作の場合には、コンテキストはDATA_TRANSFER_DONE状態にあり、ECCチェックの結果を待つ。この場合には、CQC226は一時的に解放処理を停止し、状態がデータパスから復帰されるのを待つ。この時間の間に、CQC226は「追加」を許可する。しかしながら、待機状態が復帰されれば、コンテキストはCQC226によって解放され、消費されたコンテキストレコードはCPC202に(結局、消費コンテキストマネージャ(CCM)164に)転送される。
CQC226がコンテキストを解放したとき、CQC226はコンテキストテーブル220の通信エントリのための「アクティブ」ビットを除去する。CQC226がコンテキストテーブル220ごとにコンテキストを調査するまで、その処理は継続する。CQC226がコンテキストテーブル220のアクティブなコンテキストの終わりに到達するとき、解放フェーズは完了する。
CQC226によって解放されたコンテキストは除去されたテーブルエントリのそれぞれにおいて「アクティブ」ビットを有する。ホールを満たすまでテーブルをシフトするための機構なしに、アクティブなエントリはコンテキストテーブル220に支出される(又は細分化される)。支出されたコンテキストは、コンテキストテーブルをスキャンすることを困難にし、「追加」フェーズをより複雑にする。コンテキストテーブル220が優先待ち行列としてそのキャラクタを保持することを保証するために、コンテキストテーブル220は圧縮される。圧縮処理において、CQC226がコンテキストを解放するとき、CQC226は1つの位置によって解放されたエントリの後に直ちに全てのエントリをシフトする。処理が完了するとき、全てのアクティブなエントリはプライオリティオーダーのリストのフロントにあり、全ての「ホール」は除去される。他のアクションの場合であるとき、圧縮処理が完了されるとき、CQC226は「完了」セマフォ(又はビット)をアサートする。最終の圧縮フェーズの終わりで、CQC226は追加フェーズを開始する。
CQC226は、一般に、プロセッサ制御モードを知っている。プロセッサ制御モードでは、全てのCM204はスタンダード動作を停止し、フラッシュ動作マネージャ208の内部のナノシーケンサ246によって実行される「ソフトコンテキスト」によってFLCの動作が本質的に駆動されるモードで進行する。ソフトコンテキストは、スタンダードフラッシュコンテキストとは異なるサイズである。一例では、ソフトコンテキストは完全な15の32ビットダブルワードを備えるが、「フラッシュコンテキスト」、FLCによって実行された完全なメディアコンテキストの部分は、一般に、ちょうど4つの32ビットダブルワードを備える。
プロセッサ制御モード(PCM)は、一般に、「フラッシュ動作」フィールドがPROCESSOR_CONTROL_MODEに設定されるコンテキストがコンテキスト待ち行列のトップに現われるとき開始する。一般に、CQC226がPCMコンテキストを待ち行列に入れれば、CQC226がスタンダードコンテキストの訂正を停止するとき、コンテキストテーブル220にPCMコンテキストの後ろにアクティブなエントリはない。PCMが開始するとき、CQC226は信号(例えば、CM_CPC_PROC_CNTL_MODE)を介してCPC202に通知する。通知に応じて、CPC202は、PCMコンテキストに与えられた位置で見つけられた「ソフトコンテキスト」をフェッチする。FOMに送信されるものの観点から、PCMコンテキストがコンテキストテーブル220の他のアクティブなエントリの後ろにある間に、FOMは、一般に、コンテキストテーブル220のPCMコンテキストの存在についての情報を有さない。CM204がソフトコンテキストを実行し始めるFOMのための準備ができるまで、コンテキストテーブル220のPCMコンテキストエントリは、FOMに「アクティブ」ビットを0として送信する。
FOMがソフトコンテキストを読み取り始めるとき、ソフトコンテキストが格納されるコンテキストキャッシュ224によって動作がFOM208に送信されるとき、CQC226は動作をスヌープする。動作がDMAコンテキスト(例えば、プリフェッチデータ、セット読み取りデータバッファ、又はコンテキストポインタの解放)を含んでいるとき、CQC226は、コンテキストテーブル220の現在未使用のストレージを選出し、トラッキングのためのコンテキストテーブルにポインタを配置する。それらのDMAコンテキストが完了するとき、FOM208はコンテキストマネージャ204に通知し、その後、コンテキストマネージャ204は通常の方法でコンテキストを解放する。
スヌープしている間に、CQC226は、「ネクストソフトコンテキストのフェッチ」動作を捜す。CQC226がそれを見つけるとき、CQC226はCPC202に信号(例えば、CM_CQC_PCM_NEXT_CONTEXT)をアサートし、CPC202はネクストソフトコンテキストをフェッチする。FOM208がソフトコンテキスト実行が完了したことをCM204に通知するとき、FOM208はFOM/CMコマンドインタフェースでCM204に通知する。その後、CQC226は、CPCに信号(例えば、CM_CPC_PROC_CNTL_MODE)をデアサートし、スタンダード動作は継続する。一例では、CM204がプロセッサ制御モードに入っており、現在ソフトコンテキストを受信するための準備ができていること示すためのレベルとして信号CM_CPC_PROC_CNTL_MODEがアサートされる。
CQC226の別の重要な機能は、タイムアウト状況をモニタすることにある。一例では、CQC226は、同一のコンテキストテーブルエントリがコンテキストテーブル220のトップ(例えばエントリ0で)に属するシステムクロック(SYS_CLK)サイクルの数を数えるように構成されたカウンタを含む。カウント値がプログラマブルな「タイムアウト」カウンタの値に到達する場合、コンテキストテーブル220のトップのエントリはタイムアウトを有すると見なされる。エントリがタイムアウトを有すると見なされるとき、エントリは、コンテキストテーブル220から除去され、コンテキストポインタは、消費コンテキストインタフェースのコンテキスト処理コーディネータ(CPC)202にリターンされる。
コンテキストのためのリターン状態は2つの起こり得る「タイムアウト」状態の1つである。第1のケースでは、タイムアウトは、可能性としてフラッシュレーンの別のダイが使用中で、R/Bラインを押し下げている状況である。この場合には、状態は、タイムアウトが別のダイのタイムアウトであることを示す。第2のケースでは、コンテキストのためのダイはカルプリットであると認識される。ここで、異なる状態はダイがカルプリットであることを示してリターンされる。
コンテキストテーブル220は、本質的にエントリの記憶媒体である。コンテキストテーブルの深度は、パラメータ化することができる。例えば、レーンごとに16ダイをサポートすることができるチップの場合には、16のエントリが実現される。1つを超える動作が1つのダイごとに管理されるならば、深度を増加させることは有利である。コンテキストテーブル220は、最小の機能を有する。大部分のより複雑な処理は、コンテキストテーブル220でCQC226によって実行される。しかしながら、コンテキストテーブル220は、複数の読み取りインタフェース、及び読み取りインタフェースのそれぞれのための多重化ロジックで実現される。一例では、コンテキストテーブル220は、FOM208に対するインタフェース、及び読み取りアクセシビリティのためのコンテキスト状態マシン(CSM)222に対するインタフェースによって実現される。コンテキストテーブル220は、CQC226に対する読み取りインタフェースも有する。コンテキストテーブル220は、プロセッサによってもアクセスされる。
コンテキストテーブル220は、同様にテーブルの圧縮フェーズのために用いられる「シフト」性能を有する。それに加えて、CQC226はシンプルな書き込みインタフェースを用いてコンテキストテーブル220をアップデートする。一例では、コンテキストテーブル220は、フリップフロップで実現される。コンテキストテーブル220がフリップフロップで実現されるとき、読み取りアクセスのために必要なアービトレーションはない。コンテキストテーブル220が約1000を超えるフリップフロップのサイズに増加する場合、コンテキストテーブル220はレジスタファイル又はSRAMで実現されるが、追加の管理及びアクセスのアービトレーションも実現される。
コンテキストキャッシュ224は、コンテキストテーブル220に類似する別のコンテキストデータストレージエレメントである。コンテキストキャッシュ224は、一般に、エントリのパラメータ化することができる数を含む。一例では、エントリの数は8である。しかしながら、エントリの他の数は、特定の実施の形態のその設計基準を満たすために実現される。例えば、完全なパイプライン動作のために事実上必要とされるよりエントリの数は1つ又は2つ以上に設定される。数は、一般に、プロセッサ制御モードの完全な「ソフトコンテキスト」のための十分なスペースを許可するために十分に大きくされる。先に述べたように、完全なコンテキストは15の32ビットダブルワードを備える。完全なメディアコンテキストのサブセットは「フラッシュコンテキスト」と指称される。フラッシュコンテキストは、一般に、完全なメディアコンテキストの第1の4つのダブルワード(又はdwords)である。フラッシュコンテキストの4つのdwordsは、一般に、ファームウェアによって指定された完全な動作を実行するためにFLCによって用いられる全ての情報を含む。スタンダード動作(例えば、FLCがプロセッサ制御モードにないとき)の間に、フラッシュコンテキストの第1の2つのdwordsのみがコンテキストキャッシュ224に格納される。フラッシュコンテキストの残りは、一般に、コンテキストテーブル220に格納される。
コンテキストキャッシュ224は、一般に、エントリのそれぞれの状態を保持する。一例では、状態は、エントリがFREE又はUSEDか否かを示すビットを備える。一例では、そのような8ビットは、コンテキストキャッシュ224で実現される。フラッシュコンテキストがコンテキストキャッシュ224で位置に書き込まれるとき、位置の状態はUSEDになる。CQC226がその位置をクリアすることを許可する状態変更についての情報を取得するとき、位置の状態はFREEにリターンする。スタンダード動作の間に、コンテキストキャッシュ224は、コンテキストキャッシュ224が状態ビットに基づいてフリーエントリのためのスペースを有することをCQC226に通知する。フリーロケーションがあるならば、CQC226は自由にCPC202からコンテキストを要求することができる。CPC202が新規のフラッシュコンテキストをフェッチしたとき、CPC202はデータの32ビットダブルワードのバーストとしてコンテキストキャッシュ224にフラッシュコンテキストを送信する。データが有効なとき、信号(例えば、CPC_CM_ENQ_CTX_VALID)がアサートされる。コンテキストキャッシュ224は、フリーロケーションにデータを書き込む。コンテキストキャッシュ224は、CPC202が単に1つのフラッシュコンテキストを書き込むだろうと予期する。
コンテキストテーブル220のトップのエントリがPROCESSOR_CONTROL_MODE動作として示されるときに入るプロセッサ制御モードでは、コンテキストキャッシュ224は完全に自由である。プロセッサ制御モードでは、コンテキストキャッシュ224は、CPC202からソフトコンテキストを受信することを予期する。コンテキストキャッシュ224は、ソフトコンテキストが15のdwordsを含むことも予期する。本質的に、コンテキストキャッシュ224は、CPC202によって送信された全てのデータを受け取って、スレーブとして行動する。コンテキストキャッシュ224にデータの適正量を書き込むことはCPC202の責務である。コンテキストキャッシュ224は、FOM208によってアクセス可能であり、フラッシュユニットで実コマンドを実行するとき、完全なフラッシュコンテキスト情報を用いる。FOM208は、32ビットダブルワードにアドレスを提供し、コンテキストキャッシュ224は、以下のクロックサイクルで要求されたダブルワードによって応答する。プロセッサ制御モードの間に、コンテキストキャッシュ224からの読み取られた応答は、動作の内容に基づいたアクションを実行するコンテキスト待ち行列コントローラ(CQC)226によってスヌープされる。コンテキストキャッシュ224は、コンテキストテーブル220であるときも、プロセッサインタフェースによってアクセス可能である。
コンテキスト状態マシン(CSM)222は、一般に、エントリの現在状態に基づいてコンテキストテーブル220のコンテキストのそれぞれの実行状態、及びFOM208によって実行されている動作又はデータパス動作の状態のいずれかを決定するように構成される。修正フェーズでは、CSM222は、FOM208がコマンドを適用するか、結果をリターンするごとにCQC226によって呼び出される。FOMコマンド通知インタフェース及びFOMコンテキストテーブル読み取りインタフェースの内容は、一般に、次の状態を決定するためにCSM222のために必要とされる全ての情報を提供する。
解放フェーズでは、CQC226がコンテキストテーブル220をスキャンし、コンテキストテーブルエントリがアクション(例えば、TRANSFER_DATA状態又はPREFETCH_DATA状態)を待っている状態であるコンテキストテーブルエントリにエンカウントするとき、CSM222はCQC226によって呼び出される。TRANSFER_DATA状態又はPREFETCH_DATA状態にエンカウントするとき、CQC226はデータ転送の状態に関するデータパスからの情報(例えば、DM、DDM、又はDTPのいずれか)を待つ。どちらにしても、CSM222は、一般に、懸案のコンテキストテーブルエントリのための次の状態を決定するために呼び出される。CSM222は、コンテキストテーブルエントリが完了状態(例えば、COMPLETED又はCOMPLETED WITH ERROR)に移行するときに、ダイ管理モジュール206に通知するための役割も担う。
図9を参照すると、図6のフラッシュ動作マネージャ(FOM)208の実施の形態の一例を図示するブロック図が示される。一例では、ブロック208は、5つのサブモジュールにより実現される。例えば、ブロック208は、ブロック(又は回路)240、ブロック(又は回路)242、ブロック(又は回路)244、ブロック(又は回路)246、及びブロック(又は回路)248を備える。回路240から248は、ハードウェア、ファームウェア、ソフトウェア、ハードウェアの組み合わせ、ファームウェア及び/又はソフトウェア、又は他のインプリメンテーションとして実現されるモジュール及び/又はブロックを表わす。ブロック240は、一例では、コマンドアービタ(CA)を実現する。ブロック242は、一例では、データ転送アービタ(DTA)を実現する。ブロック244は、一例では、フラッシュ動作フォーマッタ(FOF)を実現する。ブロック246は、一例では、ナノシーケンサを実現する。ブロック248は、一例では、制御状態マシン(FOMCSM)を実現する。
データ転送アービタ242は、一般に、データフローマネージャ214にフラッシュ動作マネージャ208を接続する。フラッシュ動作フォーマッタ244は、一般に、フラッシュバスコントローラ212にフラッシュ動作マネージャ208を連結する。制御状態マシン248は、一般に、コンテキストマネージャ204にフラッシュ動作マネージャ208を連結する。コマンドアービタ240は、一般に、フラッシュ動作フォーマッタ(FOM)244と制御状態マシン248との間に接続される。データ転送アービタ242は、一般に、フラッシュ動作フォーマッタ244と制御状態マシン248との間に連結される。ナノシーケンサ246は、一般に、フラッシュ動作フォーマッタ244と制御状態マシン248との間に連結される。コマンドアービタ240は、一般に、適用するためのコマンドのためのコンテキストマネージャのコンテキストテーブルをスキャンし、その後、フラッシュバスコントローラ(FBC)212に信号を送信するためにフラッシュ動作フォーマッタ(FOF)244と通信する。
図10を参照すると、本発明の実施の形態によるフラッシュメディアコンテキストレイアウト300の一例を図示する図が示される。フラッシュトランザクションのそれぞれは、一般に、コンテキストによって表わされる。コンテキストは、フラッシュバンクを有するトランザクションを実行するためにシステムハードウェアによって用いられる全ての情報を含み、及び/又はシステムバッファの位置に又はその位置からデータを移動させるデータ構造である。コンテキストは、一般に、ファームウェアによって構成され、コンテキストの内容が事実上位置付けられる場所にバッファコントローラ(BC)へのポインタとしてフラッシュレーンコントローラ(FLC)に送信される。ファームウェアは、フラッシュ動作のより大きなハードウェア自動化を許可するためにこれらのコンテキスト(例えば、コンテキストリスト)のリンクリストを構成することを決定する。一般に、管理されたフラッシュユニット(例えば、ダイ、LUN等)ごとに1つのコンテキストリストがある。
一般に、通常動作の間に、完全なコンテキストの部分のみがフラッシュトランザクションを実行するためにFLCによって用いられる。従って、FLCによって用いられる部分のみが、FLCのコンテキストキャッシュに格納される。通常動作の間にFLCのコンテキストキャッシュに格納される完全なコンテキストの部分は、一般に「フラッシュコンテキスト」と指称される。フラッシュメディアコンテキストレイアウト300から観察することができるとき、フラッシュコンテキストは、一例では、完全な15のダブルワードコンテキストの第1の4つのダブルワードのみを備える。
一例では、本発明の実施の形態によって実現されたコンテキストは、以下の内容及び/又はフィールドを備える:フラッシュ動作フィールド(フラッシュローアドレスフィールド)、チャンク記述ポインタ/コピーバックローアドレスフィールド、コンフィギュレーションビットフィールド、ネクストコンテキストポインタフィールド、DMAスキップマスクフィールド、データバッファポインタフィールド、オルタネートデータバッファポインタフィールド、ロジカルブロックアドレス(LBA)フィールド、状態フィールド、フラッシュユニット数(FUN)フィールド、メタデータ又はコンフィギュレーションデータポインタのいずれかを含むフィールド、メタデータ、及び/又はフラッシュコンフィギュレーションデータ、メタデータ又はフラッシュコンフィギュレーションデータのいずれかを含むフィールド、64ビットLBAモードが用いられる場合にメタデータ又はロジカルブロックアドレス(LBA)の上部のいずれかを含むフィールド、及びコンテキストのために誤り訂正符号化(ECC)を含むフィールド。フラッシュ動作フィールドは、動作コードを備える。一例では、動作コードは8ビットを備える。ハードウェアに実行するための動作を通信するために、動作コードはファームウェアによって生成される。一般に、動作は、フラッシュアレイに少なくとも1つのアクセスを含む。ファームウェアに使用可能な基本動作コードは、例えば、RESET、SYNCHRONOUS_RESET、READ_ID、READ_PARAMETER_PAGE、GET_FEATURES、SET_FEATURES、READ_PAGE、PROGRAM_PAGE、ERASE_BLOCK、COPYBACK_READ/PROGRAM、READ_STATUS、READ_STATUS_ENHANCED、PROCESSOR_CONTROL_MODE、MULTIPLANE PROGRAM PAGE、及びMULTIPLANE PROGRAM ENDを含む動作を表わす値を備える。
フラッシュローアドレスフィールドは、フラッシュメモリにアクセスのページのローアドレスを含む。一例では、フラッシュローアドレスフィールドは、ページアドレスと連結されたブロックアドレスを含む。フラッシュローアドレスは、動作の3つの(3)ローアドレスサイクルの間にフラッシュアレイに送信される。消去動作のために、フラッシュメモリのアクセスのブロックアドレスのみが送信される。ちょうど1バイトのアドレスを用いるREAD_ID動作のために、バイトは、一例では、フラッシュローアドレスの左端のバイト(MSB)に配置される。フラッシュ動作がPROCESSOR_CONTROL_MODEであるとき、フラッシュローアドレスフィールドもソフトコンテキストポインタとして用いられる。プロセッサ制御モード動作に遭遇するとき、FLCはソフトコンテキストのシステムバッファアドレスとしてフラッシュローアドレスフィールドの値を用いる。
DMAスキップマスクフィールドは、システムバッファに又はそのシステムバッファからデータを移動させるとき、ビットの状態(例えば、「1」又は「0」)に基づいて、ページのセクタ(リージョン)が転送又はスキップされることを許可するビットを含む。一例では、DMAスキップマスクフィールドは、アクティブロースキップマスク又はフォワードマスク(例えば、転送を示す「1」、及びページのそれぞれのスキップを示す「0」)として実現される。DMAスキップマスクフィールドは、少数のセクタのトランザクションのために共通の読み取り/修正/書き込み(RMW)動作のために主としてoを用いる。例えば、8Kページデバイスでは、ページは、通常、16の(16)セクタに分割される。DMAスキップマスクフィールドの特定のビットが1であるとき、対応するセクタは、一例では、システムバッファに書き込まれるか、又はシステムバッファから読み取られる。ビットが0であるとき、対応するセクタは、システムバッファへの書き込み又はシステムバッファからの読み取りが省略される。一例では、データが2つの個別のソースから書き込まれることを許可するモードもある:未変更のページデータを含むバッファチャンク、及び最新のページデータを含むバッファチャンク。それらの場合のために、1つの状態(例えば、「0」)はセクタが最新のページデータ含むチャンクから書き込まれることを示すために用いられ、別の状態(例えば、「1」)は、セクタが未変更のページデータ含むチャンクから書き込まれることを示すために用いられる。ビット位置も重要である。例えば、左端のビット(MSB)は、一般に、最初、又はページにおける最小の番号のセクタに対応するビットである。右端のビット(LSB)は、一般に、ページにおける最大の番号のセクタに対応するビットである。ページで16未満のリージョンがある場合、構わず右端のビットが処理される。しかしながら、他の配置は特定の実施の形態のその設計基準を満たすために実現される。一例では、ボーズチャウドゥーリーホッケンガム(BCH)誤り訂正コード(ECC)が実現されるとき、マスクの細分性は1つの(1)情報ワードである。
ネクストコンテキストポインタフィールドは、ファームウェアによって構築されたコンテキストリスト(例えば、コンテキストのリンクリスト)のネクストコンテキストへのポインタを備える。「ネクストコンテキストポインタ」がFLCにファームウェアによってプログラムされる「リストポインタの終わり」と等しい場合、ハードウェアは探索の終わりに達したと仮定する。ハードウェアは、「リストポインタの終わり」値がリンクリストを横断し続ける前に変化するのを待つ。ハードウェアによるリスト探索を同様に停止する「ヌルポインタ」値も定義される。
一例では、チャンク記述子ポインタ/コピーバックローアドレスフィールドは、一般に、コピーバックコマンドのために書き込まれるためにキャッシュされたデータのために、フラッシュメモリのページのローアドレスを提供する。ローアドレスは、ブロックアドレスとページアドレスの連結である。別の一例では、コピーバックフラッシュローアドレスフィールドは、非コピーバックコンテキストのための未使用のフィールドと共有される。例えば、チャンク記述子ポインタ/コピーバックローアドレスフィールドは、バッファ割付けマネージャ(BAM)アシストフィールドを提供するために用いられる。BAMアシストフィールドは、バッファ割付けマネージャ(BAM)によって管理されたデータバッファの内部のデータチャンクのための記述子に対するポインタを備える。
チャンク記述子フィールドは、キャッシュ管理のために用いられる。チャンク記述子は、チャンクアドレス(例えば、システムバッファの)、有効ビット、ダーティビット、転送未解決カウント、状態、LBA、及びバッファ管理に用いられるポインタを含む。DMAが完了した後、チャンク記述子ポインタは、一般に、フラッシュメディアコントローラ(FMC)のDMAマネージャによってBAMに送信される。チャンク記述子ポインタは、フラグ(例えば、BAMルックアップ要求ビット)が設定された場合、DMAを開始するため、バッファデータポインタを取得するためにBAMに送信される。チャンク記述子ポインタ/BAMアシストフィールドは、一般的なBAMアシストフィールドとしてファームウェアによってセットアップされ、コンテンツは、BAMシーケンサのスペシフィックプログラミングに依存するファームウェアによって決定される。一般に、チャンク記述子ポインタ/BAMアシストフィールドは、ハードウェアに完全にトランスペアレントである。
データバッファポインタフィールドは、一般に、フラッシュメディアからバッファコントローラに/バッファコントローラからフラッシュメディアに送信される実データにポインタを提供する。データバッファポインタフィールドは、コンテキストが最初にフェッチされるとき、コンテキストに送信するか、又はBAMルックアップ要求ビットが設定される場合にBAMルックアップによるBAMによってデータバッファポインタフィールドは満たされる。データバッファポインタフィールドは、一般に、チャンクの第1のバイトのアドレス、必ずではなくチャンクの第1の有効なLBAを提供する。
オルタネートデータバッファポインタフィールドは、フラッシュメディアからバッファコントローラに/バッファコントローラからフラッシュメディアに送信されるデータに対するポインタである。オルタネートデータバッファポインタフィールドは、動作がバッファから又はそのバッファに複数のリソース又はデスティネーションを用いるとき用いられる。オルタネートデータバッファポインタは、読み取り/修正/書き込み(RMW)動作のために主に用いられる。ホストがフルページよりも小さい動作を実行するとき、ホストは、ページをアップデートするためにRMW動作を終える。オルタネートデータバッファポインタは、読み取り動作がテンポラリチャンクで古いページデータを格納するために用いられる。その後、書き込み動作が実行されるとき、スキップマスクは未変更のページデータを含むメディアチャンク又はアップデートするためのデータを含むホストチャンクのいずれかからセクタ(又はリージョン)の書き込みソースを選ぶために用いられる。
メタデータフィールドは、一般に、フラッシュページに関連するメタデータ(例えば、LBA等の管理情報、順序番号付、不良ブロックインジケータ等)を備える。全てのメタデータがコンテキストの内部で適合するであろうことが一般に期待される。そうでなければ、メタデータバッファポインタは、メタデータがシステムバッファに格納されるか、システムバッファから検索されるように、メタデータ自体の場所のコンテキストに含まれる。書き込みのために、メタデータフィールドは、一般に、ファームウェアによって占められ、ページへのハードウェアによって挿入される。読み取りには、読み取りページからファームウェアがメタデータの内容を要求することが大抵の場合望ましい。これらの場合のために、コンテキストは、コンテキストにページからメタデータを読み込むように構成される。一例では、メタデータのバイトのサイズは、メタデータサイズレジスタによって決定される。
フラッシュコンフィギュレーションデータフィールドは、一般に、メタデータフィールドとバイト位置を共有し、一般に、限定されたバイト数が転送される(例えば、READ_ID、GET_FEATURES、SET_FEATURES、READ_STATUS等)動作のために用いられる。そのような転送に関連するバイト数は一般に小さいので(例えば、SET_FEATURESとGET_FEATURESは4バイトを用いる;READ IDは一般に5バイトを用いる;READ_STATUSはわずか1バイトを用いる)、データは別々のバッファ位置にコンテキストに単に転送される。そのような転送に関連するデータがコンテキストに割り当てられたスペースより大きくなる場合、フラッシュコンフィギュレーションデータポインタフィールドが用いられる。GET_FEATURESとSET_FEATURESコマンドは、常に4バイトを用いることが想定される。READ_IDコマンドのために必要とされるバイト数は、一例では、READ IDコマンドレジスタのための複数の読み取りバイトから取得される。フラッシュコンフィギュレーションデータフィールドがコンフィギュレーションデータのために用いられるとき、7つのダブルワードの全てはハードウェアによってアップデートされ、ファームウェアは単に適切なバイトを読み取る必要がある。
メタデータバッファポインタフィールドは、ページメタデータ(例えば、フラッシュページのユーザデータに含まれる管理データ)の位置のアドレスを備える。メタデータバッファポインタフィールドは、全てのメタデータがコンテキスト自体に格納されることが予想されるとき、多くのアプリケーションのために省略される。メタデータバッファポインタフィールドは、メタデータが外部システムバッファから検索されるとき用いられる。メタデータバッファポインタフィールドは、一般に、メタデータがコンテキストにではなく外部に格納される場合にのみ用いられる。一例では、コンフィギュレーションビットは、メタデータが外部に又はコンテキストの内部に格納されるか否かを指定するように実現される。一例では、外部システムバッファは、フラッシュメディアコントローラ(FMC)を含むチップの外側にあるメモリ(例えば、DDR RAM)として実現される。別の一例では、外部システムバッファは、FMC IPの外側にあるオンチップRAMとして実現される。なお別の一例では、外部システムバッファは、FMC IPであるメモリを備える。一般に、外部システムバッファは、コンテキストの外側にあるあらゆるストレージである。
フラッシュコンフィギュレーションデータポインタフィールドは、一般に、取得されるか又はフラッシュユニットに書き込まれる必要があるコンフィギュレーションデータの位置のアドレスを提供する。READ_ID、GET_FEATURES、及びSET_FEATURESコマンドに関連するフラッシュコンフィギュレーションデータは、メタデータがデータトランザクションのためにコンテキストフィールドに割り当てられるとき、コンテキスト自体に格納される。しかしながら、メタデータの場合のように、データサイズがコンテキストのフラッシュコンフィギュレーションデータのために割り当てられたスペースより大きくなる場合、システムバッファのデータにポインタはアクセスのために用いられる。
ロジカルブロックアドレス(LBA)フィールドは、一般に、ページにおける第1のデータリージョンのLBAを提供する。LBAは、一般に、システムバッファとフラッシュのセクタのそれぞれのためのデータ保護に符号化される。ページがLBAの隣接するグループであるので、グループの第1のLBAのみがコンテキストの一部として用いられる。LBAは、セクタページのためのバッファCRCをシードするために用いられる。LBAは、またメタデータのLBA部分に対して選択的にチェックされる。例えば、コンフィギュレーションビットは、メタデータのLBA部分に対してLBAをチェックするべきか否かを選択するために実現される。例えば、LBAは、コンフィギュレーションビットが設定されるとき、メタデータのLBA部分に対してチェックされる。一例では、下位32ビットのみがシーディングのために用いられる。
フラッシュユニットナンバー(FUN)フィールドは、コンテキストが適用されるフラッシュユニットを決定するために、識別子としてファームウェアによって用いられる。決定はハードウェアにトランスペアレントである。フラッシュユニットナンバーフィールドは、コンテキストがハードウェアによって消費された後、識別子がファームウェアに送信されれば、ファームウェアがコンテキストを一致させるように、専らファームウェアによって管理目的のために用いられる。
コンフィギュレーションビットフィールドは、一般に、コンテキストを構成し、ハードウェアフローの様々なポイントでコンテキスト(及びコンテキストが表わす転送)のディスポジションを決定するために用いられる全てのビットを含む。一例では、コンテキストのコンフィギュレーションビットフィールドで使用可能なコンテキストビット及びフィールドは、限定されるものではないが、以下のものを含む:消費コンテキストマネージャ割り込みイネーブル;フラッシュインタフェースで部分的なコマンドを用いて、DMAスキップマスクフィーチャの実行を有効/無効にする部分的なコマンドのイネーブルビット;システムバッファへのDMAディスエーブル;FLCローカルバッファに又はそのバッファからの全てのデータ転送ディスエーブル;スクランブラ機能を有効/無効にするスクランブラ機能イネーブル;ECCエラー検出割り込みイネーブル;読み取りデータの復号化を有効/無効にするか、又は書き込みデータにパリティを追加するECCマクロバイパス;バッファCRCイネーブル;システムデータバッファ、読み取り上のシステムバッファ又はコンテキストにメタデータを転送せず、書き込み上の全てのソースからのメタデータの挿入を防ぐ(例えば、メタデータフィールドブランクを残す)イグノアメタデータ信号(ビット);DMA(例えば、読み取り上のデータバッファにメタデータを転送し、書き込み上のデータバッファからメタデータを受け取る)のためにユーザデータを有するメタデータを保持するための信号(ビット);メタデータの「起動LBA」フィールドがコンテキストの始まるLBAフィールドに対してチェックされるか否かを示す信号(ビット);バッファにECCパリティフィールドを保持するか否か(例えば、読み取り上のシステムバッファへのECCパリティバイトの転送、及び書き込み上のシステムバッファからのフラッシュへのECCの転送)を示す信号(ビット);管理されたデータバッファ(例えば、どれだけのデータがクワンタムバーストのシステムバッファに転送されるかを判断するために用いられる)の代わりに平面バッファ(例えば、メモリの管理されていないエリアに/からデータを転送する)を用いるか否かを示す信号(ビット);セクタデータ長(例えば、ビットがクリアな場合に、セクタデータ長は予約エリアセクタ長コンフィギュレーションから決定される)を決定するためにユーザデータセクタ長コンフィギュレーションを用いるか否かを示す信号(ビット);フラッシュコンフィギュレーションデータを転送する(例えば、コンテキストにフラッシュデータを読み取り、又はコンテキストからのフラッシュデータを書き込む)か否かを示す信号(ビット);システムバッファに又はそのシステムバッファから完全な生のフラッシュページを転送するか否かを示す信号(ビット);オルタネートバッファ(例えば、セクタの転送を省略する代わりにオルタネートデータバッファポインタによってポイントされたバッファチャンクに/から転送されるマークセクタ(リージョン)に用いられるスキップマスクをもたらす)を有するスキップマスクを用いるか否かを示す信号(ビット);スクランブラが有効になるときにリージョンのそれぞれのためのスクランブラシードを定義するフィールド。システムバッファに又はそのシステムバッファから完全な生のフラッシュページを転送するか否かを示す信号は、その性質によって大部分の他のオプションと相互排除である。システムバッファに又はそのシステムバッファから完全な生のフラッシュページを転送するか否かを示す信号は、一般に、他のビットセッティングを無視する。システムバッファに又はそのシステムバッファから完全な生のフラッシュページを転送する特徴は、一般に、ファームウェアがページの如何なるリージョンにも属さない未使用エリアを取得することを許可する。転送フラッシュコンフィギュレーションデータ信号は、READ ID、GET FEATURES、及びSET FEATUREのような動作のようなコマンドのために用いられる。データのサイズは、コンフィギュレーションデータ長レジスタによって決定される。データは、メタデータによって通常占められるコンテキストの位置に現われる。
状態フィールドは、一般に、ファームウェアへの現状状態に用いるビットを備える。一例では、状態フィールドは、プログラム/消去動作のためにパス/フェイル状態を含む。別の一例では、状態フィールドは、読み取り動作のECCロジックによって検出されたエラー回数も含む。しかしながら、フィールドの他の用途は、特定の実施の形態のその設計基準を満たすために実現される。一例では、状態フィールドは、フラッシュページにおけるエラー回数及びコンテキストマネージャのための完了コード(例えば、クリーン、プログラム/消去エラー、訂正された読み取りエラー、訂正できない読み取りエラー、システムバッファからのプリフェッチのバッファCRCエラー、動作タイムアウト、LBA/メタデータミスマッチ、違法動作等)を示すように構成される。
先に述べたように、コンテキストは、コマンドの実行を決定するデータ構造である。コンテキストは、ファームウェアとハードウェアとの間の通信のユニットである。一般的なコンテキストフローは、図2及び3に関連して、以下の通り概説される。ファームウェアは、メモリポインタに加えてFMC102のプロセッサインタフェースロジック(PIL)150のコンテキスト構造バッファ(CCB)にコンテキストを書き込む。複数のコンテキストは、コンテキスト構造の内部のネクストポインタフィールドを用いることによってコンテキストリストのファームウェアによってリンクされる。ハードウェアは、コンテキストアップデートポート(CUP)168によってメモリポインタに関連する位置にコンテキストのメモリ書き込みを実行する。ファームウェアは、例えば、フラッシュレーンコントローラ(FLC)156a〜156nのそれぞれのダイ管理モジュール(DMM)206におけるダイ管理レジスタによる特定のダイの実行を有効にする。ダイ管理レジスタの別々のセットは、ダイのために存在する。DMM206は、フラッシュレーンコントローラ(FLC)156a〜156nのそれぞれのコンテキストマネージャ(CM)204にレジスタの情報を通信する。その後、CM204は、コンテキスト訂正ポート(CRP)166、及びフラッシュレーンバスのそれぞれでコマンドの実行のためのスケジュールを通じて処理するためにメモリから有効にされたコンテキストをフェッチする。CM204は、一般に、コマンドをスケジュールし、データ指向の動作のためにデータDMAマネージャ(DDM)ブロック152を指示する。DDMブロック152は、一般に、コンテキストからCRP166を通じてデータパラメータを抽出するためにメモリからコンテキストをフェッチする。DDM152及びCM204によるコンテキストの無事完了に際して、状態は消費コンテキストマネージャ(CCM)164にアップデートされる。完了に際して、割り込みはハードウェアによって生成され、ファームウェアは与えられたコンテキストのために完了状態を読み取る。
ブロック172a〜172n及び174a〜174nを備えるデータDMAインタフェースポート(DDIP)は、一般に、DTP158a〜158nとシステムバッファコントローラ、及び関連するコンテキストとの間でリアルタイムデータをルーティングする役割を担う。データ転送のそれぞれは、1つ以上の領域を備える。リージョンは、1つ以上のエリアを備える。実際のフォーマットは、関連するコンテキストと同様にFMC(例えば、レジスタを用いて)からのコンフィギュレーションセッティングによって決定される。セッティングは、転送ごと、リージョンごと、及びエリアごとに基づいて分類される。ルーティングは、追加コンフィギュレーションセッティングと同様にデータ転送フォーマットのエリアタイプに従って決定される。ルーティングは、一般に、機能性をパッドしストリップすることを含む。データ転送のそれぞれは、全てのコンテキストdwordを含む。従って、DDM152は、DDIPによってコンテキストアクセスを開始し、DDIPは実データ移動に先立ってそれ自身のコンテキストキャッシュエリアに全てのコンテキストdwordを読み取る。関連するコンテキストが検索されれば、DDIPは適切なコンフィギュレーションセッティングを有するその内部制御回路をプログラムし、DTP158a〜158nのそれぞれにいくらかのコンフィギュレーション情報を提供する。その後、DDIPは、リージョンのそれぞれの内部のエリアのそれぞれを追跡し、適切なルーティングのためのロジックをセットアップする。実データ転送の間に、データがコンテキストにリダイレクトされる場合、DDIPはライトモードにコンテキストアクセスを切り替える。転送が完了したとき、DDIPは転送とコンテキストの両方のアクセスが終わったことをDDM152に通知する。DDIPはエラー検査を実行する。例えば、DDIPは、システムバッファCRCチェッキング及び/又は受信されたLBAがコンテキストからの期待するLBAとマッチするかベリファイを実行するように構成される。システムバッファECCバイトエラー(許可されたとき)と同様にこれらのチェックの結果は、一般に、DDMブロック152に送信される。DDMブロック152は、次に選択されたFLC156a〜156nに情報を送信する。DDIPもCRCを生成し挿入するように構成される。全ユーザデータはリージョンのそれぞれから全てのユーザデータバイトを集めることによって構成される。同様に、全メタデータは、リージョンのそれぞれからメタデータバイトを集めることによって構成される。一例では、定義済みの上限に到達するまで、メタデータは集められる。一例では、DDIPは、DDIPがシステムバッファに/からユーザデータエリアの使用された部分のみ、及びコンテキストに/からメタデータエリアの使用された部分のみをルートするデフォルトコンフィギュレーションを有する。ECCエリアはストリップ/パッドされる。デフォルトコンフィギュレーションは複数の変化を提供するために修正される。例えば、DDIPは(1)未使用のバイトを含む全ユーザデータエリアをそのまま保持し、(2)システムバッファに/からユーザデータエリアを有するメタデータエリアを保持し、(3)メタデータエリアをストリップ/パッドし、(4)ECCをそのまま保持し、及び/又は(5)全領域をそのままに保持する(例えば、ストリップ/パッドがない)ように構成される。
コンテキストレイアウト構造300(図10に関して上に記述した)は、ターゲットの如何なるページをプログラムするために用いられる。トップモジュールの間でのプログラムデータフローの一例は以下の通り概説される。ファームウェアは、プロセッサロジックインタフェース(PIL)150の内部のCCBの関連するメモリポインタを有するプログラムコマンドを有するコンテキストをプログラムする。CCBは、CUP168を通じてメモリへの書き込み動作を実行する。ファームウェアは、コンテキストの実行を許可するためにFLC156a〜156nのそれぞれの内部のDMM206を有効にする。FLC156a〜156nのそれぞれの内部のCM204は、メモリからCRP166を通じてコンテキストをフェッチし、フラッシュバスコントローラ(FBC)154a〜154nのそれぞれのコマンドのスケジューリングのために用いられるコンテキストの部分を処理する。FLCはコンテキストについてDDM152と通信し、DDM152はCRP166を通じてコンテキストをフェッチし、DTPブロック158a〜158nのそれぞれにデータチャンクのポインタを提供する。DTPブロック158a〜158nのそれぞれは、コンテキストから復号化されたポインタによってメモリからデータを要求する。その要求は、ブロック172a〜172n及び174a〜174nによって構成されたデータDMAインタフェースポート(DDIP)を介して行われる。データDMAインタフェースポート(DDIP)は、クワンタムバーストのメモリからデータを読み取る。
メモリから読み取られたデータは、一般に、ブロック172a〜172n及び174a〜174nによって構成されたDDIPによってDTPに送信される。DTPでは、有効であれば、データはCRCのためにチェックされ、有効であってFLC156a〜156nのそれぞれに通過したのであれば、ECCはユーザデータに追加される。データの完全性が失敗する場合、状態はCCMブロック164にアップデートされる。FLC156a〜156nのそれぞれのフラッシュ動作マネージャ(FOM)208は、フラッシュバスコントローラ(FBC)154a〜154nのそれぞれのプログラムサイクルに関連するコマンド及びデータをスケジュールする。FBC154a〜154nのそれぞれは、フラッシュインタフェース仕様ごとにフラッシュバスインタフェースでプログラム動作を実行する。FBC154a〜154nのそれぞれは、動作の完了のためにフラッシュから状態を読み取る。FBC154a〜154nのそれぞれは、FLC156a〜156nのそれぞれと通信し、FLC156a〜156nのそれぞれは、動作の完了したときにCCM164と通信する。CCM164は、CCM164に関連するコンテキストレジスタに属するコンテキストが完了し、ファームウェアが検査のために準備ができていることをファームウェアに通知するためにファームウェアに割り込みをアサートする。その後、ファームウェアは、CCM164からコンテキストを読み取る。ファームウェアがコンテキストを読み取り処理することを終了するとき、ファームウェアは別の消費されたコンテキストがロードされることを許可する信号(例えば、ビット)をアサートする。
基本的なフラッシュ読み取りデータフローは以下の通り説明される。コンテキスト構造は、ターゲットのあらゆるページを読み取るために用いられる。ファームウェアは、プロセッサロジックインタフェース(PIL)150の内部のCCBの関連するメモリポインタによって読み取りコマンド有するコンテキストをプログラムする。CCBは、CUP168を通じてメモリに書き込みを実行する。ファームウェアは、コンテキストの実行を許可するために、FLC156a〜156nのそれぞれの内部のDMM206を有効にする。FLC156a〜156nのそれぞれの内部のCM204は、メモリからCRP166を通じてコンテキストをフェッチし、FBC154a〜154nのそれぞれのコマンドのスケジューリングのために必要なコンテキストの部分を処理する。FLC156a〜156nのそれぞれは、ターゲットへの読み取りコマンドの実行のためにFBC154a〜154nのそれぞれと通信する。FLC156a〜156nのそれぞれは、コンテキストについてDDM152と通信し、DDM152は、CRP166を通じてコンテキストをフェッチし、DTPブロック158a〜158nのそれぞれにデータチャンクのポインタを提供する。
フラッシュからFBC154a〜154nのそれぞれを介してDTP158a〜158nのそれぞれにデータを受信するに際して、DTP158a〜158nのそれぞれは、コンテキストから復号化されたポインタによってメモリに書き込まれるデータを要求する。DTP158a〜158nのそれぞれは、ブロック172a〜172n及び174a〜174nによって構成されたデータDMAインタフェースポート(DDIP)を介して行う。DDIPは、クワンタムバーストのメモリにデータを書き込む。DTPでは、有効であれば、データはECCのためにチェックされ、有効であれば、CRCはユーザデータに追加され、データはDDIPに送信される。データの完全性が失敗する場合、状態はCCMブロック164にアップデートされる。読み取り動作の状態は、動作の完了したときにCCMブロック164に提供される。CCMブロック164は、CCMブロック164のコンテキストレジスタに属するコンテキストが完了し、ファームウェアが検査のために準備ができていることをファームウェアに通知するためにファームウェアに割り込みをアサートする。ファームウェアは、CCMブロック164からコンテキストを読み取る。ファームウェアがコンテキストを読み取り処理することを終了するとき、ファームウェアは別の消費されたコンテキストがロードされることを許可する信号(例えば、ビット)をアサートする。
図11を参照すると、本発明の実施の形態によるフラッシュページのリージョンパーティションの一例を図示する図が示される。NAND型フラッシュメモリーは、一般に、ユーザデータを含むページに編成される。一般に、大部分の共通ページサイズは8KBである。ユーザデータの8KBに加えて、NAND型フラッシュメモリーは、複数の目的のために用いられる付加的なバイトを含む予備のエリアを有する。最初に、予備のエリアは、一般に、ページメタデータと指称されるフラッシュ管理情報(例えば、LBA、順序番号付、不良ブロックインジケータ等)を含む。次に、予備のエリアは、誤り訂正コード(ECC)パリティ及び/又はエンドツーエンドデータの完全性チェック(EDC)情報を含む。ECCパリティは、ユーザデータとメタデータのデータ保護(例えば、エラーの検出及び訂正)のために用いられる。一例では、8KBユーザデータとは別に、メタデータ、ECC、及びEDCとの間で共有される512バイトの付加的な予備のエリアがある。
物理的ページは、複数のリージョンを備える。本発明の実施の形態によるフラッシュメディアコントローラは、従来のページリージョンを用いるが、リージョンが設定可能であることを許可する(例えば、レジスタ等を介して)。一例では、リージョンは、リージョンレイアウト400を用いて配列される。別の一例では、リージョンは、リージョンレイアウト410を用いて配列される。
リージョンレイアウト400が用いられるとき、リージョンのそれぞれは、ECC406のリージョンに続くメタデータ404のエリアに続くユーザデータフィールド402を含む。ECC406は、一般に、ユーザデータ402及びメタデータ404の両方を保護する。リージョン400のサイズは、一般に、ユーザデータ402及びメタデータ404のサイズとして設定可能である。その後、ECCエリア406のサイズは、ユーザデータ402及びメタデータ404のサイズから続く。本発明の実施の形態によって実現されたフラッシュメディアコントローラは、一般に、従来のページフォーマット構造におけるような隣接したページリージョンをサポートする。隣接したページリージョンは、複数のリージョンの隣接を表わす。しかしながら、リージョンは2のべき乗のサイズに拘束されない;リージョンはあらゆるサイズである。リージョンがあらゆるサイズであることを許可することによって、本発明の実施の形態によって実現されたフラッシュメディアコントローラは、より大きいセクタ、DIF、CRC、及び/又は付加的なメタデータをサポートする。一般に、サイズは全てプログラマブルである。
リージョンレイアウト410が用いられるとき、リージョンのそれぞれは、第1のフィールド412及び第2のフィールド414を含む。第1のフィールド412は、一般に、生、スクランブル(可能であれば)、暗号化(可能であれば)されたホストセクタデータを含む。一例では、ユーザデータのサイズは、512/1K/2K/4Kバイトプラスn dwordである、ここで、nは、例えば、0〜32まで変動する。一例では、現在のLBAは、スクランブラと暗号化のエンジンのためにシードするために用いられる。第2のフィールド414は、一般に、ページメタデータと指称されるフラッシュ管理情報(例えば、LBA、順序番号付、不良ブロックインジケータ等)を含む。リージョンレイアウト410を用いて、メタデータが物理的ページに配置される2つの方法がある、(1)メタデータはリージョンにわたって分散される、(2)全メタデータは最後のリージョンにのみ配置される。メタデータがリージョンにわたって分散されるとき、メタデータは、一般に、リージョンの一部として扱われる。リージョンのサイズは、一般に、ユーザデータとメタデータのサイズとして設定可能である。一例では、ユーザデータとメタデータのサイズはプログラマブルである(例えば、レジスタを介して)。一般に、ファームウェアは、プログラムされたサイズが物理的ページサイズの範囲内であることを保証するための役割を担う。
図12A及び12Bを参照すると、フラッシュページ構造の一例を図示する図が示される。本発明の実施の形態によって実現されたフラッシュメディアコントローラは、一般に、従来のページリージョンを用いるが、ページリージョンが設定可能であることを許可する(例えば、レジスタを介して)。一例では、フラッシュページ構造500は、リージョンレイアウト400を用いて実現される。別の一例では、複数のフラッシュページ構造510、515、520、525、530、535は、リージョンレイアウト410を用いて実現される。
一例では、メタデータは、ページ構造500のリージョンのメタデータエリアにおいて左から右に送信される。例えば、8Kバイトのページサイズ及び512バイトの予備のエリアを有するフラッシュデバイスでは、512バイトのホストセクタサイズに最大544バイトを有するリージョンのそれぞれによって、16のリージョンが格納される。一例では、リージョンのそれぞれは、ユーザデータの512バイト、メタデータの4バイト、及びECCのための28バイトまでを備える。もし合計のメタデータカウントが28バイトならば、メタデータの4バイトは第1の7つのリージョンのそれぞれのメタデータエリアに入り、9つの存続するメタデータエリア(例えば、リージョン7〜15に)に0が詰められるか、又は他の利用ために使用可能にされる。データDMAインタフェースポートがページを処理しているとき、データDMAインタフェースポートが、メタデータの挿入及び収集をどこで開始するべきか認識しており、リージョン境界でもあるコードワード境界がどこにあるか認識しているように、データDMAインタフェースポートは、ページの処理におけるプログレスのトラックを維持する。リージョンサイズがプログラマブルな一方で、リージョンサイズはECCコーデックが働くことができる最大のコードワードより大きくなるべきでない。例えば、BCH ECCは、1K+80情報ワードのための48ビットの訂正までサポートする。訂正ビットのそれぞれのために、16ビットのパリティが追加される。
リージョンレイアウト410を用いて、様々なフラッシュページ構造510、515、520、525、530、535が実現される。一例では、フラッシュページは8つのリージョンに分割され、リージョンのそれぞれはリージョンレイアウト410を用いて構成される。フラッシュページの未使用の予備のエリアは、2つの方法で利用される。第1の例では、メタデータは、リージョン(構造510、520、530によって図示された)の一部としてリージョンにわたって分散される。第2の例では、全メタデータは、ページ(構造515、525、535によって図示された)の最後のリージョンにのみ配置される。第1の例(構造510及び515によって図示された)では、LDPCの情報ワードはホストセクタサイズに等しい。この一例では、リージョンは全て別々のEDCを有し、ECCパリティ領域が付随される。EDCにリージョンの内部のホストセクタのBAがシードされる。第2の例(構造520及び525によって図示された)では、LDPCの情報ワードはホストセクタサイズより大きい。この一例では、2つのリージョンごとに別々のEDCを有し、ECCパリティが付随される。EDCにリージョンの内部の最後のホストセクタのLBAがシードされる。第3の例(構造530及び535によって図示された)では、LDPCの情報ワードはホストセクタサイズ以下である。この一例では、1つのリージョンの内部では、2つのECCパリティが付随され、1つのEDCが付随される。EDCにリージョンの内部のホストセクタのLBAがシードされる。ページリージョンが設定可能であるので、他のページ構造は特定の実施の形態のその設計基準を満たすために実現される。
図13を参照すると、本発明の実施の形態によるプロセス600を図示する流れ図が示される。処理(又は方法)600は、一般に、本発明の実施の形態によるメタデータをハンドリングするためのステップを提供する。一例では、処理600は、ステップ(又は状態)602、ステップ(又は状態)604、ステップ(又は状態)606、ステップ(又は状態)608、及びステップ(又は状態)610を備える。ステップ602では、処理600は、コンテキストに格納される定義済みのメタデータサイズに対応する閾値を定義する。ステップ604では、処理600は、要求がフラッシュデバイスからメタデータを読み取るか、又はフラッシュデバイスにメタデータを書き込むための要求のために待機する。読み取り又は書き込み動作が実行されるとき、処理600は、ステップ606に移行する。ステップ606では、処理600は、メタデータサイズが定義済みの閾値より大きいか否かを判断する。メタデータサイズが定義済みの閾値より大きいとき、処理600は、ステップ608に移行する。メタデータサイズが定義済みの閾値以下であるとき、処理600は、ステップ610に移行する。
ステップ608では、処理600は、読み取りトランザクションに関連するコンテキスト構造のフラッシュデバイスから読み取られたメタデータを格納するか(例えば、コンテキストアップデートポート(CUP)168を介して)、又は書き込みトランザクションに関連するコンテキスト構造からフラッシュデバイスにプログラムされるためのメタデータを検索する(例えば、コンテキスト訂正ポート(CRP)166及びBC_RD_I/Fを介して)。ステップ610では、処理600は、読み取りトランザクションに関連するコンテキスト構造において定義されたメタデータポインタによって識別された位置(例えば、外部システムバッファの)のフラッシュデバイスから読み取られたメタデータを格納するか、又は書き込みトランザクションに関連するコンテキスト構造において定義されたメタデータポインタによって識別された位置(例えば、外部システムバッファの)からフラッシュデバイスにプログラムされるためのメタデータを検索する。例えば、プログラムコマンドの間に、メタデータはデータDMA読み取りインタフェースポート(DDRIP)172a〜172nのそれぞれ及びBC_RD_I/Fを介して検索され、読み取りコマンドの間に、メタデータはデータDMA書き込みインタフェースポート(DDWIP)174a〜174nのそれぞれ及びBC_WR_I/Fを介してアップデートされる。ステップ608又はステップ610のいずれかでは、トランザクションを完了するに際して、処理600は、ステップ604にリターンする。
本発明の実施の形態によるフラッシュメディアコントローラ(FMC)は、一般に、システムバッファ及び/又はフラッシュメディアコントローラでメタデータストレージをハンドリングする様々な方法を提供する。本発明の実施の形態によるフラッシュメディアコントローラは、メタデータハンドリングのために以下の特徴を含む。メタデータ情報は、ページベースごとにコンテキストが定義されるコンテキストベースごとに定義される。メタデータサイズが定義済みの閾値以下であるとき、完了したメタデータはコンテキスト構造の内部に格納される。フラッシュプログラムサイクルの間に、コンテキストからのメタデータ(例えば、CRP166及びBC_RD_I/Fを介して)は、フラッシュターゲットに格納され、読み取りサイクルの間に、フラッシュターゲットから読み取られたメタデータは、コンテキスト構造の後に格納される(例えば、CUP168を介して)。メタデータサイズが定義済みの閾値より大きいとき、コンテキスト構造の内部のメタデータを格納する代わりに、メタデータポインタはコンテキストの内部に定義される。メタデータポインタは、フラッシュプログラムサイクルの間に外部システムメモリからメタデータを検索し(例えば、DDRIPのそれぞれ及びBC_RD_I/Fを介して)、コンテキストによって指定されたメタデータポインタによって示された外部システムメモリの位置へのフラッシュ読み取りコマンドから読み取られたデータを格納するためにアドレスポインタを提供する(例えば、DDWIPのそれぞれ及びBC_WR_I/Fを介して)。別の一例では、FMCは、メタデータの別の部分が外部システムメモリによってハンドリングされる間に、メタデータのある部分がコンテキストによってハンドリングされるように構成される。
メタデータのサイズは、一般に、フラッシュトランザクションレイヤ(FTL)によって定義される。一例では、FTLはおよそ12バイトのメタデータを用いる。図10に示されたコンテキスト300の最大の使用可能な予備のエリアは、28バイトである。FTLメタデータサイズパラメータ及びコンテキスト300の予備のエリアパラメータの両方を考慮に入れて、28バイトの定義済みの閾値が選択される。例えば、メタデータサイズが28バイト以下であるとき、完了したメタデータは、フラッシュメディアコントローラのフラッシュレーンコントローラの内部のコンテキスト構造の内部に格納される。フラッシュプログラムサイクルの間に、コンテキストからのメタデータはフラッシュターゲットに格納され、読み取りサイクルの間に、フラッシュターゲットから読み取られたメタデータは、コンテキスト構造の後に格納される。メタデータサイズが28バイトを超えているとき、コンテキスト構造の内部にメタデータを格納する代わりに、フラッシュレーンコントローラは、メタデータが格納される外部メモリの位置を指すコンテキストの内部のメタデータポインタを定義する。ページサイズがホストサイズの倍数である場合に(例えば、図12に示されるように)、メタデータは、一般に、ホストユーザデータのそれぞれに分散される。例えば、1Kバイトのページサイズ及び1024バイトのホストサイズのために、フラッシュプログラムコマンドの間に、コンテキストからの28バイトは、2つのホストユーザデータの間に分散される(例えば、ユーザデータのそれぞれにメタデータの14バイト):
ホストユーザデータ1(512バイト)+メタデータ1(14バイト)+ECC+ホストユーザデータ2(512バイト)+メタデータ2(14バイト)+ECC。
メタデータは、一般に、ECCの利用によって保護される。ECCの利用は、一般に、メタデータ部分を通じて、完全性チェック及び訂正を提供する。
本発明の様々な信号は、一般に、「オン」(例えば、デジタルHIGH、又は1)又は「オフ」(例えば、デジタルLOW、又は0)がある。しかしながら、信号のオン(例えば、アサートされた)及びオフ(例えば、デアサートされた)の状態の特定の極性は、特定の実施の形態のその設計基準を満たすために調節される(例えば、逆にされる)。
図1〜9、及び13によって実行される機能は、従来のメインプロセッサ、デジタルコンピュータ、マイクロプロセッサ、マイクロコントローラ、RISC(縮小命令型コンピュータ)プロセッサ、CISC(複雑命令セットコンピュータ)プロセッサ、SIMD(単一命令多重データ)プロセッサ、信号プロセッサ、中央演算処理装置(CPU)、算術論理演算装置(ALU)、ビデオデジタル信号プロセッサ(VDSP)、及び/又は関連する技術分野における当業者に明らかであろうように本明細書の教示に従ってプログラムされた同様の計算機の1つ以上を用いて実現される。適切なソフトウェア、ファームウェア、符号化、ルーチン、命令、オペコード、マイクロコード、及び/又はプログラムモジュールもまた関連する技術分野における当業者に明らかであろうように本明細書の教示に基づいて熟練したプログラマによって容易に準備される。ソフトウェアは、一般に、機械実装のプロセッサの1つ以上によって1つの媒体又は複数の媒体から実行される。
本発明は、更にASIC(特定用途向け集積回路)、プラットホームASIC、FPGA(フィールドプログラマブルゲートアレイ)、PLD(プログラマブルロジックデバイス)、CPLD(コンプレックスプログラマブルロジックデバイス)、シーゲート、RFIC(高周波集積回路)、ASSP(特定用途専用標準品)、1つ以上のモノリシック集積回路、1つ以上のチップ又はダイに配置されたフリップチップモジュール及び/又はマルチチップモジュールによって、又はここで説明されるように従来の構成回路の適切なネットワークを相互に接続することによって実現され、それらの修正は、技術分野における当業者に容易に明らかである。
本発明は、また本発明による1つ以上の処理又は方法を行うように機械をプログラムするために用いられる命令を含むコンピュータ製品である記憶媒体又は媒体及び/又は送信媒体又は媒体を含む。コンピュータ製品に包含される命令の機械による実行は、回路素子を取り巻く動作に加えて、入力データを記憶媒体で1つ以上のファイル、及び/又はオーディオ及び/又はビジュアルな描写のようなフィジカルオブジェクト又は実体の典型である1つ以上の出力信号に変換する。記憶媒体は、限定されるものではないが、フロッピー(登録商標)ディスク、ハードドライブ、磁気ディスク、光ディスク、CD−ROM、DVD、及び光磁気ディスクを含む如何なるタイプのディスク、及びROM(リードオンリメモリ)、RAM(ランダムアクセスメモリ)、EPROM(電気的プログラム可能リードオンリメモリ)、EEPROM(電気的消去可能リードオンリメモリ)、UVPROM(紫外線消去可能リードオンリメモリ)、フラッシュメモリ、磁気カード、光カードのような回路、及び/又は電子命令の格納のために適切な如何なるタイプの媒体を含む。
本発明のエレメントは、1つ以上のデバイス、ユニット、コンポーネント、システム、機械及び/又は装置の一部又は全てを構成する。デバイスは、限定されるものではないが、サーバ、ワークステーション、記憶アレイコントローラ、記憶システム、パーソナルコンピュータ、ラップトップコンピュータ、ノートブックコンピュータ、パームコンピュータ、携帯情報端末、携帯電子デバイス、バッテリ駆動デバイス、セットトップボックス、エンコーダ、デコーダ、トランスコーダ、コンプレッサ、デコンプレッサ、プリプロセッサ、ポストプロセッサ、トランスミッタ、レシーバ、トランシーバ、サイファ回路、携帯電話、デジタルカメラ、ポジショニング及び/又はナビゲーションシステム、医療機器、ヘッドアップ表示装置、ワイヤレスデバイス、オーディオ録音、記憶及び/又は再生装置、ビデオ録画、記憶及び/又は再生装置、ゲームプラットホーム、周辺装置及び/又はマルチチップモジュールを含む。関連する技術分野における当業者は、特定用途の基準を満たす他のタイプのデバイスで、本発明のエレメントが実現されることを理解するであろう。
本発明は、特にその好適な実施の形態に関して表わされ説明されたが、本発明の範囲から逸脱することなく、形式と細部の様々な変更なし得るであろうことが当業者によって理解されるであろう。