Nothing Special   »   [go: up one dir, main page]

JP2009157807A - Memory controller, flash memory system provided with memory controller, and method for controlling flash memory - Google Patents

Memory controller, flash memory system provided with memory controller, and method for controlling flash memory Download PDF

Info

Publication number
JP2009157807A
JP2009157807A JP2007337524A JP2007337524A JP2009157807A JP 2009157807 A JP2009157807 A JP 2009157807A JP 2007337524 A JP2007337524 A JP 2007337524A JP 2007337524 A JP2007337524 A JP 2007337524A JP 2009157807 A JP2009157807 A JP 2009157807A
Authority
JP
Japan
Prior art keywords
physical
data
logical
page
written
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
JP2007337524A
Other languages
Japanese (ja)
Other versions
JP4760826B2 (en
Inventor
Naoki Mukoda
直樹 向田
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
TDK Corp
Original Assignee
TDK Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by TDK Corp filed Critical TDK Corp
Priority to JP2007337524A priority Critical patent/JP4760826B2/en
Publication of JP2009157807A publication Critical patent/JP2009157807A/en
Application granted granted Critical
Publication of JP4760826B2 publication Critical patent/JP4760826B2/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Abstract

<P>PROBLEM TO BE SOLVED: To provide technology for managing association between a logical page (or a logical sector region) and a physical page (or a physical sector region) in order to efficiently obtain the association between the logical page (or the logical sector region) and the physical page (or the physical sector region). <P>SOLUTION: A memory controller is configured to prepare page management information (or sector management information) showing association between a physical page (or a physical sector region) in a physical block with a series of data written therein and a logical page (or a logical sector region) in a logical block corresponding to the physical block. The prepared page management information (or the prepared sector management information) is written in a physical page (or a physical sector region) following the physical page (or the physical sector region) with final data of the series of data written therein. <P>COPYRIGHT: (C)2009,JPO&INPIT

Description

本発明は、メモリコントローラ、メモリコントローラを備えるフラッシュメモリシステム、並びにフラッシュメモリの制御方法に関する。   The present invention relates to a memory controller, a flash memory system including the memory controller, and a flash memory control method.

従来、論理ブロックに含まれる論理ページと、この論理ブロックに対応する物理ブロックに含まれる物理ページとの対応関係を固定せずに、ホストシステムから与えられる各論理ページに対応するデータを、ホストシステムから与えられる順番で物理ブロック内の物理ページに書き込んでいく方法が知られている(例えば特許文献1参照)。かかる書き込み方法では、物理ブロック内のデータが書き込まれていないページに対して、先頭から順番にホストシステムから与えられるデータを書き込んでいくため、データの書き換えを容易に行うことができる。一方、データを読み出すときには、論理ページと物理ページの対応関係が固定されていないため、論理ページと物理ページの対応関係を把握する必要が生じる。   Conventionally, data corresponding to each logical page given from the host system is not stored in the host system without fixing the correspondence between the logical page included in the logical block and the physical page included in the physical block corresponding to the logical block. There is known a method of writing to physical pages in a physical block in the order given by (see, for example, Patent Document 1). In such a writing method, since data given from the host system is written in order from the head to a page in which data in the physical block is not written, data can be easily rewritten. On the other hand, when data is read, since the correspondence between the logical page and the physical page is not fixed, it is necessary to grasp the correspondence between the logical page and the physical page.

特開2005−196736号公報JP 2005-196736

各物理ページの冗長領域に対応する論理ページ(又は論理セクタ領域)の番号等の論理ページ(又は論理セクタ領域)を特定する情報を書き込んでおけば、この情報に基づいて、論理ページ(又は論理セクタ領域)と物理ページ(又は物理セクタ領域)の対応関係を把握することができる。   If information specifying the logical page (or logical sector area) such as the number of the logical page (or logical sector area) corresponding to the redundant area of each physical page is written, the logical page (or logical page) is written based on this information. The correspondence relationship between the sector area) and the physical page (or physical sector area) can be grasped.

しかし、データが書き込まれている各物理ページから論理ページ(又は論理セクタ領域)を特定する情報を順次読み出して、論理ページ(又は論理セクタ領域)と物理ページ(又は物理セクタ領域)の対応関係を把握するのでは、処理効率が良くない。   However, the information specifying the logical page (or logical sector area) is sequentially read from each physical page where data is written, and the correspondence between the logical page (or logical sector area) and the physical page (or physical sector area) is determined. To grasp, processing efficiency is not good.

そこで、本発明は、効率的に論理ページ(又は論理セクタ領域)と物理ページ(又は物理セクタ領域)の対応関係を把握することができる論理ページ(又は論理セクタ領域)と物理ページ(又は物理セクタ領域)の対応関係の管理技術を提供することを目的とする。   Therefore, the present invention provides a logical page (or logical sector area) and a physical page (or physical sector) that can efficiently grasp the correspondence between the logical page (or logical sector area) and the physical page (or physical sector area). The purpose is to provide the management technology of the correspondence relationship of (region).

本発明の第一の側面に従うメモリコントローラは、
ホストシステムから与えられるアクセス指示に基づいて、複数個の物理セクタ領域を含む物理ブロック単位で消去が行われるフラッシュメモリに対するアクセスを制御するメモリコントローラであって、
複数個の論理セクタ領域で構成された論理ブロックと前記物理ブロックとの対応関係を管理するブロック管理手段と、
前記アクセス指示によりアクセス対象の領域として指定された論理アクセス領域が属する前記論理ブロックと対応する前記物理ブロック内のデータが書き込まれていない前記物理セクタ領域の先頭を検索する空きセクタ領域検索手段と、
前記アクセス指示により前記論理アクセス領域に対して書き込むことが指示された一連のデータを、前記空きセクタ領域検索手段によって検出されたデータが書き込まれていない先頭の前記物理セクタ領域から、末尾の前記物理セクタ領域に向かって順次書き込んでいくデータ書き込み手段と、
前記データ書き込み手段により前記一連のデータが書き込まれた前記物理ブロック内の前記物理セクタ領域と、前記物理ブロックに対応する前記論理ブロック内の前記論理セクタ領域との対応関係を示すセクタ管理情報を、前記一連のデータの末尾データが書き込まれた前記物理セクタ領域の次の前記物理セクタ領域に書き込むセクタ管理情報書き込み手段と、
を備える。
A memory controller according to the first aspect of the present invention comprises:
A memory controller that controls access to a flash memory that is erased in units of physical blocks including a plurality of physical sector areas, based on an access instruction given from a host system,
A block management means for managing a correspondence relationship between a logical block composed of a plurality of logical sector areas and the physical block;
Empty sector area search means for searching for the beginning of the physical sector area in which data in the physical block corresponding to the logical block to which the logical access area specified as the area to be accessed by the access instruction belongs is not written;
A series of data instructed to be written to the logical access area by the access instruction is transferred from the head physical sector area to which the data detected by the free sector area search means is not written, to the physical address at the end. Data writing means for sequentially writing toward the sector area;
Sector management information indicating a correspondence relationship between the physical sector area in the physical block in which the series of data is written by the data writing unit and the logical sector area in the logical block corresponding to the physical block, Sector management information writing means for writing to the physical sector area next to the physical sector area in which the end data of the series of data is written;
Is provided.

好適な実施形態では、前記セクタ管理情報書き込み手段は、前記データ書き込み手段により前記一連のデータが書き込まれた前記物理ブロック内のデータが書き込まれている全ての前記物理セクタ領域に対して、前記物理ブロックに対応する前記論理ブロック内の前記論理セクタ領域が先頭から順番に対応しているときには、前記一連のデータの末尾データが書き込まれた前記物理セクタ領域の次の前記物理セクタ領域に前記セクタ管理情報を書き込まない。   In a preferred embodiment, the sector management information writing means applies the physical management to all the physical sector areas to which data in the physical block in which the series of data has been written by the data writing means. When the logical sector areas in the logical block corresponding to the block correspond in order from the top, the sector management is performed in the physical sector area next to the physical sector area in which the end data of the series of data is written. Do not write information.

好適な実施形態では、前記セクタ管理情報書き込み手段は、セクタ管理情報作成手段を備える。前記セクタ管理情報作成手段は、前記アクセス指示により前記論理アクセス領域に対して前記一連のデータを書き込むことを指示されたときに、前記論理アクセス領域が属する前記論理ブロックと対応する前記物理ブロック内のデータが書き込まれている末尾の前記物理セクタ領域に前記セクタ管理情報が記憶されている場合は、前記セクタ管理情報に基づいて、前記一連のデータの末尾データが書き込まれる前記物理セクタ領域の次の前記物理セクタ領域に書き込む前記セクタ管理情報を作成する。   In a preferred embodiment, the sector management information writing means includes sector management information creating means. The sector management information creating means, when instructed to write the series of data to the logical access area by the access instruction, in the physical block corresponding to the logical block to which the logical access area belongs When the sector management information is stored in the physical sector area at the end where data is written, based on the sector management information, the next physical sector area to which the end data of the series of data is written The sector management information to be written in the physical sector area is created.

好適な実施形態では、前記セクタ管理情報作成手段は、前記アクセス指示により前記論理アクセス領域に対して前記一連のデータを書き込むことを指示されたときに、前記論理アクセス領域が属する前記論理ブロックと対応する前記物理ブロック内のデータが書き込まれている末尾の前記物理セクタ領域に前記セクタ管理情報が記憶されていない場合には、前記物理ブロック内のデータが書き込まれている前記物理セクタ領域に対して、前記物理ブロックに対応する前記論理ブロック内の前記論理セクタ領域が先頭から順番に対応しているとみなして、前記一連のデータの末尾データが書き込まれる前記物理セクタ領域の次の前記物理セクタ領域に書き込む前記セクタ管理情報を作成する。   In a preferred embodiment, the sector management information creating means corresponds to the logical block to which the logical access area belongs when the access instruction is instructed to write the series of data to the logical access area. If the sector management information is not stored in the physical sector area at the end where data in the physical block is written, the physical sector area in which data in the physical block is written is stored. The logical sector area in the logical block corresponding to the physical block is considered to correspond in order from the beginning, and the physical sector area next to the physical sector area in which the end data of the series of data is written The sector management information to be written in is created.

好適な実施形態では、前記アクセス指示により指定された前記論理アクセス領域が属する前記論理ブロックと対応する前記物理ブロック内の前記物理セクタ領域に記憶されているデータを、前記物理ブロック内のデータが書き込まれている末尾の前記物理セクタ領域に記憶されている前記セクタ管理情報に基づいて読み出すデータ読み出し手段を更に備える。   In a preferred embodiment, the data stored in the physical sector area in the physical block corresponding to the logical block to which the logical access area specified by the access instruction belongs is written into the data in the physical block. And a data reading means for reading based on the sector management information stored in the last physical sector area.

好適な実施形態では、前記データ読み出し手段は、前記論理アクセス領域が属する前記論理ブロックと対応する前記物理ブロック内に前記セクタ管理情報が記憶されていないときは、前記物理ブロック内のデータが書き込まれている前記物理セクタ領域に対して、前記物理ブロックに対応する前記論理ブロック内の前記論理セクタ領域が先頭から順番に対応しているとみなして、データの読み出しを行う。   In a preferred embodiment, the data reading means writes the data in the physical block when the sector management information is not stored in the physical block corresponding to the logical block to which the logical access area belongs. It is assumed that the logical sector area in the logical block corresponding to the physical block corresponds to the physical sector area corresponding to the physical block in order from the top, and data is read out.

本発明の第二の側面に従うメモリコントローラは、
ホストシステムから与えられるアクセス指示に基づいて、複数個の物理ページを含む物理ブロック単位で消去が行われるフラッシュメモリに対するアクセスを制御するメモリコントローラであって、
複数個の論理ページで構成された論理ブロックと前記物理ブロックとの対応関係を管理するブロック管理手段と、
前記アクセス指示によりアクセス対象の論理ページとして指定された論理アクセスページが属する前記論理ブロックと対応する前記物理ブロック内のデータが書き込まれていない前記物理ページの先頭を検索する空きページ検索手段と、
前記アクセス指示により前記論理アクセスページに対して書き込むことが指示された一連のデータを、前記空きページ検索手段によって検出されたデータが書き込まれていない先頭の前記物理ページから、末尾の前記物理ページに向かって順次書き込んでいくデータ書き込み手段と、
前記データ書き込み手段により前記一連のデータが書き込まれた前記物理ブロック内の前記物理ページと、前記物理ブロックに対応する前記論理ブロック内の前記論理ページとの対応関係を示すページ管理情報を、前記一連のデータの末尾データが書き込まれた前記物理ページの次の前記物理ページに書き込むページ管理情報書き込み手段と、
を備える。
A memory controller according to the second aspect of the present invention comprises:
A memory controller that controls access to a flash memory that is erased in units of physical blocks including a plurality of physical pages, based on an access instruction given from a host system,
Block management means for managing a correspondence relationship between a logical block composed of a plurality of logical pages and the physical block;
Empty page search means for searching for the top of the physical page in which data in the physical block corresponding to the logical block to which the logical access page designated as the logical page to be accessed belongs by the access instruction belongs,
A series of data instructed to be written to the logical access page by the access instruction is transferred from the first physical page to which the data detected by the empty page search unit is not written to the last physical page. Data writing means for sequentially writing toward the
Page management information indicating a correspondence relationship between the physical page in the physical block in which the series of data is written by the data writing unit and the logical page in the logical block corresponding to the physical block; Page management information writing means for writing to the physical page next to the physical page in which the end data of the data is written;
Is provided.

好適な実施形態では、前記ページ管理情報書き込み手段は、前記データ書き込み手段により前記一連のデータが書き込まれた前記物理ブロック内のデータが書き込まれている全ての前記物理ページに対して、前記物理ブロックに対応する前記論理ブロック内の前記論理ページが先頭から順番に対応しているときには、前記一連のデータの末尾データが書き込まれた前記物理ページの次の前記物理ページに前記ページ管理情報を書き込まない。   In a preferred embodiment, the page management information writing unit is configured to apply the physical block to all the physical pages in which data in the physical block in which the series of data is written by the data writing unit is written. The page management information is not written to the physical page next to the physical page in which the end data of the series of data is written when the logical pages in the logical block corresponding to .

好適な実施形態では、前記ページ管理情報書き込み手段は、ページ管理情報作成手段を備える。前記ページ管理情報作成手段は、前記アクセス指示により前記論理アクセスページに対して前記一連のデータを書き込むことを指示されたときに、前記論理アクセスページが属する前記論理ブロックと対応する前記物理ブロック内のデータが書き込まれている末尾の前記物理ページに前記ページ管理情報が記憶されている場合は、前記ページ管理情報に基づいて、前記一連のデータの末尾データが書き込まれる前記物理ページの次の前記物理ページに書き込む前記ページ管理情報を作成する。   In a preferred embodiment, the page management information writing means includes page management information creating means. The page management information creation means, when instructed to write the series of data to the logical access page by the access instruction, in the physical block corresponding to the logical block to which the logical access page belongs When the page management information is stored in the last physical page in which data is written, the physical next to the physical page in which the last data of the series of data is written based on the page management information The page management information written on the page is created.

好適な実施形態では、前記ページ管理情報作成手段は、前記アクセス指示により前記論理アクセスページに対して前記一連のデータを書き込むことを指示されたときに、前記論理アクセスページが属する前記論理ブロックと対応する前記物理ブロック内のデータが書き込まれている末尾の前記物理ページに前記ページ管理情報が記憶されていない場合には、前記物理ブロック内のデータが書き込まれている前記物理ページに対して、前記物理ブロックに対応する前記論理ブロック内の前記論理ページが先頭から順番に対応しているとみなして、前記一連のデータの末尾データが書き込まれる前記物理ページの次の前記物理ページに書き込む前記ページ管理情報を作成する。   In a preferred embodiment, the page management information creation means corresponds to the logical block to which the logical access page belongs when the access instruction is instructed to write the series of data to the logical access page. When the page management information is not stored in the last physical page in which the data in the physical block is written, the physical page in which the data in the physical block is written The page management that considers that the logical pages in the logical block corresponding to the physical block correspond in order from the top, and writes to the physical page next to the physical page to which the end data of the series of data is written Create information.

好適な実施形態では、前記アクセス指示により指定された前記論理アクセスページが属する前記論理ブロックと対応する前記物理ブロック内の前記物理ページに記憶されているデータを、前記物理ブロック内のデータが書き込まれている末尾の前記物理ページに記憶されている前記ページ管理情報に基づいて読み出すデータ読み出し手段を更に備える。   In a preferred embodiment, data stored in the physical page in the physical block corresponding to the logical block to which the logical access page specified by the access instruction belongs is written into the data in the physical block. And a data reading means for reading based on the page management information stored in the last physical page.

好適な実施形態では、前記データ読み出し手段は、前記論理アクセスページが属する前記論理ブロックと対応する前記物理ブロック内に前記ページ管理情報が記憶されていないときは、前記物理ブロック内のデータが書き込まれている前記物理ページに対して、前記物理ブロックに対応する前記論理ブロック内の前記論理ページが先頭から順番に対応しているとみなして、データの読み出しを行う。   In a preferred embodiment, the data reading means writes the data in the physical block when the page management information is not stored in the physical block corresponding to the logical block to which the logical access page belongs. For the physical page, the logical pages in the logical block corresponding to the physical block are considered to correspond in order from the top, and data is read out.

本発明の第三の側面に従うフラッシュメモリシステムは、第一及び第二の側面のいずれかの側面に従うメモリコントローラと、前記メモリコントローラによってアクセスされるフラッシュメモリとを備える。   A flash memory system according to a third aspect of the present invention includes a memory controller according to any one of the first and second aspects, and a flash memory accessed by the memory controller.

本発明の第四の側面に従うフラッシュメモリの制御方法は、
ホストシステムから与えられるアクセス指示に基づいて、複数個の物理セクタ領域を含む物理ブロック単位で消去が行われるフラッシュメモリの制御方法であって、
複数個の論理セクタ領域で構成された論理ブロックと前記物理ブロックとの対応関係を管理するブロック管理ステップと、
前記アクセス指示によりアクセス対象の領域として指定された論理アクセス領域が属する前記論理ブロックと対応する前記物理ブロック内のデータが書き込まれていない前記物理セクタ領域の先頭を検索する空きセクタ領域検索ステップと、
前記アクセス指示により前記論理アクセス領域に対して書き込むことが指示された一連のデータを、前記空きセクタ領域検索ステップで検出されたデータが書き込まれていない先頭の前記物理セクタ領域から、末尾の前記物理セクタ領域に向かって順次書き込んでいくデータ書き込みステップと、
前記データ書き込みステップで前記一連のデータが書き込まれた前記物理ブロック内の前記物理セクタ領域と、前記物理ブロックに対応する前記論理ブロック内の前記論理セクタ領域との対応関係を示すセクタ管理情報を、前記一連のデータの末尾データが書き込まれた前記物理セクタ領域の次の前記物理セクタ領域に書き込むセクタ管理情報書き込みステップと、
を備える。
A method for controlling a flash memory according to the fourth aspect of the present invention includes:
A flash memory control method in which erasure is performed in units of physical blocks including a plurality of physical sector areas based on an access instruction given from a host system,
A block management step for managing a correspondence relationship between a logical block composed of a plurality of logical sector areas and the physical block;
A free sector area search step for searching for the beginning of the physical sector area in which data in the physical block corresponding to the logical block to which the logical access area designated as the access target area by the access instruction belongs is not written;
A series of data instructed to be written to the logical access area by the access instruction is transferred from the first physical sector area to which the data detected in the free sector area search step is not written to the last physical sector. A data writing step of sequentially writing toward the sector area;
Sector management information indicating a correspondence relationship between the physical sector area in the physical block in which the series of data is written in the data writing step and the logical sector area in the logical block corresponding to the physical block, Sector management information writing step for writing to the physical sector area next to the physical sector area in which the end data of the series of data is written;
Is provided.

本発明の第五の側面に従うフラッシュメモリの制御方法は、
ホストシステムから与えられるアクセス指示に基づいて、複数個の物理ページを含む物理ブロック単位で消去が行われるフラッシュメモリの制御方法であって、
複数個の論理ページで構成された論理ブロックと前記物理ブロックとの対応関係を管理するブロック管理ステップと、
前記アクセス指示によりアクセス対象の論理ページとして指定された論理アクセスページが属する前記論理ブロックと対応する前記物理ブロック内のデータが書き込まれていない前記物理ページの先頭を検索する空きページ検索ステップと、
前記アクセス指示により前記論理アクセスページに対して書き込むことが指示された一連のデータを、前記空きページ検索ステップで検出されたデータが書き込まれていない先頭の前記物理ページから、末尾の前記物理ページに向かって順次書き込んでいくデータ書き込みステップと、
前記データ書き込みステップで前記一連のデータが書き込まれた前記物理ブロック内の前記物理ページと、前記物理ブロックに対応する前記論理ブロック内の前記論理ページとの対応関係を示すページ管理情報を、前記一連のデータの末尾データが書き込まれた前記物理ページの次の前記物理ページに書き込むページ管理情報書き込みステップと、
を備える。
A control method of a flash memory according to the fifth aspect of the present invention is:
A flash memory control method in which erasure is performed in units of physical blocks including a plurality of physical pages based on an access instruction given from a host system,
A block management step for managing a correspondence relationship between a logical block composed of a plurality of logical pages and the physical block;
A free page search step of searching for the top of the physical page in which data in the physical block corresponding to the logical block to which the logical access page designated as the logical page to be accessed by the access instruction belongs is not written;
A series of data instructed to be written to the logical access page by the access instruction is transferred from the first physical page to which the data detected in the empty page search step is not written to the last physical page. A data writing step of sequentially writing toward the
Page management information indicating a correspondence relationship between the physical page in the physical block in which the series of data is written in the data writing step and the logical page in the logical block corresponding to the physical block; A page management information writing step for writing to the physical page next to the physical page in which the end data of the data is written;
Is provided.

効率的に論理ページ(又は論理セクタ領域)と物理ページ(又は物理セクタ領域)の対応関係を把握することができる論理ページ(又は論理セクタ領域)と物理ページ(又は物理セクタ領域)の対応関係の管理技術を提供することができる。   Correspondence between logical page (or logical sector area) and physical page (or physical sector area) that can efficiently grasp the correspondence between logical page (or logical sector area) and physical page (or physical sector area) Management technology can be provided.

以下、本発明の幾つかの実施の形態を、図面を参照しながら詳細に説明する。   Hereinafter, some embodiments of the present invention will be described in detail with reference to the drawings.

<第1の実施形態>。   <First Embodiment>.

図1は、本発明の第1の実施形態に係るフラッシュメモリシステム1を概略的に示すブロック図である。   FIG. 1 is a block diagram schematically showing a flash memory system 1 according to the first embodiment of the present invention.

図1に示すように、フラッシュメモリシステム1は、フラッシュメモリ2と、それを制御するメモリコントローラ3とで構成されている。   As shown in FIG. 1, the flash memory system 1 includes a flash memory 2 and a memory controller 3 that controls the flash memory 2.

フラッシュメモリシステム1は、外部バス13を介してホストシステム4と接続されている。ホストシステム4は、ホストシステム4の全体の動作を制御するためのCPU(Central Processing Unit)、フラッシュメモリシステム1との情報の授受を担うコンパニオンチップ等から構成されている。ホストシステム4は、例えば、文字、音声、あるいは画像情報等の種々の情報を処理するパーソナルコンピュータやデジタルスチルカメラをはじめとする各種情報処理装置であってもよい。   The flash memory system 1 is connected to the host system 4 via the external bus 13. The host system 4 is composed of a CPU (Central Processing Unit) for controlling the entire operation of the host system 4, a companion chip for transferring information to and from the flash memory system 1, and the like. The host system 4 may be various information processing apparatuses such as a personal computer and a digital still camera that process various types of information such as characters, sounds, and image information.

メモリコントローラ3は、図1に示すように、マイクロプロセッサ6と、ホストインターフェースブロック7と、ワークエリア8と、バッファ9と、フラッシュメモリインターフェースブロック10と、ECC(Error Collection Code)ブロック11と、ROM(Read Only Memory)12とから構成される。メモリコントローラ3は、内部バス14を介してフラッシュメモリ2と接続されている。これら機能ブロックによって構成されるメモリコントローラ3は、一つの半導体チップ上に集積される。以下、各機能ブロックについて説明する。   As shown in FIG. 1, the memory controller 3 includes a microprocessor 6, a host interface block 7, a work area 8, a buffer 9, a flash memory interface block 10, an ECC (Error Collection Code) block 11, and a ROM. (Read Only Memory) 12. The memory controller 3 is connected to the flash memory 2 via the internal bus 14. The memory controller 3 constituted by these functional blocks is integrated on one semiconductor chip. Hereinafter, each functional block will be described.

ホストインターフェースブロック7は、ホストシステム4との間でデータ、アドレス情報、ステータス情報、外部コマンド等の授受を行なう。外部コマンドとは、ホストシステム4がフラッシュメモリシステム1に対して処理の実行を指示するためのコマンドである。ホストシステム4よりフラッシュメモリシステム1に供給されるデータ等は、ホストインターフェースブロック7を入口としてフラッシュメモリシステム1の内部(例えば、バッファ9)に取り込まれる。また、フラッシュメモリシステム1からホストシステム4に供給されるデータ等は、ホストインターフェースブロック7を出口としてホストシステム4に供給される。   The host interface block 7 exchanges data, address information, status information, external commands and the like with the host system 4. The external command is a command for the host system 4 to instruct the flash memory system 1 to execute processing. Data or the like supplied from the host system 4 to the flash memory system 1 is taken into the flash memory system 1 (for example, the buffer 9) using the host interface block 7 as an entrance. Data supplied from the flash memory system 1 to the host system 4 is supplied to the host system 4 through the host interface block 7 as an exit.

ホストインターフェースブロック7は、コマンドレジスタR1、セクタ数レジスタR2及びLBAレジスタR3を備えている。コマンドレジスタR1、セクタ数レジスタR2及びLBAレジスタR3には、ホストシステム4から与えられる情報が書き込まれる。コマンドレジスタR1には、書き込みコマンド、読み出しコマンド等の外部コマンドが書き込まれる。セクタ数レジスタR2にはアクセス対象領域のセクタ数が書き込まれる。LBAレジスタR3には、アクセス対象領域の先頭のLBA(Logical Block Address)(後述)が書き込まれる。   The host interface block 7 includes a command register R1, a sector number register R2, and an LBA register R3. Information given from the host system 4 is written in the command register R1, the sector number register R2, and the LBA register R3. External commands such as a write command and a read command are written in the command register R1. The number of sectors in the access target area is written in the sector number register R2. LBA (Logical Block Address) (described later) of the access target area is written in the LBA register R3.

ワークエリア8は、フラッシュメモリ2の制御に必要なデータを一時的に格納する作業領域であり、複数のSRAM(Static Random Access Memory)セルによって構成されている。ワークエリア8には、例えば、論理ブロックと物理ブロックとの対応関係を示したアドレス変換テーブル(後述)等が記憶される。   The work area 8 is a work area for temporarily storing data necessary for controlling the flash memory 2, and is composed of a plurality of SRAM (Static Random Access Memory) cells. The work area 8 stores, for example, an address conversion table (described later) indicating the correspondence between logical blocks and physical blocks.

バッファ9は、フラッシュメモリ2から読み出したデータを、ホストシステム4が受け取り可能な状態となるまで保持する。また、バッファ9は、フラッシュメモリ2に書き込むデータを、フラッシュメモリ2が書き込み可能な状態となるまで保持する。   The buffer 9 holds the data read from the flash memory 2 until the host system 4 can receive the data. The buffer 9 holds data to be written to the flash memory 2 until the flash memory 2 is in a writable state.

フラッシュメモリインターフェースブロック10は、内部バス14を介して、フラッシュメモリ2との間でデータ、アドレス情報、ステータス情報、内部コマンド等の授受を行う。ここで、内部コマンドとは、メモリコントローラ3がフラッシュメモリ2に処理の実行を指示するためのコマンドであり、フラッシュメモリ2は、メモリコントローラ3から与えられる内部コマンドに従って動作する。   The flash memory interface block 10 exchanges data, address information, status information, internal commands, and the like with the flash memory 2 via the internal bus 14. Here, the internal command is a command for the memory controller 3 to instruct the flash memory 2 to execute processing, and the flash memory 2 operates in accordance with the internal command given from the memory controller 3.

ECCブロック11は、フラッシュメモリ2に書き込むデータに付加される誤り訂正符号(ECC:Error Collection Code)を生成するとともに、読み出したデータに付加されている誤り訂正符号に基づいて、読み出したデータに含まれる誤りを検出・訂正する。   The ECC block 11 generates an error correction code (ECC) added to data to be written to the flash memory 2 and is included in the read data based on the error correction code added to the read data. Detect and correct errors.

ROM12は、マイクロプロセッサ6による処理の手順を定義するプログラムを格納する不揮発性の記憶素子である。例えば、アドレス変換テーブルの作成等の処理手順を定義するプログラムが格納されている。   The ROM 12 is a non-volatile storage element that stores a program that defines a processing procedure performed by the microprocessor 6. For example, a program that defines a processing procedure such as creation of an address conversion table is stored.

マイクロプロセッサ6は、ROM12に記憶されているプログラムに従って、メモリコントローラ3の全体の動作を制御する。例えば、マイクロプロセッサ6は、ROM12から読み出した各種処理を定義したコマンドセットに基づいてフラッシュメモリインターフェースブロック10に処理を実行させる。   The microprocessor 6 controls the overall operation of the memory controller 3 in accordance with a program stored in the ROM 12. For example, the microprocessor 6 causes the flash memory interface block 10 to execute processes based on a command set that defines various processes read from the ROM 12.

フラッシュメモリ2はNAND型フラッシュメモリからなる。NAND型フラッシュメモリは、レジスタと、複数のメモリセルが2次元的に配列されたメモリセルアレイを備えている。メモリセルアレイは、複数のメモリセル群と、ワード線とを備える。ここで、メモリセル群は、複数のメモリセルが直列に接続されたものである。各ワード線は、メモリセル群の特定のメモリセルを選択するためのものである。このワード線を介して選択されたメモリセルとレジスタとの間で、レジスタから選択されたメモリセルへのデータの書き込み又は選択されたメモリセルからレジスタへのデータの読み出しが行われる。   The flash memory 2 is a NAND flash memory. The NAND flash memory includes a register and a memory cell array in which a plurality of memory cells are two-dimensionally arranged. The memory cell array includes a plurality of memory cell groups and word lines. Here, the memory cell group is a group in which a plurality of memory cells are connected in series. Each word line is for selecting a specific memory cell in the memory cell group. Data is written from the register to the selected memory cell or data is read from the selected memory cell to the register between the selected memory cell and the register via the word line.

NAND型フラッシュメモリでは、データ読み出し動作及びデータ書き込み動作はページ(物理ページ)単位で行われ、データ消去動作はブロック(物理ブロック)単位で行われる。物理ブロックは、複数のページ(物理ページ)で構成される。例えば、1個の物理ページは、所定サイズ(例えば2048バイト)のユーザ領域と、所定サイズ(例えば64バイト)の冗長領域とで構成され、1個の物理ブロックが、所定個数(例えば64個)の物理ページで構成されている。ユーザ領域は、ホストシステム4から与えられるデータを記憶するための領域であり、所定個数(例えば4個)の物理セクタ領域(512バイト単位の記憶領域)で構成されている。冗長領域は、誤り訂正符号(ECC:Error Collection Code)、論理アドレス情報、ブロックステータス(フラグ)等の付加データを記憶するための領域である。   In the NAND flash memory, a data read operation and a data write operation are performed in units of pages (physical pages), and a data erase operation is performed in units of blocks (physical blocks). A physical block is composed of a plurality of pages (physical pages). For example, one physical page includes a user area of a predetermined size (for example, 2048 bytes) and a redundant area of a predetermined size (for example, 64 bytes), and one physical block has a predetermined number (for example, 64). It consists of physical pages. The user area is an area for storing data given from the host system 4, and is configured by a predetermined number (for example, four) of physical sector areas (storage areas in units of 512 bytes). The redundant area is an area for storing additional data such as an error correction code (ECC), logical address information, and a block status (flag).

図2は、本実施形態で用いるNAND型フラッシュメモリの1個の物理ページに含まれる記憶領域を示している。   FIG. 2 shows a storage area included in one physical page of the NAND flash memory used in this embodiment.

ユーザ領域25は、ホストシステム4から与えられるデータを記憶するための領域である。冗長領域26は、誤り訂正符号(ECC:Error Collection Code)、論理アドレス情報、ブロックステータス(フラグ)等の付加データを記憶するための領域である。   The user area 25 is an area for storing data given from the host system 4. The redundant area 26 is an area for storing additional data such as an error correction code (ECC), logical address information, and a block status (flag).

本実施形態では、図2に示すようにユーザ領域25は、1セクタ(例えば512バイト)の物理セクタ領域60(60a−60d)に分割して使用される。冗長領域26は、所定サイズ(例えば8バイト)の共通冗長領域50と、所定サイズ(例えば14バイト)の分割冗長領域70(70a−70d)に分割して使用される。各物理ブロックの先頭物理ページの共通冗長領域50には、論理アドレス情報、ブロックステータス(フラグ)等の物理ブロック毎で管理される情報が書き込まれる。   In the present embodiment, as shown in FIG. 2, the user area 25 is used by being divided into one sector (for example, 512 bytes) physical sector area 60 (60a-60d). The redundant area 26 is divided into a common redundant area 50 having a predetermined size (for example, 8 bytes) and a divided redundant area 70 (70a to 70d) having a predetermined size (for example, 14 bytes). Information managed for each physical block such as logical address information and block status (flag) is written in the common redundant area 50 of the first physical page of each physical block.

4個の物理セクタ領域60a−60dと4個の分割冗長領域70a−70dは、1対1の対応関係が予め設定されている。本実施形態では、物理セクタ領域60aが分割冗長領域70aに、物理セクタ領域60bが分割冗長領域70bに、物理セクタ領域60cが分割冗長領域70cに、物理セクタ領域60dが分割冗長領域70dに、それぞれ対応している。分割冗長領域70a−70dには、対応関係にある物理セクタ領域60a−60dに記憶されるデータに付加される誤り訂正符号等の物理セクタ領域60(60a−60d)毎で管理される情報が書き込まれる。   The four physical sector areas 60a-60d and the four divided redundant areas 70a-70d have a one-to-one correspondence set in advance. In the present embodiment, the physical sector area 60a is the divided redundant area 70a, the physical sector area 60b is the divided redundant area 70b, the physical sector area 60c is the divided redundant area 70c, and the physical sector area 60d is the divided redundant area 70d. It corresponds. In the divided redundant areas 70a to 70d, information managed for each physical sector area 60 (60a to 60d) such as an error correction code added to data stored in the corresponding physical sector areas 60a to 60d is written. It is.

このように、1個の物理ページがmセクタのユーザ領域で構成され、1個の物理ブロックがn個の物理ページで構成されているNAND型フラッシュメモリでは、1個の物理ブロックは、m×n個の物理セクタ領域(1セクタ単位の領域)で構成されているNAND型フラッシュメモリとして取り扱うこともできる。つまり、本実施形態で用いたNAND型フラッシュメモリの場合には、256個の物理セクタ領域(1セクタ単位の領域)で構成されているNAND型フラッシュメモリとして取り扱うことができる。以下の説明で、物理ブロック内の物理セクタ領域に付けた通し番号を物理セクタ番号(PSN)と言う。例えば、1個の物理ブロックが256個の物理セクタ領域で構成されている場合、各物理ブロック内の256個の物理セクタ領域には、PSNとして#0−#255が付与される。   As described above, in a NAND flash memory in which one physical page is configured by a user area of m sectors and one physical block is configured by n physical pages, one physical block is m × It can also be handled as a NAND flash memory composed of n physical sector areas (areas per sector). In other words, the NAND flash memory used in the present embodiment can be handled as a NAND flash memory composed of 256 physical sector areas (areas of one sector unit). In the following description, a serial number assigned to a physical sector area in a physical block is referred to as a physical sector number (PSN). For example, when one physical block is composed of 256 physical sector areas, # 0 to # 255 are assigned as PSNs to 256 physical sector areas in each physical block.

論理アドレス情報は、物理ブロックと論理ブロックの対応関係を判別するための情報である。従って、記憶データが消去された物理ブロックのような、対応する論理ブロックの無い物理ブロックについては、その冗長領域26に(先頭物理ページの共通冗長領域50に)、論理アドレス情報は格納されていない。   The logical address information is information for determining the correspondence between physical blocks and logical blocks. Therefore, for a physical block having no corresponding logical block such as a physical block from which stored data has been erased, logical address information is not stored in the redundant area 26 (in the common redundant area 50 of the first physical page). .

ブロックステータス(フラグ)は、物理ブロックの良否を示すフラグである。尚、初期不良の物理ブロックについては、不良ブロック(正常にデータの書き込み等を行うことができない物理ブロック)であることを示すブロックステータス(フラグ)が製造メーカによって書き込まれている。また、この初期不良の物理ブロックを示すブロックステータス(フラグ)を、ユーザ領域に書き込んでいる製造メーカもある。   The block status (flag) is a flag indicating pass / fail of the physical block. For the initial defective physical block, a block status (flag) indicating a defective block (physical block in which data cannot be normally written) is written by the manufacturer. Some manufacturers also write a block status (flag) indicating the initial defective physical block in the user area.

ホストシステム4側のアドレス空間は、セクタ(512バイト)単位で分割した領域(以下、論理セクタ領域と言う)に付けた通番であるLBA(Logical Block Address)で管理されている。又、メモリコントローラ内で行われるアドレス管理では、複数個の論理セクタ領域で論理ブロックを形成し、この論理ブロックに対して、1個又は複数個の物理ブロックが割り当てている。   The address space on the host system 4 side is managed by an LBA (Logical Block Address) which is a serial number assigned to an area (hereinafter referred to as a logical sector area) divided in units of sectors (512 bytes). In address management performed in the memory controller, a logical block is formed by a plurality of logical sector areas, and one or a plurality of physical blocks are allocated to the logical block.

本実施形態では、図3に示したようにLBAが連続する256個の論理セクタ領域をまとめたものを論理ブロックとし、この論理ブロックに通し番号を付している。以下、論理ブロックに付した通し番号を論理ブロック番号(LBN)と言う。例えば、LBA#0−#255の256個の論理セクタ領域は、LBN#0の論理ブロックに属し、LBA#256−#511の256個の論理セクタ領域はLBN#1の論理ブロックに属している。このように、LBA#0−#2047999の2048000個の論理セクタ領域は、LBN#0−#7999の8000個の論理ブロックのいずれかに属している。   In the present embodiment, as shown in FIG. 3, a group of 256 logical sector areas with continuous LBAs is defined as a logical block, and a serial number is assigned to this logical block. Hereinafter, a serial number assigned to a logical block is referred to as a logical block number (LBN). For example, the 256 logical sector areas of LBA # 0- # 255 belong to the logical block of LBN # 0, and the 256 logical sector areas of LBA # 256- # 511 belong to the logical block of LBN # 1. . As described above, the 2048,000 logical sector areas of LBA # 0 to # 20479999 belong to one of 8000 logical blocks of LBN # 0 to # 7999.

更に、この論理ブロックを複数個まとめたものを論理ゾーンとし、この論理ゾーンに通し番号を付している。以下、論理ゾーンに付した通し番号を論理ゾーン番号(LZN)と言う。図3の例では、LBNが連続する論理ブロックを、異なる論理ゾーンに順次振り分けるようにして論理ゾーンを形成する。例えば、LBN#0の論理ブロックはLZN#0の論理ゾーンに、LBN#1の論理ブロックはLZN#1の論理ゾーンに、LBN#2の論理ブロックはLZN#2の論理ゾーンにという順番でLZN#7の論理ゾーンまで振り分けていく。以下同様に、LBN#8の論理ブロックをLZN#0の論理ゾーンに、LBN#9の論理ブロックをLZN#1の論理ゾーンに、LBN#10の論理ブロックをLZN#2の論理ゾーンに振り分けていく。このようにして、1000個の論理ブロックからなる8個の論理ゾーンが形成される。   Further, a logical zone is formed by collecting a plurality of logical blocks, and serial numbers are assigned to the logical zones. Hereinafter, the serial number assigned to the logical zone is referred to as a logical zone number (LZN). In the example of FIG. 3, logical zones are formed by sequentially allocating logical blocks having consecutive LBNs to different logical zones. For example, the logical block of LBN # 0 is in the logical zone of LZN # 0, the logical block of LBN # 1 is in the logical zone of LZN # 1, and the logical block of LBN # 2 is in the logical zone of LZN # 2. Sort to logical zone # 7. Similarly, the logical block of LBN # 8 is assigned to the logical zone of LZN # 0, the logical block of LBN # 9 is assigned to the logical zone of LZN # 1, and the logical block of LBN # 10 is assigned to the logical zone of LZN # 2. Go. In this way, 8 logical zones composed of 1000 logical blocks are formed.

また、図3の例では、論理ゾーンは形成するが、物理ゾーンは形成しない。そして、どの論理ゾーンであるかに関わらず、各論理ゾーンに対して、全範囲の物理ブロックを割り当てている。従って、論理ゾーンは単なるアドレス変換テーブルの作成単位であり、どの論理ブロックがどの物理ブロックに割り当てられても良い。   In the example of FIG. 3, a logical zone is formed, but a physical zone is not formed. Regardless of which logical zone, the entire range of physical blocks is assigned to each logical zone. Therefore, the logical zone is simply a unit for creating an address conversion table, and any logical block may be assigned to any physical block.

このアドレス変換テーブルは、論理ブロックと物理ブロックとの対応関係を記述したテーブルであり、各論理ゾーンに割り当てられている論理ブロックのグループ単位で作成される。このアドレス変換テーブルは、フラッシュメモリ2内に保存される。また、対応関係にある論理ブロック内の領域と物理ブロック内の領域を管理するために、論理セクタ領域と物理セクタ領域60の対応関係が後述する方法によって把握される(なお、後述の第2の実施形態では、論理ページ(後述)と物理ページの対応関係が把握される)。   This address conversion table is a table describing the correspondence between logical blocks and physical blocks, and is created in units of logical blocks assigned to each logical zone. This address conversion table is stored in the flash memory 2. In addition, in order to manage the area in the logical block and the area in the physical block that have a correspondence relationship, the correspondence relation between the logical sector area and the physical sector area 60 is grasped by a method described later (note that the second sector described later In the embodiment, the correspondence between a logical page (described later) and a physical page is grasped).

尚、フラッシュメモリ内の物理ブロックには、出荷時から不良である先天性の不良ブロックが含まれている。更に、出荷時に良品の物理ブロックであっても、使用開始後に劣化して不良ブロックになる物理ブロック(後天性の不良ブロック)もある。従って、本実施形態では、8000個の論理ブロックに対し、8192個の物理ブロックを割り当てている。   Note that the physical blocks in the flash memory include innate defective blocks that are defective from the time of shipment. Furthermore, even if a physical block is a non-defective product at the time of shipment, there is a physical block (acquired defective block) that deteriorates after use and becomes a defective block. Therefore, in this embodiment, 8192 physical blocks are assigned to 8000 logical blocks.

第1の実施形態では、論理ブロックに含まれる256個の論理セクタ領域と物理ブロックに含まれる256個の物理セクタ領域60との対応関係をセクタ単位で管理している。1個の物理ページに4個の物理セクタ領域60が含まれている。第1の実施形態におけるNAND型フラッシュメモリは、各物理ページに対するデータの書き込みを物理セクタ領域60毎に分けて実行することのできるNAND型フラッシュメモリである。つまり、1個の物理ページに含まれる4個の物理セクタ領域60に対するデータの書き込みを4回に分けて実行することができる。   In the first embodiment, the correspondence between 256 logical sector areas included in a logical block and 256 physical sector areas 60 included in a physical block is managed in units of sectors. One physical page includes four physical sector areas 60. The NAND flash memory according to the first embodiment is a NAND flash memory that can execute data writing for each physical page separately for each physical sector area 60. In other words, data writing to the four physical sector areas 60 included in one physical page can be executed four times.

第1の実施形態の書き込み処理では、ホストシステム4によって、コマンドレジスタR1に、書き込みコマンドを示すコマンドコードが書き込まれ、セクタ数レジスタR2に、書き込むデータのセクタ数が書き込まれ、LBAレジスタR3には、書き込みを開始する先頭データに対応するLBAが書き込まれる。セクタ数レジスタR2及びLBAレジスタR3に書き込まれた情報に基づいて、アクセス対象の領域である論理アクセス領域が判別され、その論理アクセス領域が含まれる論理ブロックに対応する物理ブロック内のデータが書き込まれていない物理セクタ領域60の先頭から、ホストシステム4から与えられるデータが書き込まれる。   In the write process of the first embodiment, the host system 4 writes a command code indicating a write command to the command register R1, writes the number of sectors of data to be written to the sector number register R2, and writes to the LBA register R3. The LBA corresponding to the top data for starting writing is written. Based on the information written in the sector number register R2 and the LBA register R3, the logical access area that is the access target area is determined, and the data in the physical block corresponding to the logical block including the logical access area is written. Data given from the host system 4 is written from the head of the physical sector area 60 that is not.

セクタ数レジスタR2及びLBAレジスタR3に書き込まれた情報に基づいて判別される論理アクセス領域が複数個の論理ブロックに跨っている場合は、データの書き込み先になる物理ブロックも複数個になる。従って、論理アクセス領域が複数個の論理ブロックに跨っている場合は、論理アクセス領域が属する論理ブロック毎に領域を分割してデータの書き込み処理が行われる。例えば、論理アクセス領域が2個の論理ブロック(第1の論理ブロックと第2の論理ブロック)に跨っている場合は、第1の論理ブロックに対応する物理ブロックに対する書き込み処理と、第2の論理ブロックに対応する物理ブロックに対する書き込み処理とが行われる。第1の論理ブロックに属する論理アクセス領域に対して書き込むことが指示されたデータについては、第1の論理ブロックに対応する物理ブロック内のデータが書き込まれていない物理セクタ領域60に書き込まれる。第2の論理ブロックに属する論理アクセス領域に対して書き込むことが指示されたデータについては、第2の論理ブロックに対応する物理ブロック内のデータが書き込まれていない物理セクタ領域60に書き込まれる。   When the logical access area determined based on the information written in the sector number register R2 and the LBA register R3 extends over a plurality of logical blocks, there are a plurality of physical blocks to which data is written. Therefore, when the logical access area extends over a plurality of logical blocks, the area is divided for each logical block to which the logical access area belongs, and data write processing is performed. For example, when the logical access area extends over two logical blocks (the first logical block and the second logical block), the write processing for the physical block corresponding to the first logical block and the second logical block Write processing is performed on the physical block corresponding to the block. Data instructed to be written to the logical access area belonging to the first logical block is written to the physical sector area 60 in which data in the physical block corresponding to the first logical block is not written. The data instructed to be written to the logical access area belonging to the second logical block is written to the physical sector area 60 where data in the physical block corresponding to the second logical block is not written.

以下の説明で、ホストシステム4から与えられる情報(つまり、コマンドレジスタR1、セクタ数レジスタR2及びLBAレジスタR3に書き込まれる情報)に基づいて実行される1セクタ又は複数セクタのデータの書き込み処理において、書き込まれるデータを、「一連のデータ」と言う。例えば、セクタ数レジスタR2に書き込まれた値がnの場合(nは1以上の整数)、nセクタ分のLBAが連続するデータが、一連のデータに対応する。尚、論理アクセス領域が複数個の論理ブロックに跨っている場合は、論理ブロック毎に一連のデータは分割される。例えば、論理アクセス領域が2個の論理ブロック(第1の論理ブロックと第2の論理ブロック)に跨っている場合に、第1の論理ブロックに属する論理アクセス領域のセクタ数がpセクタで、第2の論理ブロックに属する論理アクセス領域のセクタ数がqセクタであれば、セクタ数レジスタR2に書き込まれた値がn(n=p+q)であっても、一連のデータは、pセクタの一連のデータとqセクタの一連のデータとに分割される。   In the following description, in the data writing process of one sector or a plurality of sectors executed based on information given from the host system 4 (that is, information written in the command register R1, the sector number register R2, and the LBA register R3), The data to be written is called “a series of data”. For example, when the value written in the sector number register R2 is n (n is an integer of 1 or more), data in which LBAs for n sectors are continuous corresponds to a series of data. When the logical access area extends over a plurality of logical blocks, a series of data is divided for each logical block. For example, when the logical access area extends over two logical blocks (the first logical block and the second logical block), the number of sectors in the logical access area belonging to the first logical block is p sectors, If the number of sectors in the logical access area belonging to the logical block 2 is q sectors, even if the value written in the sector number register R2 is n (n = p + q), the series of data is a series of p sectors. The data is divided into a series of data of q sectors.

ホストシステム4は、書き込むデータのアドレス又は読み出すデータのアドレスをLBAで指示する。つまり、セクタ数レジスタR2及びLBAレジスタR3に書き込まれた情報に基づいて判別されるLBA(セクタ数レジスタR2に書き込まれた値が1の場合)、又は、LBAが連続する範囲(セクタ数レジスタR2に書き込まれた値が2以上の場合)が、書き込むデータの書き込み先を指示するアドレス又は読み出すデータの読み出し元を指示するアドレスになる。   The host system 4 indicates the address of the data to be written or the address of the data to be read by LBA. That is, the LBA discriminated based on the information written in the sector number register R2 and the LBA register R3 (when the value written in the sector number register R2 is 1), or the range where the LBA is continuous (sector number register R2 When the value written in (2) is 2 or more), the address indicating the write destination of the data to be written or the address indicating the read source of the data to be read is obtained.

ここで、1個の論理ブロックに含まれる論理セクタ領域の個数が2個(例えば、i=8のときは256個)の場合、LBAの下位iビット(例えば、i=8のときは下位8ビット)が、論理ブロック内の論理セクタ領域に付けた通し番号に対応する。以下、論理ブロック内の論理セクタ領域に付けた通し番号を、「論理セクタ番号(LSN)」と言う。それに対し、物理ブロック内の物理セクタ領域60に付けた通し番号を、「物理セクタ番号(PSN)」と言う。又、LBAの下位iビット(例えば、i=8のときは下位8ビット)を除いた、LBAの上位側のビットが、前述したLBN(論理ブロック番号)に対応する。従って、セクタ数レジスタR2及びLBAレジスタR3に書き込まれた情報に基づいて判別される論理アクセス領域(LBAが連続する範囲)内の先頭の論理セクタ領域と末尾の論理セクタ領域のLBAのLBNに対応する部分のビットが示す値が同一であれば、論理アクセス領域は複数個の論理ブロックに跨っていない。 Here, when the number of logical sector areas included in one logical block is 2 i (for example, 256 when i = 8), the lower i bits of the LBA (for example, lower when i = 8) 8 bits) corresponds to the serial number assigned to the logical sector area in the logical block. Hereinafter, the serial number assigned to the logical sector area in the logical block is referred to as “logical sector number (LSN)”. On the other hand, the serial number assigned to the physical sector area 60 in the physical block is referred to as “physical sector number (PSN)”. Further, the upper bits of the LBA excluding the lower i bits of the LBA (for example, the lower 8 bits when i = 8) correspond to the LBN (logical block number) described above. Therefore, it corresponds to the LBN of the LBA of the first logical sector area and the last logical sector area in the logical access area (the range where the LBA continues) determined based on the information written in the sector number register R2 and the LBA register R3. If the value indicated by the bit of the part to be processed is the same, the logical access area does not extend over a plurality of logical blocks.

以下、本実施形態での書き込みの概要を説明する。   Hereinafter, an outline of writing in the present embodiment will be described.

メモリコントローラ3は、ホストシステム4から与えられる書き込み指示(書き込みコマンド及び書き込み先のアドレス)に従って、この書き込み指示と共に与えられる一連のデータを、フラッシュメモリ2に書き込む。この書き込み処理では、書き込み先の論理セクタ領域が属する論理ブロックが特定され、その論理ブロックに対応する物理ブロック(又は、この論理ブロックに対して新たに割り当てた物理ブロック)に、一連のデータが書き込まれる。物理ブロック内の物理セクタ領域60には、先頭から順番に(つまりPSNが小さいほうから順番に)一連のデータが書き込まれていく。従って、一連のデータを書き込むときには、物理ブロック内のデータが書き込まれている物理セクタ領域の末尾の検索が行われる。そして、その末尾の物理セクタ領域60の次の物理セクタ領域60から一連のデータが順次書き込まれていく。言い換えれば、物理ブロック内のデータが書き込まれていない先頭の物理セクタ領域から一連のデータが順次書き込まれていく。   The memory controller 3 writes a series of data given together with the write instruction to the flash memory 2 in accordance with a write instruction (write command and write destination address) given from the host system 4. In this write processing, a logical block to which a write-destination logical sector area belongs is specified, and a series of data is written to a physical block corresponding to the logical block (or a physical block newly allocated to the logical block). It is. A series of data is written in the physical sector area 60 in the physical block in order from the top (that is, in order from the smallest PSN). Therefore, when writing a series of data, the end of the physical sector area where the data in the physical block is written is searched. Then, a series of data is sequentially written from the physical sector area 60 next to the last physical sector area 60. In other words, a series of data is sequentially written from the first physical sector area in which data in the physical block is not written.

本実施形態では、一連のデータの末尾データが書き込まれた物理セクタ領域60の次の物理セクタ領域60に、論理セクタ領域と物理セクタ領域60の対応関係を示す情報(以下、「セクタ管理情報」と言う)、例えば、論理セクタ領域と物理セクタ領域60の対応関係を示すテーブルを書き込んでいる。つまり、セクタ管理情報は、ホストシステム4から書き込み指示と共に与えられる一連のデータと同様に、ユーザ領域25(物理セクタ領域60)に書き込まれる。従って、物理ブロック内のデータが書き込まれている物理セクタ領域60の末尾を検索し、その物理セクタ領域60からセクタ管理情報を読み出すことにより、論理セクタ領域と物理セクタ領域60の対応関係を把握することができる。本実施形態では、セクタ管理情報は、例えば、256個の論理セクタ領域の論理セクタ番号にそれぞれ対応する256個のレコードを有するテーブルである(例えば、後述の図5(A)参照)。   In the present embodiment, information indicating the correspondence between the logical sector area and the physical sector area 60 (hereinafter referred to as “sector management information”) in the physical sector area 60 next to the physical sector area 60 in which the end data of a series of data is written. For example, a table indicating the correspondence between the logical sector area and the physical sector area 60 is written. In other words, the sector management information is written in the user area 25 (physical sector area 60) in the same manner as a series of data given together with a write instruction from the host system 4. Accordingly, the correspondence between the logical sector area and the physical sector area 60 is grasped by searching the end of the physical sector area 60 in which data in the physical block is written and reading the sector management information from the physical sector area 60. be able to. In this embodiment, the sector management information is, for example, a table having 256 records corresponding to the logical sector numbers of 256 logical sector areas (see, for example, FIG. 5A described later).

尚、物理ブロック内のデータが書き込まれている末尾の物理セクタ領域60には、論理セクタ領域と物理セクタ領域60の対応関係に関する最新のセクタ管理情報を保存しておく必要がある。従って、一連のデータを書き込む際には、その一連のデータを書き込む物理ブロック内のデータが書き込まれている末尾の物理セクタ領域60からセクタ管理情報を読み出し、このセクタ管理情報を更新した最新のセクタ管理情報を、その一連のデータの末尾データが書き込まれた物理セクタ領域60の次の物理セクタ領域60に書き込む。このセクタ管理情報の更新では、書き込む一連のデータに対応する部分について、読み出されたセクタ管理情報の内容が更新される。尚、物理セクタ領域60にセクタ管理情報を書き込む場合、物理ブロック内のデータが書き込まれている末尾の物理セクタ領域60に記憶されているデータがセクタ管理情報であるか否かを判別可能にするために、本実施形態では、セクタ管理情報の書込み先の物理セクタ領域60に対応する分割冗長領域70に、セクタ管理情報が書き込まれたことを意味するフラグ(以下、「管理フラグ」と言う)を書き込む。これにより、物理ブロック内のデータが書き込まれている末尾の物理セクタ領域60に対応した分割冗長領域70に、管理フラグが記憶されていれば、その末尾の物理セクタ領域60に記憶されているデータは、セクタ管理情報であり、管理フラグが記憶されていなければ、その末尾の物理セクタ領域60に記憶されているデータは、一連のデータの末尾データであることがわかる。   It should be noted that the latest sector management information regarding the correspondence between the logical sector area and the physical sector area 60 needs to be stored in the last physical sector area 60 in which data in the physical block is written. Therefore, when writing a series of data, the sector management information is read from the last physical sector area 60 in which the data in the physical block to which the series of data is written is written, and the latest sector in which the sector management information is updated is read. The management information is written in the physical sector area 60 next to the physical sector area 60 in which the end data of the series of data is written. In this sector management information update, the contents of the read sector management information are updated for the portion corresponding to the series of data to be written. When sector management information is written in the physical sector area 60, it is possible to determine whether or not the data stored in the physical sector area 60 at the end where the data in the physical block is written is the sector management information. Therefore, in this embodiment, a flag (hereinafter referred to as “management flag”) means that the sector management information is written in the divided redundant area 70 corresponding to the physical sector area 60 to which the sector management information is written. Write. Thus, if the management flag is stored in the divided redundant area 70 corresponding to the last physical sector area 60 in which the data in the physical block is written, the data stored in the last physical sector area 60 is stored. Is sector management information, and if the management flag is not stored, it can be seen that the data stored in the physical sector area 60 at the end is the end data of a series of data.

また、同一の物理ブロックに複数の一連のデータを連続的に書き込むような場合には、物理ブロック内のデータが書き込まれている末尾の物理セクタ領域60からセクタ管理情報を読み出さずに、ワークエリア8に保持されている、論理セクタ領域と物理セクタ領域60の対応関係に関する情報を、そのまま使用するようにしてもよい。   Further, when a plurality of series of data is continuously written in the same physical block, the work area is not read out from the last physical sector area 60 in which the data in the physical block is written. The information regarding the correspondence relationship between the logical sector area and the physical sector area 60 held in FIG. 8 may be used as it is.

また、物理ブロック内に書き込まれている全てのデータが、先頭の論理セクタ領域に対応するデータから論理セクタ領域の順番(LSNの順番)で各物理セクタ領域60に格納されている場合には、一連のデータの末尾データが書き込まれた物理セクタ領域60の次の物理セクタ領域60に、セクタ管理情報を書き込まないようにしてもよい。そして、このように物理ブロック内のデータが書き込まれている末尾の物理セクタ領域60にセクタ管理情報が書き込まれていない場合、つまり、物理ブロック内のデータが書き込まれている末尾の物理セクタ領域60に一連のデータの末尾データが書き込まれている場合、その物理ブロックには先頭の論理セクタ領域に対応するデータから論理セクタ領域の順番(LSNの順番)でデータが格納されていると判断して、論理セクタ領域と物理セクタ領域60の対応関係を把握する。   Further, when all the data written in the physical block is stored in each physical sector area 60 in the order of the logical sector area (LSN order) from the data corresponding to the head logical sector area, The sector management information may not be written in the physical sector area 60 next to the physical sector area 60 in which the end data of the series of data is written. When the sector management information is not written in the last physical sector area 60 in which the data in the physical block is written as described above, that is, in the last physical sector area 60 in which the data in the physical block is written. If the end data of a series of data is written to the physical block, it is determined that the data is stored in the physical block in the order of the logical sector area (LSN order) from the data corresponding to the head logical sector area. The correspondence relationship between the logical sector area and the physical sector area 60 is grasped.

ホストシステム4から与えられる書き込み指示と共に与えられる複数セクタ領域分のデータを書き込み先の物理ブロック内の空きセクタ領域に全て書き込むことができない場合には、その物理ブロック内の最後尾の物理セクタ領域60の1セクタ領域前の物理セクタ領域60まで、ホストシステム4から与えられるデータを書き込み、最後尾の物理セクタ領域60には、その時点での論理セクタ領域と物理セクタ領域60の対応関係を示すセクタ管理情報を書き込む。残りのデータについては、別の物理ブロックを新たに割り当て、その物理ブロック内の物理セクタ領域60に書き込み、残りのデータの末尾データが書き込まれた物理セクタ領域60の次の物理セクタ領域60に、その時点での論理セクタ領域と物理セクタ領域60の対応関係を示すセクタ管理情報を書き込む。このように1個の論理ブロックに対して2個の物理ブロックが割り当てられたような場合、後から割り当てられた物理ブロック(2個目の物理ブロック)には、2個の物理ブロックを合わせた論理セクタ領域と物理セクタ領域60の対応関係を示すセクタ管理情報、つまり、1個目の物理ブロック内の論理セクタ領域と物理セクタ領域60の対応関係を示す情報を含めたセクタ管理情報が書き込まれる。尚、1個目の物理ブロックにおいて、一連のデータの末尾データが書き込まれた物理セクタ領域60の次の物理セクタ領域60が、1個目の物理ブロックの最後尾の物理セクタ領域60の1セクタ前の物理セクタ領域60である場合、次の一連のデータは、その最後尾の物理セクタ領域60からではなく、2個目の物理ブロックの先頭の物理セクタ領域60から書き込む。   When all of the data for a plurality of sector areas given together with the write instruction given from the host system 4 cannot be written to the empty sector area in the write destination physical block, the last physical sector area 60 in the physical block The data given from the host system 4 is written up to the physical sector area 60 one sector area before, and the last physical sector area 60 is a sector indicating the correspondence between the logical sector area and the physical sector area 60 at that time. Write management information. For the remaining data, another physical block is newly allocated, written in the physical sector area 60 in the physical block, and in the physical sector area 60 next to the physical sector area 60 in which the tail data of the remaining data is written. Sector management information indicating the correspondence between the logical sector area and the physical sector area 60 at that time is written. When two physical blocks are allocated to one logical block in this way, the two physical blocks are combined with the physical block allocated later (second physical block). Sector management information indicating the correspondence between the logical sector area and the physical sector area 60, that is, sector management information including information indicating the correspondence between the logical sector area and the physical sector area 60 in the first physical block is written. . In the first physical block, the physical sector area 60 next to the physical sector area 60 in which the end data of the series of data is written is one sector in the last physical sector area 60 of the first physical block. In the case of the previous physical sector area 60, the next series of data is written not from the last physical sector area 60 but from the first physical sector area 60 of the second physical block.

上述のようにホストシステム4から与えられる書き込み指示と共に与えられる複数セクタ領域分のデータを、書き込み先の物理ブロック(1個目の物理ブロック)内の空きセクタ領域に全て書き込むことができない場合には、その物理ブロック(1個目の物理ブロック)に書き込むことができなかったデータは、新たに割り当てた物理ブロック(2個目の物理ブロック)に書き込まれる。このような場合、新たに割り当てた物理ブロック(2個目の物理ブロック)に書き込まれる先頭データが先頭の論理セクタ領域に対応することはないので、新たに割り当てた物理ブロック(2個目の物理ブロック)に対する書き込み処理では、必ずセクタ管理情報が書き込まれる。従って、ホストシステム4から与えられる書き込み指示と共に与えられる複数セクタ領域分のデータを、2個の物理ブロックに跨って書き込む場合には、1個目の物理ブロックの最後尾の物理セクタ領域60にセクタ管理情報を書き込まなくてもよい。物理ブロックから各物理セクタ領域60に格納されているデータを読み出すときには、物理ブロック内のデータが書き込まれている末尾の物理セクタ領域60からセクタ管理情報を読み出し、このセクタ管理情報に基づいて論理セクタ領域と物理セクタ領域60の対応関係を把握する。   As described above, when all of the data for a plurality of sector areas given together with the write instruction given from the host system 4 cannot be written in the empty sector area in the write destination physical block (first physical block) The data that could not be written to the physical block (first physical block) is written to the newly allocated physical block (second physical block). In such a case, since the head data written to the newly allocated physical block (second physical block) does not correspond to the head logical sector area, the newly allocated physical block (second physical block) In the writing process for (block), sector management information is always written. Accordingly, when data for a plurality of sector areas given together with a write instruction given from the host system 4 is written across two physical blocks, the sector is stored in the last physical sector area 60 of the first physical block. It is not necessary to write management information. When reading the data stored in each physical sector area 60 from the physical block, the sector management information is read from the last physical sector area 60 where the data in the physical block is written, and the logical sector is based on this sector management information. The correspondence between the area and the physical sector area 60 is grasped.

以下、図4乃至図6を参照して、本実施形態での書き込みの具体例を説明する。なお、一連のデータは、前述したように、PSNが小さい方から順番に書き込まれるが、以下、n番目(nは自然数)に書き込まれる一連のデータを「第nの一連のデータ」と言う。   A specific example of writing in the present embodiment will be described below with reference to FIGS. As described above, a series of data is written in order from the smallest PSN. Hereinafter, a series of data written in the nth (n is a natural number) is referred to as an “nth series of data”.

まず、ホストシステム4からの第1の書き込み指示から、論理アクセス領域として、LBA#0−#15の16個の論理セクタ領域(LBN#0の論理ブロック内のLSN#0−#15の論理セクタ領域)を特定する。また、この論理アクセス領域が属する論理ブロックと対応する物理ブロックが無いため、この論理ブロックに対して新たな物理ブロックを割り当てる。この物理ブロックには未だデータが書き込まれていないため、物理ブロック内のデータが書き込まれていない先頭の物理セクタ領域60として、物理ブロック内の先頭の物理セクタ領域60(PSN#0の物理セクタ領域60)を特定する。この先頭の物理セクタ領域60(PSN#0の物理セクタ領域60)から、ホストシステム4から与えられた一連のデータを書き込む。この結果、LSN#0−#15の16個の論理セクタ領域に対応する第1の一連のデータが、PSN#0−#15の16個の物理セクタ領域60に書き込まれる(図4(A)参照)。この書き込み処理を開始するときに、一連のデータの先頭データに対応する論理セクタ領域のLSNの値と、この先頭データが書き込まれる物理セクタ領域のPSNの値が一致しているため、この書き込み処理で、先頭の論理セクタ領域に対応するデータから論理セクタ領域の順番(LSNの順番)で一連のデータが書き込まれる判断することができる。   First, from the first write instruction from the host system 4, 16 logical sector areas of LBA # 0 to # 15 (logical sectors of LSN # 0 to # 15 in the logical block of LBN # 0) are used as logical access areas. Area). Since there is no physical block corresponding to the logical block to which this logical access area belongs, a new physical block is allocated to this logical block. Since no data has been written yet in this physical block, the first physical sector area 60 (PSN # 0 physical sector area) in the physical block is used as the first physical sector area 60 in which no data in the physical block is written. 60) is specified. A series of data given from the host system 4 is written from the top physical sector area 60 (PSN # 0 physical sector area 60). As a result, the first series of data corresponding to the 16 logical sector areas of LSN # 0- # 15 is written to the 16 physical sector areas 60 of PSN # 0- # 15 (FIG. 4A). reference). When this writing process is started, the LSN value of the logical sector area corresponding to the head data of a series of data matches the PSN value of the physical sector area to which the head data is written. Thus, it can be determined that a series of data is written in the order of the logical sector areas (LSN order) from the data corresponding to the top logical sector area.

この段階では、物理ブロック内に書き込まれている全てのデータが、先頭の論理セクタ領域(LSN#0の論理セクタ領域)に対応するデータからLSNの小さい順で各物理セクタ領域60に格納されている。つまり、物理ブロック内のデータが書き込まれている全ての物理セクタ領域60で、物理セクタ領域60のPSNとその物理セクタ領域60に記憶されているデータに対応した論理セクタ領域のLSNとが同じ番号である。従って、第1の一連のデータの末尾データが記憶されている物理セクタ領域60(PSN#15の物理セクタ領域60)の次の物理セクタ領域60(PSN#16の物理セクタ領域60)に、セクタ管理情報を書き込まない。   At this stage, all the data written in the physical block is stored in each physical sector area 60 in the order of LSN from the data corresponding to the head logical sector area (LSN # 0 logical sector area). Yes. That is, in all the physical sector areas 60 in which data in the physical block is written, the PSN of the physical sector area 60 and the LSN of the logical sector area corresponding to the data stored in the physical sector area 60 are the same number. It is. Accordingly, the sector in the physical sector area 60 (PSN # 16 physical sector area 60) next to the physical sector area 60 (PSN # 15 physical sector area 60) in which the end data of the first series of data is stored is stored. Do not write management information.

次に、ホストシステム4からの第2の書き込み指示から、論理アクセス領域として、LBA#16−#31の16個の論理セクタ領域(LBN#0の論理ブロック内のLSN#16−#31の論理セクタ領域)を特定する。また、物理ブロック内のデータが書き込まれている末尾の物理セクタ領域60として、PSN#15の物理セクタ領域60を特定する。特定された末尾の物理セクタ領域60(PSN#15の物理セクタ領域60)の次の物理セクタ領域60(PSN#16の物理セクタ領域60)から、ホストシステム4から与えられた一連のデータを書き込む。この結果、LSN#16−#31の16個の論理セクタ領域に対応する第2の一連のデータが、PSN#16−#31の16個の物理セクタ領域60に書き込まれる(図4(A)参照)。この書き込み処理を開始するときに、物理ブロック内のデータが書き込まれている末尾の物理セクタ領域60(PSN#15の物理セクタ領域60)にセクタ管理情報が書き込まれていないため、この時点で、物理ブロック内の物理セクタ領域60に先頭の論理セクタ領域に対応するデータから論理セクタ領域の順番(LSNの順番)で一連のデータが書き込まれていると判断することができる。更に、この書き込み処理で書き込まれる一連のデータの先頭データに対応する論理アクセス領域のLSNの値と、この先頭データが書き込まれる物理セクタ領域のPSNの値が一致しているため、この一連のデータを書き込んだ後も、この状態が維持されると判断することができる。   Next, from the second write instruction from the host system 4, 16 logical sector areas of LBA # 16- # 31 (logics of LSN # 16- # 31 in the logical block of LBN # 0) are used as logical access areas. (Sector area) is specified. Further, the physical sector area 60 of PSN # 15 is specified as the last physical sector area 60 in which data in the physical block is written. A series of data given from the host system 4 is written from the physical sector area 60 (physical sector area 60 of PSN # 16) next to the identified last physical sector area 60 (physical sector area 60 of PSN # 15). . As a result, the second series of data corresponding to the 16 logical sector areas of LSN # 16- # 31 is written to the 16 physical sector areas 60 of PSN # 16- # 31 (FIG. 4A). reference). Since the sector management information is not written in the last physical sector area 60 (the physical sector area 60 of PSN # 15) where the data in the physical block is written when this writing process is started, at this time, It can be determined that a series of data is written in the order of the logical sector areas (LSN order) from the data corresponding to the first logical sector area in the physical sector area 60 in the physical block. Further, since the LSN value of the logical access area corresponding to the head data of the series of data written by this writing process matches the PSN value of the physical sector area to which the head data is written, this series of data It can be determined that this state is maintained even after writing.

この段階でも、物理ブロック内のデータが書き込まれている全ての物理セクタ領域60で、物理セクタ領域60のPSNとその物理セクタ領域60に記憶されているデータに対応した論理セクタ領域のLSNとが同じ番号である。従って、第2の一連のデータの末尾データが記憶されている物理セクタ領域60(PSN#31の物理セクタ領域60)の次の物理セクタ領域60(PSN#32の物理セクタ領域60)にも、セクタ管理情報を書き込まない。   Even at this stage, the PSN of the physical sector area 60 and the LSN of the logical sector area corresponding to the data stored in the physical sector area 60 are the same in all the physical sector areas 60 in which data in the physical block is written. It is the same number. Therefore, the physical sector area 60 (PSN # 32 physical sector area 60) next to the physical sector area 60 (PSN # 31 physical sector area 60) in which the end data of the second series of data is stored is also stored. Sector management information is not written.

次に、ホストシステム4からの第3の書き込み指示から、論理アクセス領域として、LBA#48−#79の32個の論理セクタ領域(LBN#0の論理ブロック内のLSN#48−#79の論理セクタ領域)を特定する。また、物理ブロック内のデータが書き込まれている末尾の物理セクタ領域60として、PSN#31の物理セクタ領域60を特定する。特定された末尾の物理セクタ領域60(PSN#31の物理セクタ領域60)の次の物理セクタ領域60(PSN#32の物理セクタ領域60)から、ホストシステム4から与えられた一連のデータを書き込む。この結果、LSN#48−#79の32個の論理セクタ領域に対応する第3の一連のデータが、PSN#32−#63の32個の物理セクタ領域60に書き込まれる(図4(A)参照)。この書き込み処理を開始するときに、物理ブロック内のデータが書き込まれている末尾の物理セクタ領域60(PSN#31の物理セクタ領域60)にセクタ管理情報が書き込まれていないため、この時点で、物理ブロック内の物理セクタ領域60に先頭の論理セクタ領域に対応するデータから論理セクタ領域の順番(LSNの順番)で一連のデータが書き込まれていると判断することができる。しかし、この書き込み処理で書き込まれる一連のデータの先頭データに対応する論理アクセス領域のLSNの値と、この先頭データが書き込まれる物理セクタ領域のPSNの値が一致していないため、この一連のデータを書き込んだ後は、この状態が維持されないと判断することができる。   Next, from the third write instruction from the host system 4, 32 logical sector areas of LBA # 48- # 79 (logics of LSN # 48- # 79 in the logical block of LBN # 0) are used as logical access areas. (Sector area) is specified. Further, the physical sector area 60 of PSN # 31 is specified as the last physical sector area 60 in which data in the physical block is written. A series of data given from the host system 4 is written from the physical sector area 60 (physical sector area 60 of PSN # 32) next to the identified end physical sector area 60 (physical sector area 60 of PSN # 31). . As a result, the third series of data corresponding to the 32 logical sector areas of LSN # 48- # 79 is written into the 32 physical sector areas 60 of PSN # 32- # 63 (FIG. 4A). reference). Since the sector management information is not written in the last physical sector area 60 (the physical sector area 60 of PSN # 31) where the data in the physical block is written when this writing process is started, at this time, It can be determined that a series of data is written in the order of the logical sector areas (LSN order) from the data corresponding to the first logical sector area in the physical sector area 60 in the physical block. However, since the LSN value of the logical access area corresponding to the head data of the series of data written by this writing process does not match the PSN value of the physical sector area to which the head data is written, this series of data After writing, it can be determined that this state is not maintained.

この段階になって、物理ブロック内のデータが書き込まれている全ての物理セクタ領域60の一部(すなわち、第3の一連のデータが記憶されているPSN#32−#63の32個の物理セクタ領域60)で、物理セクタ領域60のPSNとその物理セクタ領域60に記憶されているデータに対応した論理セクタ領域のLSNとが異なる番号となる。この場合、メモリコントローラ3が、物理ブロック内のデータが書き込まれている全ての物理セクタ領域60(PSN#0−#63の物理セクタ領域60)と論理セクタ領域との対応関係を示すセクタ管理情報#0を作成する。ここでは、第3の一連のデータを書き込む前の末尾の物理セクタ領域60(PSN#31の物理セクタ領域60)に、セクタ管理情報が書き込まれていないため(その末尾の物理セクタ領域60に対応した分割冗長領域70に管理フラグが書き込まれていないため)、新規にセクタ管理情報を作成する。具体的には、ワークエリア8上にLSN#0−255にそれぞれ対応する256個のレコードを有するテーブル作成領域を確保し、このテーブル作成領域にPSNを書き込んでいく。セクタ管理情報#0の場合には、図5(A)に示すように、LSN#48−79に対応した32個のレコードに、第3の一連のデータが書き込まれた32個の物理セクタ領域60に対応するPSN#32−#63を書き込む。また、第3の一連のデータの先頭データが書き込まれているPSN#32の物理セクタ領域60よりも前の物理セクタ領域60には先頭の論理セクタ領域に対応するデータから論理セクタ領域の順番でデータが格納されていると判断して、LSN#0−#31に対応した32個のレコードに、PSN#0−31を書き込む。これにより、セクタ管理情報#0の作成が完了する。メモリコントローラ3は、作成したセクタ管理情報#0を、第3の一連のデータの末尾データが書き込まれている物理セクタ領域60(PSN#63の物理セクタ領域60)の次の物理セクタ領域60(PSN#64の物理セクタ領域60)に書き込む。また、セクタ管理情報#0が書き込まれた物理セクタ領域60(PSN#64の物理セクタ領域60)に対応した分割冗長領域70に、管理フラグを書き込む。   At this stage, a part of all physical sector areas 60 in which data in the physical block is written (that is, 32 physicals PSN # 32- # 63 in which the third series of data is stored). In the sector area 60), the PSN of the physical sector area 60 and the LSN of the logical sector area corresponding to the data stored in the physical sector area 60 have different numbers. In this case, the memory controller 3 uses the sector management information indicating the correspondence between all the physical sector areas 60 (physical sector areas 60 of PSN # 0 to # 63) in which data in the physical block is written and the logical sector areas. Create # 0. Here, since sector management information is not written in the last physical sector area 60 (PSN # 31 physical sector area 60) before the third series of data is written (corresponding to the last physical sector area 60). Since the management flag is not written in the divided redundant area 70), new sector management information is created. Specifically, a table creation area having 256 records respectively corresponding to LSN # 0-255 is secured on the work area 8, and the PSN is written into this table creation area. In the case of sector management information # 0, as shown in FIG. 5A, 32 physical sector areas in which a third series of data is written in 32 records corresponding to LSN # 48-79. PSN # 32- # 63 corresponding to 60 is written. Further, the physical sector area 60 before the physical sector area 60 of PSN # 32 in which the top data of the third series of data is written is in the order of the logical sector area from the data corresponding to the top logical sector area. It is determined that data is stored, and PSN # 0-31 is written in 32 records corresponding to LSN # 0- # 31. Thereby, the creation of the sector management information # 0 is completed. The memory controller 3 uses the created sector management information # 0 as the physical sector area 60 (next to the physical sector area 60 (physical sector area 60 of PSN # 63) in which the end data of the third series of data is written. Write to PSN # 64 physical sector area 60). Further, the management flag is written in the divided redundant area 70 corresponding to the physical sector area 60 (PSN # 64 physical sector area 60) in which the sector management information # 0 is written.

尚、後述するように、一度でもセクタ管理情報を書き込んだ物理ブロックについては、その物理ブロックに一連のデータを書き込む都度に、一連のデータの末尾データが書き込まれている物理セクタ領域60の次の物理セクタ領域60に、セクタ管理情報を書き込む。   As will be described later, for the physical block in which the sector management information has been written even once, each time a series of data is written to the physical block, the next to the physical sector area 60 in which the end data of the series of data is written. Sector management information is written in the physical sector area 60.

次に、ホストシステム4からの第4の書き込み指示から、論理アクセス領域として、LBA#16−#47の32個の論理セクタ領域(LBN#0の論理ブロック内のLSN#16−#47の論理セクタ領域)を特定する。また、物理ブロック内のデータが書き込まれている末尾の物理セクタ領域60として、PSN#64の物理セクタ領域60を特定する。特定された末尾の物理セクタ領域60(PSN#64の物理セクタ領域60)の次の物理セクタ領域60(PSN#65の物理セクタ領域60)から、ホストシステム4から与えられた一連のデータを書き込む。この結果、LSN#16−#47の32個の論理セクタ領域に対応する第4の一連のデータが、PSN#65−#96の32個の物理セクタ領域60に書き込まれる(図4(A)参照)。この書き込み処理を開始するときに、物理ブロック内のデータが書き込まれている末尾の物理セクタ領域60(PSN#64の物理セクタ領域60)にセクタ管理情報が書き込まれているため、この時点で、物理ブロック内の物理セクタ領域60に先頭の論理セクタ領域に対応するデータから論理セクタ領域の順番(LSNの順番)で一連のデータが書き込まれていないと判断することができる。   Next, from the fourth write instruction from the host system 4, 32 logical sector areas of LBA # 16- # 47 (logics of LSN # 16- # 47 in the logical block of LBN # 0) are used as logical access areas. (Sector area) is specified. Further, the physical sector area 60 of PSN # 64 is specified as the last physical sector area 60 in which data in the physical block is written. A series of data given from the host system 4 is written from the physical sector area 60 (physical sector area 60 of PSN # 65) next to the identified last physical sector area 60 (physical sector area 60 of PSN # 64). . As a result, a fourth series of data corresponding to the 32 logical sector areas of LSN # 16- # 47 is written into the 32 physical sector areas 60 of PSN # 65- # 96 (FIG. 4A). reference). Since the sector management information is written in the last physical sector area 60 (the physical sector area 60 of PSN # 64) in which data in the physical block is written when this writing process is started, at this time, It can be determined that a series of data is not written in the order of the logical sector area (LSN order) from the data corresponding to the first logical sector area in the physical sector area 60 in the physical block.

また、第4の一連のデータが書き込まれる前の末尾の物理セクタ領域60(PSN#64の物理セクタ領域60)に、セクタ管理情報#0が書き込まれているため(その末尾の物理セクタ領域60に対応した分割冗長領域70に管理フラグが書き込まれているため)、セクタ管理情報#0を読み出し、セクタ管理情報#0に基づいてセクタ管理情報#1を作成する。つまり、第4の一連のデータに対応する部分について、セクタ管理情報#0の内容を更新する。具体的には、図5(B)に示すように、セクタ管理情報#0における、LSN#16−#47に対応するレコードに、第4の一連のデータが書き込まれた32個の物理セクタ領域60に対応したPSN#65−#96を書き込むことで、セクタ管理情報#1を作成する。作成したセクタ管理情報#1を、第4の一連のデータの末尾データが書き込まれている物理セクタ領域60(PSN#96の物理セクタ領域60)の次の物理セクタ領域60(PSN#97の物理セクタ領域60)に書き込む。また、セクタ管理情報#1が書き込まれた物理セクタ領域60(PSN#97の物理セクタ領域60)に対応した分割冗長領域70に、管理フラグを書き込む。   Further, since the sector management information # 0 is written in the last physical sector area 60 (PSN # 64 physical sector area 60) before the fourth series of data is written (the last physical sector area 60). Sector management information # 0 is read out, and sector management information # 1 is created based on sector management information # 0. That is, the contents of sector management information # 0 are updated for the portion corresponding to the fourth series of data. Specifically, as shown in FIG. 5B, 32 physical sector areas in which a fourth series of data is written in records corresponding to LSN # 16- # 47 in sector management information # 0. Sector management information # 1 is created by writing PSN # 65- # 96 corresponding to 60. The created sector management information # 1 is stored in the physical sector area 60 (PSN # 97 physical physical area) next to the physical sector area 60 (PSN # 96 physical sector area 60) in which the end data of the fourth series of data is written. Write to sector area 60). Also, the management flag is written in the divided redundant area 70 corresponding to the physical sector area 60 (PSN # 97 physical sector area 60) in which the sector management information # 1 is written.

以後、同様にして、第5〜第8の一連のデータ及びセクタ管理情報#2〜#5がそれぞれ同一の物理ブロックに書き込まれる。   Thereafter, similarly, the fifth to eighth series of data and the sector management information # 2 to # 5 are written in the same physical block.

すなわち、LBA#0−#31の32個の論理セクタ領域(LBN#0の論理ブロック内のLSN#0−#31の論理セクタ領域)に対応する第5の一連のデータを、物理ブロック内のデータが書き込まれている末尾の物理セクタ領域60(PSN#97の物理セクタ領域60)の次の物理セクタ領域60(PSN#98の物理セクタ領域60)から書き込む(図4(A)及び図4(B)参照)。また、第5の一連のデータが書き込まれる前の末尾の物理セクタ領域60(PSN#97の物理セクタ領域60)に書き込まれているセクタ管理情報#1に基づいて、セクタ管理情報#2を作成する。具体的には、図5(C)に示すように、セクタ管理情報#1における、LSN#0−#31に対応するレコードに、第5の一連のデータが書き込まれた32個の物理セクタ領域60に対応したPSN#98−129を書き込むことで、セクタ管理情報#2を作成する。作成したセクタ管理情報#2を、第5の一連のデータの末尾データが書き込まれている物理セクタ領域60(PSN#129の物理セクタ領域60)の次の物理セクタ領域60(PSN#130の物理セクタ領域60)に書き込む。   That is, the fifth series of data corresponding to the 32 logical sector areas of LBA # 0 to # 31 (the logical sector areas of LSN # 0 to # 31 in the logical block of LBN # 0) are stored in the physical block. Data is written from the physical sector area 60 (PSN # 98 physical sector area 60) next to the last physical sector area 60 (PSN # 97 physical sector area 60) in which data is written (FIGS. 4A and 4). (See (B)). Also, sector management information # 2 is created based on sector management information # 1 written in the last physical sector area 60 (PSN # 97 physical sector area 60) before the fifth series of data is written. To do. Specifically, as shown in FIG. 5C, 32 physical sector areas in which a fifth series of data is written in records corresponding to LSN # 0- # 31 in the sector management information # 1. By writing PSN # 98-129 corresponding to 60, sector management information # 2 is created. The created sector management information # 2 is stored in the physical sector area 60 (the physical sector area of the PSN # 130) next to the physical sector area 60 (the physical sector area 60 of the PSN # 129) in which the end data of the fifth series of data is written. Write to sector area 60).

次に、LBA#16−#31の16個の論理セクタ領域(LBN#0の論理ブロック内のLSN#16−#31の論理セクタ領域)に対応した第6の一連のデータを、物理ブロック内のデータが書き込まれている末尾の物理セクタ領域60(PSN#130の物理セクタ領域60)の次の物理セクタ領域60(PSN#131の物理セクタ領域60)から書き込む(図4(B)参照)。また、第6の一連のデータが書き込まれる前の末尾の物理セクタ領域60(PSN#130の物理セクタ領域60)に書き込まれているセクタ管理情報#2に基づいて、セクタ管理情報#3を作成する。具体的には、図6(A)に示すように、セクタ管理情報#2における、LSN#16−#31に対応するレコードに、第6の一連のデータが書き込まれた16個の物理セクタ領域60に対応したPSN#131−146を書き込むことで、セクタ管理情報#3を作成する。作成したセクタ管理情報#3を、第6の一連のデータの末尾データが書き込まれている物理セクタ領域60(PSN#146の物理セクタ領域60)の次の物理セクタ領域60(PSN#147の物理セクタ領域60)に書き込む。   Next, a sixth series of data corresponding to the 16 logical sector areas of LBA # 16- # 31 (the logical sector area of LSN # 16- # 31 in the logical block of LBN # 0) is stored in the physical block. Is written from the physical sector area 60 (PSN # 131 physical sector area 60) next to the last physical sector area 60 (PSN # 130 physical sector area 60) in which data is written (see FIG. 4B). . Also, sector management information # 3 is created based on sector management information # 2 written in the last physical sector area 60 (PSN # 130 physical sector area 60) before the sixth series of data is written. To do. Specifically, as shown in FIG. 6A, 16 physical sector areas in which a sixth series of data is written in records corresponding to LSN # 16- # 31 in the sector management information # 2. By writing PSN # 131-146 corresponding to 60, sector management information # 3 is created. The created sector management information # 3 is stored in the physical sector area 60 (physical sector area 60 of PSN # 147) next to the physical sector area 60 (physical sector area 60 of PSN # 146) in which the end data of the sixth series of data is written. Write to sector area 60).

次に、LBA#64−#79の16個の論理セクタ領域(LBN#0の論理ブロック内のLSN#64−#79の論理セクタ領域)に対応する第7の一連のデータを、物理ブロック内のデータが書き込まれている末尾の物理セクタ領域60(PSN#147の物理セクタ領域60)の次の物理セクタ領域60(PSN#148の物理セクタ領域60)から書き込む(図4(B)参照)。また、第7の一連のデータが書き込まれる前の末尾の物理セクタ領域60(PSN#147の物理セクタ領域60)に書き込まれているセクタ管理情報#3に基づいて、セクタ管理情報#4を作成する。具体的には、図6(B)に示すように、セクタ管理情報#3における、LSN#64−#79に対応するレコードに、第7の一連のデータが書き込まれた16個の物理セクタ領域60に対応したPSN#148−163を書き込むことで、セクタ管理情報#4を作成する。作成したセクタ管理情報#4を、第7の一連のデータの末尾データが書き込まれている物理セクタ領域60(PSN#163の物理セクタ領域60)の次の物理セクタ領域60(PSN#164の物理セクタ領域60)に書き込む。   Next, the seventh series of data corresponding to the 16 logical sector areas of LBA # 64- # 79 (the logical sector area of LSN # 64- # 79 in the logical block of LBN # 0) is stored in the physical block. Is written from the physical sector area 60 (PSN # 148 physical sector area 60) next to the last physical sector area 60 (PSN # 147 physical sector area 60) in which data is written (see FIG. 4B). . Also, sector management information # 4 is created based on sector management information # 3 written in the last physical sector area 60 (PSN # 147 physical sector area 60) before the seventh series of data is written. To do. Specifically, as shown in FIG. 6B, 16 physical sector areas in which a seventh series of data is written in records corresponding to LSN # 64- # 79 in sector management information # 3. By writing PSN # 148-163 corresponding to 60, sector management information # 4 is created. The created sector management information # 4 is stored in the physical sector area 60 (the physical sector area of PSN # 164) next to the physical sector area 60 (the physical sector area 60 of PSN # 163) in which the end data of the seventh series of data is written. Write to sector area 60).

次に、LBA#80−#95の16個の論理セクタ領域(LBN#0の論理ブロック内のLSN#80−#95の論理セクタ領域)に対応する第8の一連のデータを、物理ブロック内のデータが書き込まれている末尾の物理セクタ領域60(PSN#164の物理セクタ領域60)の次の物理セクタ領域60(PSN#165の物理セクタ領域60)から書き込む(図4(B)参照)。また、第8の一連のデータが書き込まれる前の末尾の物理セクタ領域60(PSN#164の物理セクタ領域60)に書き込まれているセクタ管理情報#4に基づいて、セクタ管理情報#5を作成する。具体的には、図6(C)に示すように、セクタ管理情報#4における、LSN#80−#95に対応するレコードに、第8の一連のデータが書き込まれた16個の物理セクタ領域60に対応したPSN#165−#180を書き込むことで、セクタ管理情報#5を作成する。作成したセクタ管理情報#5を、第8の一連のデータの末尾データが書き込まれている物理セクタ領域60(PSN#180の物理セクタ領域60)の次の物理セクタ領域60(PSN#181の物理セクタ領域60)に書き込む。   Next, the eighth series of data corresponding to the 16 logical sector areas of LBA # 80- # 95 (the logical sector area of LSN # 80- # 95 in the logical block of LBN # 0) is stored in the physical block. Is written from the physical sector area 60 (PSN # 165 physical sector area 60) next to the last physical sector area 60 (PSN # 164 physical sector area 60) in which data is written (see FIG. 4B) . Also, sector management information # 5 is created based on sector management information # 4 written in the last physical sector area 60 (PSN # 164 physical sector area 60) before the eighth series of data is written. To do. Specifically, as shown in FIG. 6C, 16 physical sector areas in which an eighth series of data is written in records corresponding to LSN # 80- # 95 in the sector management information # 4. The sector management information # 5 is created by writing PSN # 165- # 180 corresponding to 60. The created sector management information # 5 is stored in the physical sector area 60 (physical sector area of PSN # 181) next to the physical sector area 60 (physical sector area 60 of PSN # 180) in which the end data of the eighth series of data is written. Write to sector area 60).

さて、この後、物理ブロックから各物理セクタ領域60に格納されているデータを読み出すときには、メモリコントローラ3は、物理ブロック内のデータが書き込まれている末尾の物理セクタ領域60(PSN#181の物理セクタ領域60)からセクタ管理情報#5を読み出し、このセクタ管理情報#5に基づいて論理セクタ領域と物理セクタ領域60の対応関係を把握する。ここでは、PSN#181の物理セクタ領域60に書き込まれているセクタ管理情報#5が、論理セクタ領域と物理セクタ領域60の最新の対応関係を示しているため、そのセクタ管理情報#5を参照するだけで、論理セクタ領域と物理セクタ領域60の最新の対応関係を把握することができる。つまり、本実施形態によれば、効率的に、論理セクタ領域と物理セクタ領域60の対応関係を把握することができる。   After that, when reading data stored in each physical sector area 60 from the physical block, the memory controller 3 reads the physical sector area 60 (PSN # 181 physical data) at the end where the data in the physical block is written. The sector management information # 5 is read from the sector area 60), and the correspondence between the logical sector area and the physical sector area 60 is grasped based on the sector management information # 5. Here, since the sector management information # 5 written in the physical sector area 60 of PSN # 181 indicates the latest correspondence between the logical sector area and the physical sector area 60, refer to the sector management information # 5. It is possible to grasp the latest correspondence relationship between the logical sector area and the physical sector area 60 simply by doing so. That is, according to the present embodiment, the correspondence relationship between the logical sector area and the physical sector area 60 can be grasped efficiently.

尚、もし、第1の一連のデータが書き込まれてから第3の一連のデータが書き込まれる前までの間に(つまりセクタ管理情報が全く書き込まれていない場合に)、物理ブロックからデータを読み出すときには、メモリコントローラ3は、先頭の論理セクタ領域に対応するデータから論理セクタ領域の順番でデータが格納されていると判断して、論理セクタ領域と物理セクタ領域60の対応関係を把握することができる。   If the first series of data is written and before the third series of data is written (that is, when no sector management information is written), the data is read from the physical block. Sometimes, the memory controller 3 determines that data is stored in the order of the logical sector area from the data corresponding to the leading logical sector area, and can grasp the correspondence between the logical sector area and the physical sector area 60. it can.

以上が、第一の実施形態の説明である。   The above is the description of the first embodiment.

なお、セクタ管理情報は、前述したような、論理セクタ領域と物理セクタ領域60の対応関係を示すテーブルであることが好ましいが、一変形例として、物理ブロックに書き込まれているそれぞれの一連のデータの先頭データに対応する論理セクタ領域の論理セクタ番号であるスタート論理セクタ番号(以下、「SLSN」と言う)とその一連のデータが書き込まれるセクタ領域数(先頭データが書き込まれるセクタ領域から末尾データが書き込まれるセクタ領域までのセクタ領域の個数であるセクタカウント値、以下、「SCNT」と言う)とを示す情報であってもよい。更に、これらの情報に、それぞれの一連のデータの先頭データが書き込まれる物理セクタ領域の物理セクタ番号(PSN)を示す情報を加えてもよい。このような情報が書き込まれている場合には、この情報に基づいて、論理セクタ領域と物理セクタ領域60の対応関係を示すテーブルが作成される。   The sector management information is preferably a table showing the correspondence between the logical sector area and the physical sector area 60 as described above, but as a modification, each series of data written in the physical block Start logical sector number (hereinafter referred to as “SLSN”) which is the logical sector number of the logical sector area corresponding to the head data of the data and the number of sector areas in which the series of data is written (from the sector area where the head data is written to the end data) May be information indicating a sector count value that is the number of sector areas up to the sector area to be written (hereinafter referred to as “SCNT”). Further, information indicating the physical sector number (PSN) of the physical sector area where the head data of each series of data is written may be added to these pieces of information. When such information is written, a table showing the correspondence between the logical sector area and the physical sector area 60 is created based on this information.

例えば、図7(A)〜(F)に、セクタ管理情報#0〜#5のそれぞれの変形例であるセクタ管理情報#0´〜#5´をそれぞれ示す。セクタ管理情報#0´〜#5´において、第nのSLSN及びSCNTの組は、第nの一連のデータに対応する。尚、物理ブロック内の物理セクタ領域60に先頭の論理セクタ領域に対応するデータから論理セクタ領域の順番(LSNの順番)で一連のデータが書き込まれている部分については、複数個の一連のデータに対応する部分を1つにまとめた情報にしてもよい。例えば、第1−2の一連のデータに対応する部分を1つにまとめて、SLSNが#0、SCNTが32としてもよい。   For example, FIGS. 7A to 7F show sector management information # 0 ′ to # 5 ′, which are modifications of the sector management information # 0 to # 5, respectively. In the sector management information # 0 ′ to # 5 ′, the set of the nth SLSN and SCNT corresponds to the nth series of data. Note that a part of a series of data written in the order of the logical sector area (LSN order) from the data corresponding to the first logical sector area in the physical sector area 60 in the physical block is a plurality of series of data. The information corresponding to the information may be integrated into one. For example, the portions corresponding to the first-second series of data may be combined into one, and SLSN may be # 0 and SCNT may be 32.

この変形例では、論理セクタ領域と物理セクタ領域60の最新の対応関係を示すテーブルは、最新のセクタ管理情報に基づいて作成される。具体的には、後から書き込まれた一連のデータに対応する論理セクタ領域と物理セクタ領域60の対応関係を優先して、LSN#0−#255の256個の論理セクタ番号に対応したレコードに物理セクタ番号(PSN)を書き込んでいく。尚、論理セクタ領域と物理セクタ領域60の対応関係は、SLPN及びSCNTの組に基づいて把握する。   In this modification, a table indicating the latest correspondence relationship between the logical sector area and the physical sector area 60 is created based on the latest sector management information. Specifically, a record corresponding to 256 logical sector numbers of LSN # 0 to # 255 is given with priority given to the correspondence relationship between the logical sector area and the physical sector area 60 corresponding to a series of data written later. The physical sector number (PSN) is written. The correspondence relationship between the logical sector area and the physical sector area 60 is grasped based on the combination of SLPN and SCNT.

例えば、セクタ管理情報#5´に基づいて、図6(C)に示したような対象テーブルが作成される。このテーブル作成では、それぞれの一連のデータに対応する論理セクタ領域と物理セクタ領域60の対応関係に基づいて、各レコードに物理セクタ番号(PSN)を書き込んでいく。この物理セクタ番号(PSN)の書き込みは、先に書き込まれた一連のデータに対応する方から順番に行われ、書き込み先のレコードに既に物理セクタ番号(PSN)が書き込まれていても、後から物理セクタ番号(PSN)を上書きする。従って、後から書き込まれた一連のデータに対応する論理セクタ領域と物理セクタ領域60の対応関係を優先したテーブルが作成される。   For example, a target table as shown in FIG. 6C is created based on the sector management information # 5 ′. In creating this table, a physical sector number (PSN) is written in each record based on the correspondence between the logical sector area and the physical sector area 60 corresponding to each series of data. The writing of the physical sector number (PSN) is performed in order from the one corresponding to the previously written series of data. Even if the physical sector number (PSN) is already written in the write destination record, the physical sector number (PSN) is written later. The physical sector number (PSN) is overwritten. Accordingly, a table is created in which the correspondence between the logical sector area and the physical sector area 60 corresponding to a series of data written later is prioritized.

<第2の実施形態>。   <Second Embodiment>.

以下、本発明の第2の実施形態を説明する。その際、第1の実施形態との相違点を主に説明し、第1の実施形態との共通点については説明を省略或いは簡略する。   Hereinafter, a second embodiment of the present invention will be described. In that case, the difference from the first embodiment will be mainly described, and the description of the common points with the first embodiment will be omitted or simplified.

第2の実施形態では、論理ブロック内の論理セクタ領域を先頭から順番に1個の物理ページ60に含まれるユーザ領域25の容量と等しいセクタ数単位でまとめたものを論理ページとして取り扱い、ページ単位(1個の物理ページに含まれるユーザ領域25の容量と等しいセクタ数単位)で論理ブロックに含まれる論理ページと物理ブロックに含まれる物理ページとの対応関係を管理する。以下の説明で、各物理ブロック内の物理ページに付けた通し番号を物理ページ番号(PPN)と言う。又、各論理ブロック内の論理ページに付けた通し番号を論理ページ番号(LPN)と言う。   In the second embodiment, logical sector areas in a logical block, which are grouped in units of sectors equal to the capacity of the user area 25 included in one physical page 60 in order from the top, are treated as logical pages. The correspondence relationship between the logical page included in the logical block and the physical page included in the physical block is managed in units (number of sectors equal to the capacity of the user area 25 included in one physical page). In the following description, a serial number assigned to a physical page in each physical block is referred to as a physical page number (PPN). A serial number assigned to a logical page in each logical block is called a logical page number (LPN).

本実施形態では、1個の物理ページが4セクタ(2048バイト)のユーザ領域25で構成され(1個の物理ページに4個の物理セクタ領域60含まれ)、1個の物理ブロックが64個の物理ページで構成されているNAND型フラッシュメモリを用いる。尚、図2に示したように、各物理ページに含まれる4個の物理セクタ領域60については、先頭から順番に(カラムアドレスが小さい方から順番に)、第1物理セクタ領域60a、第2物理セクタ領域60b、第3物理セクタ領域60c、第4物理セクタ領域60dと言う。ここで、PPN#0の物理ページに含まれる第1物理セクタ領域60aがPSN#0の物理セクタ領域に対応し、PPN#0の物理ページに含まれる第2物理セクタ領域60bがPSN#1の物理セクタ領域に対応し、PPN#0の物理ページに含まれる第3物理セクタ領域60cがPSN#2の物理セクタ領域に対応し、PPN#0の物理ページに含まれる第4物理セクタ領域60dがPSN#3の物理セクタ領域に対応する。PPN#1の物理ページに含まれる第1物理セクタ領域60a、第2物理セクタ領域60b、第3物理セクタ領域60c及び第4物理セクタ領域60dには、PSN#4−#7の物理セクタ領域がそれぞれ対応し、以下同様の対応関係で、PPN#63の物理ページに含まれる第1物理セクタ領域60a、第2物理セクタ領域60b、第3物理セクタ領域60c及び第4物理セクタ領域60dには、PSN#252−#255の物理セクタ領域がそれぞれ対応する。   In the present embodiment, one physical page is configured by the user area 25 of 4 sectors (2048 bytes) (4 physical sector areas 60 are included in one physical page), and 64 physical blocks are included. NAND type flash memory composed of physical pages is used. As shown in FIG. 2, with respect to the four physical sector areas 60 included in each physical page, the first physical sector area 60a, the second physical sector area 60a, and second They are referred to as a physical sector area 60b, a third physical sector area 60c, and a fourth physical sector area 60d. Here, the first physical sector area 60a included in the physical page of PPN # 0 corresponds to the physical sector area of PSN # 0, and the second physical sector area 60b included in the physical page of PPN # 0 is PSN # 1. Corresponding to the physical sector area, the third physical sector area 60c included in the physical page of PPN # 0 corresponds to the physical sector area of PSN # 2, and the fourth physical sector area 60d included in the physical page of PPN # 0 is included. This corresponds to the physical sector area of PSN # 3. The first physical sector area 60a, the second physical sector area 60b, the third physical sector area 60c, and the fourth physical sector area 60d included in the physical page of PPN # 1 include the physical sector areas of PSN # 4- # 7. The first physical sector area 60a, the second physical sector area 60b, the third physical sector area 60c, and the fourth physical sector area 60d included in the physical page of the PPN # 63 have the same corresponding relationship. The physical sector areas of PSN # 252- # 255 correspond to each other.

また、各論理ページには4個の論理セクタ領域が含まれる。LPN#0の論理ページには、LSN#0−#3の論理セクタ領域が含まれ、LPN#1の論理ページには、LSN#4−#7の論理セクタ領域が含まれ、以下同様に順次割り当てられ、LPN#63の論理ページには、LSN#252−#255の論理セクタ領域が含まれる。各論理ページに含まれる4個の論理セクタ領域は、各物理ページに含まれる4個の物理セクタ領域(第1物理セクタ領域60a、第2物理セクタ領域60b、第3物理セクタ領域60c及び第4物理セクタ領域60d)に対して、LSNが小さい方から順番に割り当てられる。   Each logical page includes four logical sector areas. The LPN # 0 logical page includes LSN # 0- # 3 logical sector areas, the LPN # 1 logical page includes LSN # 4- # 7 logical sector areas, and so on. The allocated logical page of LPN # 63 includes the logical sector area of LSN # 252- # 255. The four logical sector areas included in each logical page are divided into four physical sector areas (first physical sector area 60a, second physical sector area 60b, third physical sector area 60c, and fourth physical area included in each physical page. The physical sector area 60d) is assigned in order from the smallest LSN.

第2の実施形態では、論理ページと物理ページとの対応関係は変化するが、物理ページ内の4個の物理セクタ領域60と論理ページ内の4個の論理セクタ領域の相対的な関係は変化しない。従って、第2の実施形態では、論理ページと物理ページとの対応関係を管理することにより、論理ブロックに含まれる256個の論理セクタ領域と物理ブロックに含まれる256個の物理セクタ領域60との対応関係を管理することができる。つまり、本実施形態のように、1個の物理ページに4個の物理セクタ領域60が含まれる場合であれば、PSNの下位2ビットとLSNの下位2ビットが常に一致するように物理セクタ領域60と論理セクタ領域との対応関係が定められている。即ち、下位2ビットが00のLSNに対応したデータは、第1物理セクタ60aに保存され、下位2ビットが01のLSNに対応したデータは第2物理セクタ60bに保存され、下位2ビットが10のLSNに対応したデータは第3物理セクタに保存され、下位2ビットが11のLSNに対応したデータは第4物理セクタに保存される。尚、論理ページ番号(LPN)は、8ビットのLSNの上位6ビットに対応し、物理ページ番号は8ビットのPSNの上位6ビットに対応する。   In the second embodiment, the correspondence relationship between the logical page and the physical page changes, but the relative relationship between the four physical sector areas 60 in the physical page and the four logical sector areas in the logical page changes. do not do. Therefore, in the second embodiment, by managing the correspondence between logical pages and physical pages, 256 logical sector areas included in the logical block and 256 physical sector areas 60 included in the physical block are Correspondence can be managed. That is, as in the present embodiment, if four physical sector areas 60 are included in one physical page, the physical sector area so that the lower 2 bits of the PSN and the lower 2 bits of the LSN always match. Correspondence between 60 and the logical sector area is defined. That is, the data corresponding to the LSN whose lower 2 bits are 00 is stored in the first physical sector 60a, the data corresponding to the LSN whose lower 2 bits are 01 is stored in the second physical sector 60b, and the lower 2 bits are 10 The data corresponding to the LSN is stored in the third physical sector, and the data corresponding to the LSN having the lower 2 bits of 11 is stored in the fourth physical sector. The logical page number (LPN) corresponds to the upper 6 bits of the 8-bit LSN, and the physical page number corresponds to the upper 6 bits of the 8-bit PSN.

以下、本実施形態での書き込みの概要を説明する。   Hereinafter, an outline of writing in this embodiment will be described.

メモリコントローラ3は、ホストシステム4から与えられる書き込み指示(書き込みコマンド及び書き込み先のアドレス)に従って、この書き込み指示と共に与えられる一連のデータを、フラッシュメモリ2に書き込む。この書き込み処理では、書き込み先の論理ページが属する論理ブロックが特定され、その論理ブロックに対応する物理ブロック(又は、この論理ブロックに対して新たに割り当てた物理ブロック)に、一連のデータが書き込まれる。物理ブロック内の物理ページには、先頭から順番に(つまりPPNが小さいほうから順番に)一連のデータが書き込まれていく。従って、一連のデータを書き込むときには、物理ブロック内のデータが書き込まれている物理ページの末尾の検索が行われる。そして、その末尾の物理ページの次の物理ページから一連のデータが順次書き込まれていく。言い換えれば、物理ブロック内のデータが書き込まれていない先頭の物理ページから一連のデータが順次書き込まれていく。   The memory controller 3 writes a series of data given together with the write instruction to the flash memory 2 in accordance with a write instruction (write command and write destination address) given from the host system 4. In this writing process, the logical block to which the logical page to be written belongs is specified, and a series of data is written to the physical block corresponding to the logical block (or a physical block newly assigned to the logical block). . A series of data is written to the physical pages in the physical block in order from the top (that is, in order from the smallest PPN). Therefore, when writing a series of data, the end of the physical page in which the data in the physical block is written is searched. Then, a series of data is sequentially written from the physical page next to the last physical page. In other words, a series of data is sequentially written from the first physical page in which data in the physical block is not written.

本実施形態では、一連のデータの末尾データが書き込まれた物理ページの次の物理ページに、論理ページと物理ページの対応関係を示す情報(以下、「ページ管理情報」と言う)、例えば、論理ページと物理ページの対応関係を示すテーブルを書き込んでいる。つまり、ページ管理情報は、ホストシステム4から書き込み指示と共に与えられる一連のデータと同様に、物理ページのユーザ領域25に書き込まれる。従って、物理ブロック内のデータが書き込まれている物理ページの末尾の検索し、その物理ページからページ管理情報を読み出すことにより、論理ページと物理ページの対応関係を把握することができる。本実施形態では、ページ管理情報は、例えば、64個の論理ページの論理ページ番号にそれぞれ対応する64個のレコードを有するテーブルである(例えば、後述の図9(A)参照)。   In the present embodiment, information indicating the correspondence between a logical page and a physical page (hereinafter referred to as “page management information”), such as logical A table indicating the correspondence between pages and physical pages is written. That is, the page management information is written in the user area 25 of the physical page, like the series of data given from the host system 4 together with the write instruction. Therefore, the correspondence between the logical page and the physical page can be grasped by searching the end of the physical page in which data in the physical block is written and reading the page management information from the physical page. In the present embodiment, the page management information is, for example, a table having 64 records respectively corresponding to the logical page numbers of 64 logical pages (for example, see FIG. 9A described later).

尚、物理ブロック内のデータが書き込まれている末尾の物理ページには、論理ページと物理ページの対応関係に関する最新のページ管理情報を保存しておく必要がある。従って、一連のデータを書き込む際には、その一連のデータを書き込む物理ブロック内のデータが書き込まれている末尾の物理ページからページ管理情報を読み出し、このページ管理情報を更新した最新のページ管理情報を、その一連のデータの末尾データが書き込まれた物理ページの次の物理ページに書き込む。このページ管理情報の更新では、書き込む一連のデータに対応する部分について、読み出されたページ管理情報の内容が更新される。尚、物理ページにページ管理情報を書き込む場合、物理ブロック内のデータが書き込まれている末尾の物理ページに記憶されているデータがページ管理情報であるか否かを判別可能にするために、本実施形態では、ページ管理情報の書込み先の物理ページの共通冗長領域50に、ページ管理情報が書き込まれたことを意味するフラグ(以下、「管理フラグ」と言う)を書き込む。これにより、物理ブロック内のデータが書き込まれている末尾の物理ページの共通冗長領域50に、管理フラグが記憶されていれば、その末尾の物理ページに記憶されているデータは、ページ管理情報であり、管理フラグが記憶されていなければ、その末尾の物理ページに記憶されているデータは、一連のデータの末尾データであることがわかる。   Note that the latest page management information related to the correspondence between the logical page and the physical page needs to be stored in the last physical page in which the data in the physical block is written. Therefore, when writing a series of data, the page management information is read from the last physical page in which the data in the physical block to which the series of data is written is written, and the latest page management information updated with this page management information Are written in the physical page next to the physical page in which the end data of the series of data is written. In the update of the page management information, the content of the read page management information is updated for a portion corresponding to a series of data to be written. Note that when page management information is written to a physical page, in order to be able to determine whether or not the data stored in the physical page at the end where the data in the physical block is written is page management information. In the embodiment, a flag (hereinafter referred to as “management flag”) indicating that page management information has been written is written in the common redundant area 50 of the physical page to which page management information is written. Thus, if the management flag is stored in the common redundant area 50 of the last physical page in which the data in the physical block is written, the data stored in the last physical page is the page management information. If the management flag is not stored, the data stored in the last physical page is the last data of a series of data.

また、同一の物理ブロックに複数の一連のデータを連続的に書き込むような場合には、物理ブロック内のデータが書き込まれている末尾の物理ページからページ管理情報を読み出さずに、ワークエリア8に保持されている、論理ページと物理ページの対応関係に関する情報を、そのまま使用するようにしてもよい。   Further, when a plurality of series of data is continuously written in the same physical block, the page management information is not read from the last physical page in which the data in the physical block is written, and the work area 8 is read. The information regarding the correspondence between the logical page and the physical page that is held may be used as it is.

また、物理ブロック内に書き込まれている全てのデータが、先頭の論理ページに対応するデータから論理ページの順番(LPNの順番)で各物理ページに格納されている場合には、一連のデータの末尾データが書き込まれた物理ページの次の物理ページに、ページ管理情報を書き込まないようにしてもよい。そして、このように物理ブロック内のデータが書き込まれている末尾の物理ページにページ管理情報が書き込まれていない場合、つまり、物理ブロック内のデータが書き込まれている末尾の物理ページに一連のデータの末尾データが書き込まれている場合、その物理ブロックには先頭の論理ページに対応するデータから論理ページの順番(LPNの順番)でデータが格納されていると判断して、論理ページと物理ページの対応関係を把握する。   If all data written in a physical block is stored in each physical page in the order of logical pages (LPN order) from the data corresponding to the first logical page, a series of data The page management information may not be written in the physical page next to the physical page in which the tail data is written. If page management information is not written to the last physical page in which data in the physical block is written in this way, that is, a series of data in the last physical page in which data in the physical block is written. Is written in the physical block, it is determined that data is stored in the logical page order (LPN order) from the data corresponding to the first logical page. To understand the correspondence of

ホストシステム4から与えられる書き込み指示と共に与えられる複数ページ分のデータを書き込み先の物理ブロック内の空きページに全て書き込むことができない場合には、その物理ブロック内の最後尾の物理ページの1ページ前の物理ページまで、ホストシステム4から与えられるデータを書き込み、末尾の物理ページには、その時点での論理ページと物理ページの対応関係を示すページ管理情報を書き込む。残りのデータについては、別の物理ブロックを新たに割り当て、その物理ブロック内の物理ページに書き込み、残りのデータの末尾データが書き込まれた物理ページの次の物理ページに、その時点での論理ページと物理ページの対応関係を示すページ管理情報を書き込む。このように1個の論理ブロックに対して2個の物理ブロックが割り当てられたような場合、後から割り当てられた物理ブロック(2個目の物理ブロック)には、2個の物理ブロックを合わせた論理ページと物理ページの対応関係を示すページ管理情報、つまり、1個目の物理ブロック内の論理ページと物理ページの対応関係を示す情報を含めたページ管理情報が書き込まれる。尚、1個目の物理ブロックにおいて、一連のデータの末尾データが書き込まれた物理ページの次の物理ページが、1個目の物理ブロックの最後尾の物理ページの1ページ前の物理ページである場合、次の一連のデータは、その最後尾の物理ページからではなく、2個目の物理ブロックの先頭の物理ページから書き込む。   If all of the data for a plurality of pages given together with the write instruction given from the host system 4 cannot be written to the empty pages in the write destination physical block, one page before the last physical page in the physical block The data given from the host system 4 is written up to the physical page, and page management information indicating the correspondence between the logical page and the physical page at that time is written into the last physical page. For the remaining data, another physical block is newly allocated, written to the physical page in the physical block, and the physical page next to the physical page in which the last data of the remaining data is written is the current logical page. And page management information indicating the correspondence between physical pages. When two physical blocks are allocated to one logical block in this way, the two physical blocks are combined with the physical block allocated later (second physical block). Page management information indicating the correspondence between logical pages and physical pages, that is, page management information including information indicating the correspondence between logical pages and physical pages in the first physical block is written. In the first physical block, the physical page next to the physical page in which the end data of the series of data is written is the physical page one page before the last physical page of the first physical block. In this case, the next series of data is written not from the last physical page but from the first physical page of the second physical block.

物理ブロックから各物理ページに格納されているデータを読み出すときには、物理ブロック内のデータが書き込まれている末尾の物理ページからページ管理情報を読み出し、このページ管理情報に基づいて論理ページと物理ページの対応関係を把握する。   When reading the data stored in each physical page from the physical block, the page management information is read from the last physical page where the data in the physical block is written, and the logical page and physical page are read based on this page management information. Know the correspondence.

以下、図8乃至図10を参照して、本実施形態での書き込みの具体例を説明する。なお、一連のデータは、前述したように、PPNが小さい方から順番に書き込まれるが、以下、n番目(nは自然数)に書き込まれる一連のデータを「第nの一連のデータ」と言う。また、以下の説明では、アクセス対象の論理ページ(一連のデータの先頭データに対応する論理セクタ領域が属する論理ページから一連のデータの末尾データに対応する論理セクタ領域が属する論理ページまでの1個または複数個の論理ページ)を「論理アクセスページ」と言う。また、この具体例では、図8(A)に示すように、論理ブロックにPBA#7の物理ブロックが割り当てられているとする。   A specific example of writing in the present embodiment will be described below with reference to FIGS. As described above, a series of data is written in order from the smallest PPN. Hereinafter, a series of data written in the nth (n is a natural number) is referred to as an “nth series of data”. Further, in the following description, one logical page to be accessed (one logical page from the logical page to which the logical sector area corresponding to the first data of the series of data belongs to the logical page to which the logical sector area corresponding to the last data of the series of data belongs) Or a plurality of logical pages) is called a “logical access page”. In this specific example, it is assumed that a physical block of PBA # 7 is allocated to the logical block as shown in FIG.

まず、ホストシステム4からの第1の書き込み指示から、論理アクセスページとして、LBN#0の論理ブロック内のLPN#0−#7の8個の論理ページを特定する。また、LBN#0の論理ブロックに対応する物理ブロックが無いため、LBN#0の論理ブロックに対応してPBA#7の物理ブロックが割り当てる。この物理ブロックには未だデータが書き込まれていないため、物理ブロック内のデータが書き込まれていない先頭の物理ページとして、PBA#7の物理ブロック内の先頭の物理ページ(PPN#0の物理ページ)を特定する。この先頭の物理ページ(PPN#0の物理ページ)から、ホストシステム4から与えられた一連のデータを書き込む。この結果、LPN#0−#7の8個の論理ページに対応する第1の一連のデータが、PPN#0−#7の8個の物理ページに書き込まれる(図8(A)参照)。この書き込み処理を開始するときに、一連のデータの先頭データに対応する論理ページのLPNの値と、この先頭データが書き込まれる物理ページのPPNの値が一致しているため、この書き込み処理で、先頭の論理ページに対応するデータから論理ページの順番(LPNの順番)で一連のデータが書き込まれる判断することができる。   First, eight logical pages LPN # 0- # 7 in a logical block of LBN # 0 are specified as logical access pages from the first write instruction from the host system 4. Further, since there is no physical block corresponding to the logical block of LBN # 0, the physical block of PBA # 7 is allocated corresponding to the logical block of LBN # 0. Since data is not yet written in this physical block, the first physical page in the physical block of PBA # 7 (physical page of PPN # 0) is the first physical page in which no data in the physical block is written. Is identified. A series of data given from the host system 4 is written from this first physical page (physical page of PPN # 0). As a result, the first series of data corresponding to the eight logical pages of LPN # 0 to # 7 is written to the eight physical pages of PPN # 0 to # 7 (see FIG. 8A). When starting this writing process, the LPN value of the logical page corresponding to the head data of a series of data matches the PPN value of the physical page to which the head data is written. It can be determined that a series of data is written in the order of logical pages (LPN order) from the data corresponding to the first logical page.

この段階では、PBA#7の物理ブロック内に書き込まれている全てのデータが、先頭の論理ページ(LPN#0の論理ページ)に対応するデータからLPNの小さい順で各物理ページに格納されている。従って、第1の一連のデータの末尾データが記憶されている物理ページ(PPN#7の物理ページ)の次の物理ページ(PPN#8の物理ページ)に、ページ管理情報を書き込まない。   At this stage, all the data written in the physical block of PBA # 7 is stored in each physical page in the order of the LPN from the data corresponding to the first logical page (LPN # 0 logical page). Yes. Accordingly, the page management information is not written to the physical page (PPN # 8 physical page) next to the physical page (PPN # 7 physical page) in which the tail data of the first series of data is stored.

次に、ホストシステム4からの第2の書き込み指示から、論理アクセスページとして、LBN#0の論理ブロック内のLPN#8−#15の8個の論理ページを特定する。また、LBN#0の論理ブロックと対応するPBA#7の物理ブロック内のデータが書き込まれている末尾の物理ページとして、PPN#7の物理ページを特定する。特定された末尾の物理ページ(PPN#7の物理ページ)の次の物理ページ(PPN#8の物理ページ)から、ホストシステム4から与えられた一連のデータを書き込む。この結果、LPN#8−#15の8個の論理ページに対応する第2の一連のデータが、PPN#8−#15の8個の物理ページに書き込まれる(図8(A)参照)。この書き込み処理を開始するときに、物理ブロック内のデータが書き込まれている末尾の物理ページ(PPN#7の物理ページ)にページ管理情報が書き込まれていないため、この時点で、物理ブロック内の物理ページに先頭の論理ページに対応するデータから論理ページの順番(LPNの順番)で一連のデータが書き込まれていると判断することができる。更に、この書き込み処理で書き込まれる一連のデータの先頭データに対応する論理ページのLPNの値と、この先頭データが書き込まれる物理ページのPPNの値が一致しているため、この一連のデータを書き込んだ後も、この状態が維持されると判断することができる。   Next, from the second write instruction from the host system 4, eight logical pages LPN # 8- # 15 in the logical block of LBN # 0 are specified as logical access pages. Further, the physical page of PPN # 7 is specified as the last physical page in which the data in the physical block of PBA # 7 corresponding to the logical block of LBN # 0 is written. A series of data given from the host system 4 is written from the physical page (physical page of PPN # 8) next to the identified last physical page (physical page of PPN # 7). As a result, the second series of data corresponding to the eight logical pages of LPN # 8- # 15 is written to the eight physical pages of PPN # 8- # 15 (see FIG. 8A). When this writing process is started, the page management information is not written in the last physical page (PPN # 7 physical page) in which data in the physical block is written. It can be determined that a series of data is written in the physical page order (LPN order) from the data corresponding to the first logical page in the physical page. Further, since the LPN value of the logical page corresponding to the top data of the series of data written by this writing process matches the PPN value of the physical page to which the top data is written, this series of data is written. After that, it can be determined that this state is maintained.

この段階でも、PBA#7の物理ブロック内のデータが書き込まれている全ての物理ページで、物理ページのPPNとその物理ページに記憶されているデータに対応した論理ページのLPNとが同じ番号である。従って、第2の一連のデータの末尾データが記憶されている物理ページ(PPN#15の物理ページ)の次の物理ページ(PPN#16の物理ページ)にも、ページ管理情報を書き込まない。   Even at this stage, in all the physical pages in which data in the physical block of PBA # 7 is written, the PPN of the physical page and the LPN of the logical page corresponding to the data stored in the physical page have the same number. is there. Accordingly, the page management information is not written in the physical page (physical page of PPN # 16) next to the physical page (physical page of PPN # 15) in which the tail data of the second series of data is stored.

次に、ホストシステム4からの第3の書き込み指示から、論理アクセスページとして、LBN#0の論理ブロック内のLPN#16−#31の16個の論理ページを特定する。また、LBN#0の論理ブロックと対応するPBA#7の物理ブロック内のデータが書き込まれている末尾の物理ページとして、PPN#15の物理ページを特定する。特定された末尾の物理ページ(PPN#15の物理ページ)の次の物理ページ(PPN#16の物理ページ)から、ホストシステム4から与えられた一連のデータを書き込む。この結果、LPN#16−#31の16個の論理ページに対応する第3の一連のデータが、PPN#16−#31の16個の物理ページに書き込まれる(図8(A)参照)。この書き込み処理を開始するときに、物理ブロック内のデータが書き込まれている末尾の物理ページ(PPN#15の物理ページ)にページ管理情報が書き込まれていないため、この時点で、物理ブロック内の物理ページに先頭の論理ページに対応するデータから論理ページの順番(LPNの順番)で一連のデータが書き込まれていると判断することができる。更に、この書き込み処理で書き込まれる一連のデータの先頭データに対応する論理ページのLPNの値と、この先頭データが書き込まれる物理ページのPPNの値が一致しているため、この一連のデータを書き込んだ後も、この状態が維持されると判断することができる。   Next, from the third write instruction from the host system 4, 16 logical pages LPN # 16- # 31 in the logical block of LBN # 0 are specified as logical access pages. Also, the physical page of PPN # 15 is specified as the last physical page in which the data in the physical block of PBA # 7 corresponding to the logical block of LBN # 0 is written. A series of data given from the host system 4 is written from the physical page (physical page of PPN # 16) next to the identified last physical page (physical page of PPN # 15). As a result, the third series of data corresponding to the 16 logical pages of LPN # 16- # 31 is written to the 16 physical pages of PPN # 16- # 31 (see FIG. 8A). When this writing process is started, the page management information is not written in the last physical page (PPN # 15 physical page) in which data in the physical block is written. It can be determined that a series of data is written in the physical page order (LPN order) from the data corresponding to the first logical page in the physical page. Further, since the LPN value of the logical page corresponding to the top data of the series of data written by this writing process matches the PPN value of the physical page to which the top data is written, this series of data is written. After that, it can be determined that this state is maintained.

この段階でも、PBA#7の物理ブロック内のデータが書き込まれている全ての物理ページで、物理ページのPPNとその物理ページに記憶されているデータに対応した論理ページのLPNとが同じ番号である。従って、第3の一連のデータの末尾データが記憶されている物理ページ(PPN#31の物理ページ)の次の物理ページ(PPN#32の物理ページ)にも、ページ管理情報を書き込まない。   Even at this stage, in all the physical pages in which data in the physical block of PBA # 7 is written, the PPN of the physical page and the LPN of the logical page corresponding to the data stored in the physical page have the same number. is there. Therefore, the page management information is not written to the physical page (physical page of PPN # 32) next to the physical page (physical page of PPN # 31) in which the tail data of the third series of data is stored.

次に、ホストシステム4からの第4の書き込み指示から、論理アクセスページとして、LBN#0の論理ブロック内のLPN#48−#63の16個の論理ページを特定する。また、LBN#0の論理ブロックに対応するPBA#7の物理ブロック内のデータが書き込まれている末尾の物理ページとして、PPN#31の物理ページを特定する。特定された末尾の物理ページ(PPN#31の物理ページ)の次の物理ページ(PPN#32の物理ページ)から、ホストシステム4から与えられた一連のデータを書き込む。この結果、LPN#48−#63の16個の論理ページに対応する第4の一連のデータが、PPN#32−#47の16個の物理ページに書き込まれる(図8(A)参照)。この書き込み処理を開始するときに、物理ブロック内のデータが書き込まれている末尾の物理ページ(PPN#31の物理ページ)にページ管理情報が書き込まれていないため、この時点で、物理ブロック内の物理ページに先頭の論理ページに対応するデータから論理ページの順番(LPNの順番)で一連のデータが書き込まれていると判断することができる。しかし、この書き込み処理で書き込まれる一連のデータの先頭データに対応する論理ページのLPNの値と、この先頭データが書き込まれる物理ページのPPNの値が一致していないため、この一連のデータを書き込んだ後は、この状態が維持されないと判断することができる。   Next, from the fourth write instruction from the host system 4, 16 logical pages LPN # 48- # 63 in the logical block of LBN # 0 are specified as logical access pages. Further, the physical page of PPN # 31 is specified as the last physical page in which data in the physical block of PBA # 7 corresponding to the logical block of LBN # 0 is written. A series of data given from the host system 4 is written from the physical page (physical page of PPN # 32) next to the identified last physical page (physical page of PPN # 31). As a result, the fourth series of data corresponding to the 16 logical pages of LPN # 48- # 63 is written to the 16 physical pages of PPN # 32- # 47 (see FIG. 8A). When this writing process is started, page management information is not written in the last physical page (physical page of PPN # 31) in which data in the physical block is written. It can be determined that a series of data is written in the physical page order (LPN order) from the data corresponding to the first logical page in the physical page. However, since the LPN value of the logical page corresponding to the top data of the series of data written by this writing process does not match the PPN value of the physical page to which the top data is written, this series of data is written. After that, it can be determined that this state is not maintained.

この段階になって、PBA#7の物理ブロック内のデータが書き込まれている全ての物理ページの一部(すなわち、第4の一連のデータが記憶されているPPN#32−#47の16個の物理ページ)で、物理ページのPPNとその物理ページに記憶されているデータに対応した論理ページのLPNとが異なる番号となる。この場合、メモリコントローラ3が、物理ブロック内のデータが書き込まれている全ての物理ページ(PPN#0−#47の物理ページ)と論理ページとの対応関係を示すページ管理情報#0を作成する。ここでは、第4の一連のデータを書き込む前の末尾の物理ページ(PPN#31の物理ページ)に、ページ管理情報が書き込まれていないため(その末尾の物理ページの共通冗長領域50に管理フラグが書き込まれていないため)、新規にページ管理情報を作成する。具体的には、ワークエリア8上にLPN#0−63にそれぞれ対応する64個のレコードを有するテーブル作成領域を確保し、このテーブル作成領域にPPNを書き込んでいく。ページ管理情報#0の場合には、図9(A)に示すように、LPN#48−63に対応した16個のレコードに、第4の一連のデータが書き込まれた16個の物理ページに対応するPPN#32−#47を書き込む。また、第4の一連のデータの先頭データが書き込まれているPPN#32の物理ページよりも前の物理ページには先頭の論理ページに対応するデータから論理ページの順番でデータが格納されていると判断して、LPN#0−#31に対応した32個のレコードに、PPN#0−31を書き込む。これにより、ページ管理情報#0の作成が完了する。メモリコントローラ3は、作成したページ管理情報#0を、第4の一連のデータの末尾データが書き込まれている物理ページ(PPN#47の物理ページ)の次の物理ページ(PPN#48の物理ページ)に書き込む。また、ページ管理情報#0が書き込まれた物理ページ(PPN#48の物理ページ)の共通冗長領域50に、管理フラグを書き込む。   At this stage, a part of all physical pages in which data in the physical block of PBA # 7 is written (that is, 16 PPN # 32 to # 47 in which the fourth series of data is stored) The physical page PPN and the logical page LPN corresponding to the data stored in the physical page have different numbers. In this case, the memory controller 3 creates page management information # 0 indicating the correspondence between all physical pages (PPN # 0 to # 47 physical pages) in which data in the physical block is written and logical pages. . Here, since the page management information is not written in the last physical page (PPN # 31 physical page) before the fourth series of data is written (the management flag in the common redundant area 50 of the last physical page). ) Is created, page management information is newly created. Specifically, a table creation area having 64 records respectively corresponding to LPN # 0-63 is secured on the work area 8, and the PPN is written into this table creation area. In the case of page management information # 0, as shown in FIG. 9A, 16 physical pages in which a fourth series of data has been written in 16 records corresponding to LPN # 48-63. Write the corresponding PPN # 32- # 47. In addition, data is stored in the order of logical pages from the data corresponding to the first logical page in the physical page before the physical page of PPN # 32 in which the first data of the fourth series of data is written. Therefore, PPN # 0-31 is written in 32 records corresponding to LPN # 0- # 31. Thereby, the creation of the page management information # 0 is completed. The memory controller 3 uses the created page management information # 0 as the physical page (PPN # 48 physical page) next to the physical page (PPN # 47 physical page) in which the tail data of the fourth series of data is written. ). Further, the management flag is written in the common redundant area 50 of the physical page (PPN # 48 physical page) in which the page management information # 0 is written.

尚、後述するように、一度でもページ管理情報を書き込んだ物理ブロックについては、その物理ブロックに一連のデータを書き込む都度に、一連のデータの末尾データが書き込まれている物理ページの次の物理ページに、ページ管理情報を書き込む。   As will be described later, for a physical block in which page management information has been written even once, each time a series of data is written to the physical block, the physical page next to the physical page in which the end data of the series of data is written To write page management information.

次に、ホストシステム4からの第5の書き込み指示から、論理アクセスページとして、LBN#0の論理ブロック内のLPN#32−#47の16個の論理ページを特定する。また、LBN#0の論理ブロックに対応するPBA#7の物理ブロック内のデータが書き込まれている末尾の物理ページとして、PPN#48の物理ページを特定する。特定された末尾の物理ページ(PPN#48の物理ページ)の次の物理ページ(PPN#49の物理ページ)から、ホストシステム4から与えられた一連のデータを書き込む。   Next, from the fifth write instruction from the host system 4, 16 logical pages LPN # 32- # 47 in the logical block of LBN # 0 are specified as logical access pages. Further, the physical page of PPN # 48 is specified as the last physical page in which the data in the physical block of PBA # 7 corresponding to the logical block of LBN # 0 is written. A series of data given from the host system 4 is written from the physical page (physical page of PPN # 49) next to the identified last physical page (physical page of PPN # 48).

しかし、ここでは、ホストシステム4から与えられた一連のデータをPBA#7の物理ブロック内の空きページに全て書き込むことはできない。なぜなら、ホストシステム4かから与えられる一連のデータは、16ページ分のデータであるのに対し、PBA#7の物理ブロック内の空きページの数は、PPN#49−#63の15ページと、1ページ不足するからである。更に、物理ブロック内のデータが書き込まれている末尾の物理ページ(PSN#48の物理ページ)にページ管理情報が書き込まれているため、この時点で、物理ブロック内の物理セクタ領域60に先頭の論理セクタ領域に対応するデータから論理セクタ領域の順番(LPNの順番)で一連のデータが書き込まれていないと判断することができる。従って、ページ管理情報を書き込む物理ページを考慮すれば2ページ不足していると判断することができる。   However, in this case, a series of data given from the host system 4 cannot be written in all the empty pages in the physical block of PBA # 7. Because the series of data given from the host system 4 is data for 16 pages, the number of free pages in the physical block of PBA # 7 is 15 pages of PPN # 49- # 63, This is because one page is insufficient. Further, since the page management information is written in the last physical page (PSN # 48 physical page) in which data in the physical block is written, at this time, the top in the physical sector area 60 in the physical block. It can be determined that a series of data is not written in the order of the logical sector areas (LPN order) from the data corresponding to the logical sector areas. Therefore, it is possible to determine that two pages are insufficient in consideration of a physical page to which page management information is written.

そこで、この場合、PBA#7の物理ブロック内の最後尾の物理ページ(PPN#63の物理ページ)の1ページ前の物理ページ(PPN#62の物理ページ)まで、ホストシステム4から与えられるデータを書き込む。PBA#7の物理ブロック内の最後尾の物理ページ(PPN#63の物理ページ)には、その時点での論理ページと物理ページの対応関係を表すページ管理情報#1を書き込む。残りのデータについては、図8(B)に示すように、LBN#0の論理ブロックに別の物理ブロック(PBA#16の物理ブロック)を新たに割り当て、そのPBA#16の物理ブロック内の先頭の物理ページ(PPN#0の物理ページ)から書き込み、残りのデータの末尾データが書き込まれた物理ページ(PPN#1の物理ページ)の次の物理ページ(PPN#2の物理ページ)に、その時点での論理ページと物理ページの対応関係を表すページ管理情報#2を書き込む。この結果、ホストシステム4から与えられた16ページ分の一連のデータのうち、14ページ分の一連のデータが、PBA#7の物理ブロック内のPPN#49−#62の物理ページに第5の一連のデータとして書き込まれ(図8(A)参照)、残りの2ページ分の一連のデータが、PBA#16の物理ブロック内のPPN#0−#1の物理ページに第6の一連のデータとして書き込まれる(図8(B)参照)。尚、上述のようにPBA#7の物理ブロック内の空きページに、ホストシステム4から書き込み指示と共に与えられる全てのデータを書き込むことができない場合、その全てのデータを新たに割り当てたPBA#16の物理ブロックに書き込むようにしてもよい。   Therefore, in this case, the data given from the host system 4 up to the physical page one page before the last physical page (physical page of PPN # 63) in the physical block of PBA # 7 (physical page of PPN # 62). Write. In the last physical page (physical page of PPN # 63) in the physical block of PBA # 7, page management information # 1 indicating the correspondence between the logical page and the physical page at that time is written. For the remaining data, as shown in FIG. 8B, another physical block (physical block of PBA # 16) is newly allocated to the logical block of LBN # 0, and the head in the physical block of PBA # 16 To the physical page (PPN # 2 physical page) next to the physical page (PPN # 1 physical page) in which the last data of the remaining data is written. Page management information # 2 representing the correspondence between the logical page and the physical page at the time is written. As a result, among a series of 16 pages of data provided from the host system 4, a series of 14 pages of data is transferred to the fifth physical page of PPN # 49- # 62 in the physical block of PBA # 7. A series of data is written as a series of data (see FIG. 8A), and the series of data for the remaining two pages is the sixth series of data on the physical pages of PPN # 0- # 1 in the physical block of PBA # 16. (See FIG. 8B). Note that, as described above, when all the data given together with the write instruction from the host system 4 cannot be written to the empty page in the physical block of PBA # 7, all the data of PBA # 16 to which all the data is newly allocated are written. You may make it write in a physical block.

尚、前述したページ管理情報#1及び#2は、それぞれ、以下のようにして作成される。   The page management information # 1 and # 2 described above are created as follows.

すなわち、第5の一連のデータが書き込まれる前の末尾の物理ページ(PPN#48の物理ページ)に、ページ管理情報#0が書き込まれているため(その末尾の物理ページの共通冗長領域50に管理フラグが書き込まれているため)、ページ管理情報#0を読み出し、ページ管理情報#0に基づいてページ管理情報#1を作成する。具体的には、図9(B)に示すように、ページ管理情報#0における、LPN#32−#45に対応するレコードに、第5の一連のデータが書き込まれた14個の物理ページ60に対応したPPN#49−62を書き込むことで、ページ管理情報#1を作成する。尚、作成されたページ管理情報#1は、第5の一連のデータの末尾データが書き込まれている物理ページ(PPN#62の物理ページ)の次の物理ページ(PPN#63の物理ページ)に書き込まれ、ページ管理情報#1が書き込まれた物理ページ(PPN#63の物理ページ)の共通冗長領域50には、管理フラグが書き込まれる。   That is, since page management information # 0 is written in the last physical page (PPN # 48 physical page) before the fifth series of data is written (in the common redundant area 50 of the last physical page). Since the management flag is written), the page management information # 0 is read, and the page management information # 1 is created based on the page management information # 0. Specifically, as shown in FIG. 9B, 14 physical pages 60 in which a fifth series of data is written in records corresponding to LPN # 32- # 45 in page management information # 0. The page management information # 1 is created by writing the PPN # 49-62 corresponding to. The created page management information # 1 is stored in the physical page (physical page of PPN # 63) next to the physical page (physical page of PPN # 62) in which the end data of the fifth series of data is written. A management flag is written in the common redundant area 50 of the physical page (physical page of PPN # 63) in which the page management information # 1 is written.

また、ページ管理情報#2については、ワークエリア8に保持されているページ管理情報#1を用いて作成する。具体的には、図10(A)に示すように、ページ管理情報#1における、LPN#46−#47に対応するレコードに、第6の一連のデータが書き込まれた2個の物理ページ60に対応したPPN#0−1を書き込む。また、それらLPN#46−#47に対応するレコード以外の全てのレコードに、旧ブロックフラグ(図では、「旧ブロックF」と記載する)を書き込む。旧ブロックフラグは、各レコードに書き込まれているPPNが、旧ブロック(本具体例ではPBA#7の物理ブロック)内の物理ページのPPNであるか、又は新ブロック(本具体例ではPBA#16の物理ブロック)内の物理ページのPPNであるかを判断するための情報である。つまり、旧ブロックフラグが書き込まれているレコードに書き込まれているPPNは、旧ブロック(本具体例ではPBA#7の物理ブロック)内の物理ページのPPNであると判断される。つまり、ページ管理情報#2を参照することで、LPN#46−#47の論理ページに対応するデータは、新ブロック(本具体例ではPBA#16の物理ブロック)に書き込まれているが、他の論理ページに対応するデータは、旧ブロックに書き込まれていることがわかる。尚、以上のようにして作成されたページ管理情報#2は、第6の一連のデータの末尾データが書き込まれている物理ページ(新ブロック内のPPN#1の物理ページ)の次の物理ページ(新ブロック内のPPN#2の物理ページ)に書き込まれ、ページ管理情報#2が書き込まれた物理ページ(新ブロック内のPPN#2の物理ページ)の共通冗長領域50には、管理フラグが書き込まれる。   The page management information # 2 is created using the page management information # 1 held in the work area 8. Specifically, as shown in FIG. 10A, two physical pages 60 in which a sixth series of data is written in records corresponding to LPN # 46- # 47 in page management information # 1. PPN # 0-1 corresponding to is written. In addition, the old block flag (described as “old block F” in the figure) is written in all records other than the records corresponding to these LPNs # 46- # 47. The old block flag indicates that the PPN written in each record is the PPN of the physical page in the old block (physical block PBA # 7 in this specific example) or the new block (PBA # 16 in this specific example). This is information for determining whether it is a PPN of a physical page in the physical block). That is, the PPN written in the record in which the old block flag is written is determined to be the PPN of the physical page in the old block (physical block of PBA # 7 in this specific example). In other words, by referring to the page management information # 2, the data corresponding to the logical pages of LPN # 46- # 47 is written in the new block (in this specific example, the physical block of PBA # 16). It can be seen that the data corresponding to the logical page is written in the old block. The page management information # 2 created as described above is the physical page next to the physical page (the physical page of PPN # 1 in the new block) in which the end data of the sixth series of data is written. The management flag is set in the common redundant area 50 of the physical page (physical page of PPN # 2 in the new block) written to (physical page of PPN # 2 in the new block) and the page management information # 2 is written. Written.

尚、本具体例において、PBA#7の物理ブロックとPBA#16の物理ブロックが同一の論理ブロック(LBN#0の論理ブロック)に対応することは、これらの物理ブロックに書き込まれている論理アドレス情報を参照することにより判断することができる。また、これらの物理ブロックの新旧関係を判断するために、先頭物理ページの共通冗長領域50に新旧関係を判断するためシリアル番号を書き込むようにすることが好ましい。また、新ブロックの先頭物理ページの共通冗長領域50や、ページ管理情報が書き込まれた物理ページの共通冗長領域50に、旧ブロックのPBAを書き込むようにしてもよい。このようにすれば、それらの共通冗長領域50を参照することにより、旧ブロックのPBAを把握することができる。   In this specific example, the fact that the physical block of PBA # 7 and the physical block of PBA # 16 correspond to the same logical block (logical block of LBN # 0) means that the logical address written in these physical blocks This can be determined by referring to the information. In order to determine the new / old relationship of these physical blocks, it is preferable to write a serial number in the common redundant area 50 of the first physical page in order to determine the new / old relationship. Further, the PBA of the old block may be written in the common redundant area 50 of the first physical page of the new block or the common redundant area 50 of the physical page in which the page management information is written. In this way, the PBA of the old block can be grasped by referring to those common redundant areas 50.

以後、ホストシステム4から一連のデータの与えられた場合には、新ブロックであるPBA#16の物理ブロックに、その一連のデータと、最新のページ管理情報とが書き込まれる。   Thereafter, when a series of data is given from the host system 4, the series of data and the latest page management information are written in the physical block of the new block PBA # 16.

例えば、LBA#0−#15の16個の論理ページに対応する第7の一連のデータを、PBA#16の物理ブロック内のデータが書き込まれている末尾の物理ページ(PPN#2の物理ページ)の次の物理ページ(PPN#3の物理ページ)から書き込む。また、第7の一連のデータが書き込まれる前の末尾の物理ページ(PPN#2の物理ページ)に書き込まれているページ管理情報#2に基づいて、ページ管理情報#3を作成する。具体的には、図10(B)に示すように、ページ管理情報#2における、LPN#0−#15に対応するレコードに、第7の一連のデータが書き込まれた16個の物理ページに対応したPPN#3−18を書き込み、且つ、それらLPN#0−#15に対応するレコードに書き込まれている旧ブロックフラグを消去する。このようにして作成されたページ管理情報#3を、第7の一連のデータの末尾データが書き込まれている物理ページ(PPN#18の物理ページ)の次の物理ページ(PPN#19の物理ページ)に書き込む。   For example, the seventh series of data corresponding to the 16 logical pages of LBA # 0 to # 15 is the last physical page in which data in the physical block of PBA # 16 is written (physical page of PPN # 2). ) From the next physical page (PPN # 3 physical page). Also, page management information # 3 is created based on page management information # 2 written in the last physical page (PPN # 2 physical page) before the seventh series of data is written. Specifically, as shown in FIG. 10 (B), the page management information # 2 includes 16 physical pages in which a seventh series of data is written in records corresponding to LPN # 0 to # 15. The corresponding PPN # 3-18 is written, and the old block flag written in the record corresponding to the LPN # 0- # 15 is erased. The page management information # 3 created in this way is used as the physical page (PPN # 19 physical page) next to the physical page (PPN # 18 physical page) in which the end data of the seventh series of data is written. ).

さて、この後、論理ブロックに割り当てられた旧ブロック又は新ブロックからデータを読み出すときには、メモリコントローラ3は、新ブロック内のデータが書き込まれている末尾の物理ページ(PPN#19の物理ページ)からページ管理情報#3を読み出し、このページ管理情報#3に基づいて論理ページと物理ページの対応関係を把握する。ここでは、新ブロック内のPPN#3の物理ページに書き込まれているページ管理情報#3が、論理ページと物理ページの最新の対応関係を示しているため、そのページ管理情報#3を参照するだけで、論理ページと物理ページの最新の対応関係を把握することができる。具体的には、LPN#0−#15及び#46−#47の論理ページに対応したデータは、新ブロックに書き込まれており、他の論理ページに対応したデータは、旧ブロックに書き込まれていることを把握することができる。つまり、本実施形態によれば、効率的に、論理ページと物理ページの対応関係を把握することができる。   After that, when data is read from the old block or new block assigned to the logical block, the memory controller 3 starts from the last physical page in which the data in the new block is written (physical page of PPN # 19). The page management information # 3 is read, and the correspondence between the logical page and the physical page is grasped based on the page management information # 3. Here, since the page management information # 3 written in the physical page of PPN # 3 in the new block indicates the latest correspondence between the logical page and the physical page, the page management information # 3 is referred to. Only the latest correspondence relationship between the logical page and the physical page can be grasped. Specifically, data corresponding to the logical pages of LPN # 0- # 15 and # 46- # 47 are written in the new block, and data corresponding to other logical pages are written in the old block. I can grasp that. That is, according to the present embodiment, it is possible to efficiently grasp the correspondence between the logical page and the physical page.

尚、もし、第1の一連のデータが書き込まれてから第4の一連のデータが書き込まれる前までの間に(つまりページ管理情報が全く書き込まれていない場合に)、物理ブロック(旧ブロック又は新ブロック)からデータを読み出すときには、メモリコントローラ3は、先頭の論理ページに対応するデータから論理ページの順番でデータが格納されていると判断して、論理ページと物理ページの対応関係を把握することができる。   If the first series of data is written and before the fourth series of data is written (that is, if no page management information is written), the physical block (the old block or When reading data from the new block), the memory controller 3 determines that the data is stored in the order of logical pages from the data corresponding to the first logical page, and grasps the correspondence between the logical page and the physical page. be able to.

以上が、第二の実施形態の説明である。   The above is the description of the second embodiment.

なお、ページ管理情報は、前述したような、論理ページと物理ページの対応関係を示すテーブルであることが好ましいが、一変形例として、物理ブロックに書き込まれているそれぞれの一連のデータの先頭データに対応する論理ページのLPN(以下、「SLPN」と言う)と、その一連のデータが書き込まれるページ数(先頭データが書き込まれるページから末尾データが書き込まれるページまでのページの個数であるページカウント値、以下、「PCNT」と言う)と、その一連のデータが書き込まれる物理ページが属する物理ブロックを示す情報であってもよい。更に、それぞれの一連のデータの先頭データが書き込まれる物理ページの物理ページ番号(PPN)を示す情報を加えてもよい。このような情報が書き込まれている場合には、この情報に基づいて、論理ページと物理ページの対応関係を示すテーブルが作成される。   The page management information is preferably a table indicating the correspondence between logical pages and physical pages as described above, but as a modification, the top data of each series of data written in the physical block LPN (hereinafter referred to as “SLPN”) of the logical page corresponding to, and the number of pages in which the series of data is written (the page count which is the number of pages from the page where the first data is written to the page where the last data is written) Value (hereinafter referred to as “PCNT”), it may be information indicating a physical block to which a physical page to which the series of data is written belongs. Furthermore, information indicating the physical page number (PPN) of the physical page in which the top data of each series of data is written may be added. When such information is written, a table indicating the correspondence between logical pages and physical pages is created based on this information.

例えば、図11(A)〜(D)に、ページ管理情報#0〜#3のそれぞれの変形例であるページ管理情報#0´〜#3´をそれぞれ示す。ページ管理情報#0´〜#3´において、第nのSLPN及びPCNTの組は、第nの一連のデータに対応する。また、新ブロックに書き込まれたページ管理情報#2´及び3´において、旧ブロックに書き込まれている一連のデータに対応するSLPN及びPCNTの組には、旧ブロックフラグが関連付けられる。尚、物理ブロック内の物理ページに先頭の論理ページに対応するデータから論理ページの順番(LPNの順番)で一連のデータが書き込まれている部分については、複数個の一連のデータに対応する部分を1つにまとめた情報にしてもよい。例えば、第1−3の一連のデータに対応する部分を1つにまとめて、SLPNが#0、PCNTが32としてもよい。   For example, FIGS. 11A to 11D show page management information # 0 ′ to # 3 ′, which are modifications of the page management information # 0 to # 3, respectively. In the page management information # 0 ′ to # 3 ′, the nth SLPN and PCNT set corresponds to the nth series of data. In the page management information # 2 ′ and 3 ′ written in the new block, an old block flag is associated with a set of SLPN and PCNT corresponding to a series of data written in the old block. For a portion where a series of data is written in the logical page order (LPN order) from the data corresponding to the first logical page to the physical page in the physical block, the portion corresponding to a plurality of series of data May be combined into one piece of information. For example, the portions corresponding to the first to third series of data may be combined into one, and SLPN may be # 0 and PCNT may be 32.

この変形例では、論理ページと物理ページの最新の対応関係を示すテーブルは、最新のページ管理情報に基づいて作成される。具体的には、後から書き込まれた一連のデータに対応する論理ページと物理ページの対応関係を優先して、LPN#0−#63の64個の論理ページ番号(LPN)に対応したレコードに物理ページ番号(PPN)を書き込んでいく。尚、論理ページと物理ページの対応関係は、SLPN及びPCNTの組に基づいて把握する。   In this modification, a table indicating the latest correspondence between logical pages and physical pages is created based on the latest page management information. Specifically, the records corresponding to the 64 logical page numbers (LPN) of LPN # 0 to # 63 are given priority in correspondence with the logical page and physical page corresponding to a series of data written later. The physical page number (PPN) is written. The correspondence relationship between the logical page and the physical page is grasped based on the set of SLPN and PCNT.

例えば、ページ管理情報#3´に基づいて、図10(B)に示したようなテーブルが作成される。このテーブル作成では、それぞれの一連のデータに対応する論理ページと物理ページの対応関係に基づいて、各レコードに物理ページ番号(PPN)を書き込んでいく。この物理ページ番号(PPN)の書き込みは、先に書き込まれた一連のデータに対応する方から順番に行われ、書き込み先のレコードに既に物理ページ番号(PPN)が書き込まれていても、後から物理ページ番号(PPN)を上書きする。従って、後から書き込まれた一連のデータに対応する論理ページと物理ページの対応関係を優先したテーブルが作成される。   For example, a table as shown in FIG. 10B is created based on the page management information # 3 ′. In this table creation, a physical page number (PPN) is written in each record based on the correspondence between the logical page and physical page corresponding to each series of data. The writing of the physical page number (PPN) is performed in order from the one corresponding to the previously written series of data. Even if the physical page number (PPN) is already written in the write destination record, the physical page number (PPN) is written later. The physical page number (PPN) is overwritten. Therefore, a table is created that prioritizes the correspondence between logical pages and physical pages corresponding to a series of data written later.

以上、本発明の幾つかの実施形態を説明したが、これらは本発明の説明のための例示であって、本発明の範囲をこれらの実施形態にのみ限定する趣旨ではない。本発明の要旨を逸脱しない範囲内において種々変更を加え得ることは勿論である。   As mentioned above, although several embodiment of this invention was described, these are the illustrations for description of this invention, Comprising: It is not the meaning which limits the scope of the present invention only to these embodiment. Of course, various modifications can be made without departing from the scope of the present invention.

例えば、上記の実施の形態では、論理ブロックに含まれる論理セクタ領域と物理ブロックとに含まれる物理セクタ領域の数は一致していた。しかしながら、論理ブロックに含まれる論理セクタ領域の数を物理ブロックに含まれる物理セクタ領域の数より少なくしてもよい。こうすることで、論理ブロックに含まれる全ての論理セクタ領域に対応するデータを物理ブロックに保存した後であっても、そのデータの書き替えデータを、当該物理ブロックの空き領域(データが書き込まれていない物理セクタ領域又は物理ページ)にデータを保存することができる。これにより効率的なデータの書き換えが可能となる。例えば、論理ブロックに含まれる論理セクタ領域の数と、物理ブロックに含まれる物理セクタ領域の数を、共に2のべき乗で与えられる数にする場合には、論理ブロックに含まれる論理セクタ領域の数を128とし、物理ブロックに含まれる物理セクタ領域の数を256とする。   For example, in the above embodiment, the number of physical sector areas included in the logical block area and the physical block included in the logical block is the same. However, the number of logical sector areas included in the logical block may be smaller than the number of physical sector areas included in the physical block. In this way, even after data corresponding to all logical sector areas included in the logical block is stored in the physical block, the rewrite data of the data is changed to the empty area (data is written in the physical block). The data can be stored in a physical sector area or physical page that is not present. This makes it possible to efficiently rewrite data. For example, when the number of logical sector areas included in the logical block and the number of physical sector areas included in the physical block are both given by powers of 2, the number of logical sector areas included in the logical block Is 128, and the number of physical sector areas included in the physical block is 256.

また、例えば、電源遮断により、セクタ管理情報(ページ管理情報)を書き込む前に書き込み処理が終了してしまうことがあり得るので、セクタ管理情報を書き込んだ物理セクタ領域60に対応する分割冗長領域70(ページ管理情報を書き込んだ物理ページの共通冗長領域50)には、書き込み処理が正常終了したことを示す終了マークを書き込むことが好ましい。また、セクタ管理情報(ページ管理情報)を書き込む必要のない場合(物理ブロック内のデータが書き込まれている全ての物理セクタ領域60(物理ページ)が、その物理ブロックに対応する論理ブロック内の論理セクタ領域(論理ページ)と先頭から順番に対応している場合)には、一連のデータの末尾データが書き込まれた物理セクタ領域60に対応する分割冗長領域70(一連のデータの末尾データが書き込まれた物理ページの共通冗長領域50)に、この終了マークを書き込む。   In addition, for example, the write process may end before the sector management information (page management information) is written due to power shutdown, so the divided redundant area 70 corresponding to the physical sector area 60 in which the sector management information has been written. It is preferable to write an end mark indicating that the writing process has ended normally in the common redundant area 50 of the physical page in which the page management information is written. In addition, when it is not necessary to write sector management information (page management information) (all physical sector areas 60 (physical pages) in which data in a physical block is written are logical in the logical block corresponding to the physical block). In the case of corresponding to the sector area (logical page) in order from the head), the divided redundant area 70 corresponding to the physical sector area 60 in which the end data of the series of data is written (the end data of the series of data is written). This end mark is written in the common redundant area 50) of the physical page.

本発明の第1の実施形態によるフラッシュメモリシステムの概略構成を示すブロック図である。1 is a block diagram showing a schematic configuration of a flash memory system according to a first embodiment of the present invention. フラッシュメモリの物理ページの構成を示す図である。It is a figure which shows the structure of the physical page of flash memory. 論理ブロックと物理ブロックの対応関係を示す図である。It is a figure which shows the correspondence of a logical block and a physical block. 図4(A)は、物理ブロック内の256個の物理セクタ領域のうちの前半部分に対する書き込みの結果の一例を示す。図4(B)は、物理ブロック内の256個の物理セクタ領域のうちの後半部分に対する書き込みの結果の一例を示す。FIG. 4A shows an example of a result of writing to the first half portion of 256 physical sector areas in the physical block. FIG. 4B shows an example of the result of writing to the latter half of the 256 physical sector areas in the physical block. 図5(A)は、図4(A)に示したセクタ管理情報#0の中身を示す。図5(B)は、図4(A)に示したセクタ管理情報#1の中身を示す。図5(C)は、図4(B)に示したセクタ管理情報#2の中身を示す。FIG. 5A shows the contents of sector management information # 0 shown in FIG. FIG. 5B shows the contents of sector management information # 1 shown in FIG. FIG. 5C shows the contents of the sector management information # 2 shown in FIG. 図6(A)は、図4(B)に示したセクタ管理情報#3の中身を示す。図6(B)は、図4(B)に示したセクタ管理情報#4の中身を示す。図6(C)は、図4(B)に示したセクタ管理情報#5の中身を示す。FIG. 6A shows the contents of sector management information # 3 shown in FIG. FIG. 6B shows the contents of the sector management information # 4 shown in FIG. FIG. 6C shows the contents of the sector management information # 5 shown in FIG. 図7(A)は、図5(A)に示したセクタ管理情報#0の変形例を示す。図7(B)は、図5(B)に示したセクタ管理情報#1の変形例を示す。図7(C)は、図5(C)に示したセクタ管理情報#2の変形例を示す。図7(D)は、図6(A)に示したセクタ管理情報#3の変形例を示す。図7(E)は、図6(B)に示したセクタ管理情報#4の変形例を示す。図7(F)は、図6(C)に示したセクタ管理情報#5の変形例を示す。FIG. 7A shows a modification of the sector management information # 0 shown in FIG. FIG. 7B shows a modification of the sector management information # 1 shown in FIG. FIG. 7C shows a modification of the sector management information # 2 shown in FIG. FIG. 7D shows a modification of the sector management information # 3 shown in FIG. FIG. 7E shows a modification of the sector management information # 4 shown in FIG. FIG. 7F shows a modification of the sector management information # 5 shown in FIG. 図8(A)は、同一の論理ブロックに割り当てられた一方の物理ブロックPBA#7に対する書き込みの結果の一例を示す。図8(B)は、同一の論理ブロックに割り当てられた他方の物理ブロックPBA#16に対する書き込みの結果の一例を示す。FIG. 8A shows an example of the result of writing to one physical block PBA # 7 assigned to the same logical block. FIG. 8B shows an example of the result of writing to the other physical block PBA # 16 assigned to the same logical block. 図9(A)は、図8(A)に示したページ管理情報#0の中身を示す。図9(B)は、図8(A)に示したページ管理情報#1の中身を示す。FIG. 9A shows the contents of the page management information # 0 shown in FIG. FIG. 9B shows the contents of the page management information # 1 shown in FIG. 図10(A)は、図8(B)に示したページ管理情報#2の中身を示す。図10(B)は、図8(B)に示したページ管理情報#3の中身を示す。FIG. 10A shows the contents of the page management information # 2 shown in FIG. FIG. 10B shows the contents of the page management information # 3 shown in FIG. 図11(A)は、図9(A)に示したページ管理情報#0の変形例を示す。図11(B)は、図9(B)に示したページ管理情報#1の変形例を示す。図11(C)は、図10(A)に示したページ管理情報#2の変形例を示す。図11(D)は、図10(B)に示したページ管理情報#3の変形例を示す。FIG. 11A shows a modification of the page management information # 0 shown in FIG. FIG. 11B shows a modification of the page management information # 1 shown in FIG. FIG. 11C shows a modification of the page management information # 2 shown in FIG. FIG. 11D shows a modification of the page management information # 3 shown in FIG.

符号の説明Explanation of symbols

1…フラッシュメモリシステム、2…フラッシュメモリ、3…メモリコントローラ、6…マイクロプロセッサ DESCRIPTION OF SYMBOLS 1 ... Flash memory system, 2 ... Flash memory, 3 ... Memory controller, 6 ... Microprocessor

Claims (11)

ホストシステムから与えられるアクセス指示に基づいて、複数個の物理セクタ領域を含む物理ブロック単位で消去が行われるフラッシュメモリに対するアクセスを制御するメモリコントローラであって、
複数個の論理セクタ領域で構成された論理ブロックと前記物理ブロックとの対応関係を管理するブロック管理手段と、
前記アクセス指示によりアクセス対象の領域として指定された論理アクセス領域が属する前記論理ブロックと対応する前記物理ブロック内のデータが書き込まれていない前記物理セクタ領域の先頭を検索する空きセクタ領域検索手段と、
前記アクセス指示により前記論理アクセス領域に対して書き込むことが指示された一連のデータを、前記空きセクタ領域検索手段によって検出されたデータが書き込まれていない先頭の前記物理セクタ領域から、末尾の前記物理セクタ領域に向かって順次書き込んでいくデータ書き込み手段と、
前記データ書き込み手段により前記一連のデータが書き込まれた前記物理ブロック内の前記物理セクタ領域と、前記物理ブロックに対応する前記論理ブロック内の前記論理セクタ領域との対応関係を示すセクタ管理情報を、前記一連のデータの末尾データが書き込まれた前記物理セクタ領域の次の前記物理セクタ領域に書き込むセクタ管理情報書き込み手段と、
を備えることを特徴とするメモリコントローラ。
A memory controller that controls access to a flash memory that is erased in units of physical blocks including a plurality of physical sector areas, based on an access instruction given from a host system,
A block management means for managing a correspondence relationship between a logical block composed of a plurality of logical sector areas and the physical block;
Empty sector area search means for searching for the beginning of the physical sector area in which data in the physical block corresponding to the logical block to which the logical access area specified as the area to be accessed by the access instruction belongs is not written;
A series of data instructed to be written to the logical access area by the access instruction is transferred from the head physical sector area to which the data detected by the free sector area search means is not written, to the physical address at the end. Data writing means for sequentially writing toward the sector area;
Sector management information indicating a correspondence relationship between the physical sector area in the physical block in which the series of data is written by the data writing unit and the logical sector area in the logical block corresponding to the physical block, Sector management information writing means for writing in the physical sector area next to the physical sector area in which the end data of the series of data is written;
A memory controller comprising:
前記セクタ管理情報書き込み手段は、前記データ書き込み手段により前記一連のデータが書き込まれた前記物理ブロック内のデータが書き込まれている全ての前記物理セクタ領域に対して、前記物理ブロックに対応する前記論理ブロック内の前記論理セクタ領域が先頭から順番に対応しているときには、前記一連のデータの末尾データが書き込まれた前記物理セクタ領域の次の前記物理セクタ領域に前記セクタ管理情報を書き込まない、
ことを特徴とする請求項1に記載のメモリコントローラ。
The sector management information writing unit is configured to output the logical block corresponding to the physical block to all the physical sector areas in which data in the physical block in which the series of data has been written by the data writing unit is written. When the logical sector areas in the block correspond in order from the top, the sector management information is not written in the physical sector area next to the physical sector area in which the end data of the series of data is written,
The memory controller according to claim 1.
前記アクセス指示により指定された前記論理アクセス領域が属する前記論理ブロックと対応する前記物理ブロック内の前記物理セクタ領域に記憶されているデータを、前記物理ブロック内のデータが書き込まれている末尾の前記物理セクタ領域に記憶されている前記セクタ管理情報に基づいて読み出すデータ読み出し手段を更に備える、
ことを特徴とする請求項1又は2に記載のメモリコントローラ。
The data stored in the physical sector area in the physical block corresponding to the logical block to which the logical access area specified by the access instruction belongs is changed to the end of the data in which the data in the physical block is written. Further comprising data reading means for reading based on the sector management information stored in the physical sector area,
The memory controller according to claim 1, wherein the memory controller is a memory controller.
前記データ読み出し手段は、前記論理アクセス領域が属する前記論理ブロックと対応する前記物理ブロック内に前記セクタ管理情報が記憶されていないときは、前記物理ブロック内のデータが書き込まれている前記物理セクタ領域に対して、前記物理ブロックに対応する前記論理ブロック内の前記論理セクタ領域が先頭から順番に対応しているとみなして、データの読み出しを行う、
ことを特徴とする請求項3に記載のメモリコントローラ。
When the sector read information is not stored in the physical block corresponding to the logical block to which the logical access area belongs, the physical read area is written with data in the physical block. On the other hand, the logical sector area in the logical block corresponding to the physical block is considered to correspond in order from the top, and data is read.
The memory controller according to claim 3.
ホストシステムから与えられるアクセス指示に基づいて、複数個の物理ページを含む物理ブロック単位で消去が行われるフラッシュメモリに対するアクセスを制御するメモリコントローラであって、
複数個の論理ページで構成された論理ブロックと前記物理ブロックとの対応関係を管理するブロック管理手段と、
前記アクセス指示によりアクセス対象の論理ページとして指定された論理アクセスページが属する前記論理ブロックと対応する前記物理ブロック内のデータが書き込まれていない前記物理ページの先頭を検索する空きページ検索手段と、
前記アクセス指示により前記論理アクセスページに対して書き込むことが指示された一連のデータを、前記空きページ検索手段によって検出されたデータが書き込まれていない先頭の前記物理ページから、末尾の前記物理ページに向かって順次書き込んでいくデータ書き込み手段と、
前記データ書き込み手段により前記一連のデータが書き込まれた前記物理ブロック内の前記物理ページと、前記物理ブロックに対応する前記論理ブロック内の前記論理ページとの対応関係を示すページ管理情報を、前記一連のデータの末尾データが書き込まれた前記物理ページの次の前記物理ページに書き込むページ管理情報書き込み手段と、
を備えることを特徴とするメモリコントローラ。
A memory controller that controls access to a flash memory that is erased in units of physical blocks including a plurality of physical pages, based on an access instruction given from a host system,
Block management means for managing a correspondence relationship between a logical block composed of a plurality of logical pages and the physical block;
Empty page search means for searching for the top of the physical page in which data in the physical block corresponding to the logical block to which the logical access page designated as the logical page to be accessed belongs by the access instruction belongs,
A series of data instructed to be written to the logical access page by the access instruction is transferred from the first physical page to which the data detected by the empty page search unit is not written to the last physical page. Data writing means for sequentially writing toward the
Page management information indicating a correspondence relationship between the physical page in the physical block in which the series of data is written by the data writing unit and the logical page in the logical block corresponding to the physical block; Page management information writing means for writing to the physical page next to the physical page in which the end data of the data is written;
A memory controller comprising:
前記ページ管理情報書き込み手段は、前記データ書き込み手段により前記一連のデータが書き込まれた前記物理ブロック内のデータが書き込まれている全ての前記物理ページに対して、前記物理ブロックに対応する前記論理ブロック内の前記論理ページが先頭から順番に対応しているときには、前記一連のデータの末尾データが書き込まれた前記物理ページの次の前記物理ページに前記ページ管理情報を書き込まない、
ことを特徴とする請求項5に記載のメモリコントローラ。
The page management information writing unit includes the logical block corresponding to the physical block for all the physical pages in which data in the physical block in which the series of data has been written by the data writing unit is written. The page management information is not written to the physical page next to the physical page in which the end data of the series of data is written,
The memory controller according to claim 5.
前記アクセス指示により指定された前記論理アクセスページが属する前記論理ブロックと対応する前記物理ブロック内の前記物理ページに記憶されているデータを、前記物理ブロック内のデータが書き込まれている末尾の前記物理ページに記憶されている前記ページ管理情報に基づいて読み出すデータ読み出し手段を更に備える、
ことを特徴とする請求項5又は6に記載のメモリコントローラ。
The data stored in the physical page in the physical block corresponding to the logical block to which the logical access page specified by the access instruction belongs is changed to the last physical in which the data in the physical block is written. Data reading means for reading based on the page management information stored in the page;
The memory controller according to claim 5, wherein the memory controller is a memory controller.
前記データ読み出し手段は、前記論理アクセスページが属する前記論理ブロックと対応する前記物理ブロック内に前記ページ管理情報が記憶されていないときは、前記物理ブロック内のデータが書き込まれている前記物理ページに対して、前記物理ブロックに対応する前記論理ブロック内の前記論理ページが先頭から順番に対応しているとみなして、データの読み出しを行う、
ことを特徴とする請求項7に記載のメモリコントローラ。
When the page management information is not stored in the physical block corresponding to the logical block to which the logical access page belongs, the data reading means is stored in the physical page in which data in the physical block is written. On the other hand, it is assumed that the logical pages in the logical block corresponding to the physical block correspond in order from the top, and data is read.
The memory controller according to claim 7.
請求項1乃至8のうちのいずれか1項に記載のメモリコントローラと、
前記メモリコントローラによってアクセスされるフラッシュメモリと
を備えるフラッシュメモリシステム。
A memory controller according to any one of claims 1 to 8,
And a flash memory system accessed by the memory controller.
ホストシステムから与えられるアクセス指示に基づいて、複数個の物理セクタ領域を含む物理ブロック単位で消去が行われるフラッシュメモリの制御方法であって、
複数個の論理セクタ領域で構成された論理ブロックと前記物理ブロックとの対応関係を管理するブロック管理ステップと、
前記アクセス指示によりアクセス対象の領域として指定された論理アクセス領域が属する前記論理ブロックと対応する前記物理ブロック内のデータが書き込まれていない前記物理セクタ領域の先頭を検索する空きセクタ領域検索ステップと、
前記アクセス指示により前記論理アクセス領域に対して書き込むことが指示された一連のデータを、前記空きセクタ領域検索ステップで検出されたデータが書き込まれていない先頭の前記物理セクタ領域から、末尾の前記物理セクタ領域に向かって順次書き込んでいくデータ書き込みステップと、
前記データ書き込みステップで前記一連のデータが書き込まれた前記物理ブロック内の前記物理セクタ領域と、前記物理ブロックに対応する前記論理ブロック内の前記論理セクタ領域との対応関係を示すセクタ管理情報を、前記一連のデータの末尾データが書き込まれた前記物理セクタ領域の次の前記物理セクタ領域に書き込むセクタ管理情報書き込みステップと、
を備えることを特徴とするフラッシュメモリの制御方法。
A flash memory control method in which erasure is performed in units of physical blocks including a plurality of physical sector areas based on an access instruction given from a host system,
A block management step for managing a correspondence relationship between a logical block composed of a plurality of logical sector areas and the physical block;
A free sector area search step for searching for the beginning of the physical sector area in which data in the physical block corresponding to the logical block to which the logical access area designated as the access target area by the access instruction belongs is not written;
A series of data instructed to be written to the logical access area by the access instruction is transferred from the first physical sector area to which the data detected in the free sector area search step is not written to the last physical sector. A data writing step of sequentially writing toward the sector area;
Sector management information indicating a correspondence relationship between the physical sector area in the physical block in which the series of data is written in the data writing step and the logical sector area in the logical block corresponding to the physical block, Sector management information writing step for writing to the physical sector area next to the physical sector area in which the end data of the series of data is written;
A method of controlling a flash memory, comprising:
ホストシステムから与えられるアクセス指示に基づいて、複数個の物理ページを含む物理ブロック単位で消去が行われるフラッシュメモリの制御方法であって、
複数個の論理ページで構成された論理ブロックと前記物理ブロックとの対応関係を管理するブロック管理ステップと、
前記アクセス指示によりアクセス対象の論理ページとして指定された論理アクセスページが属する前記論理ブロックと対応する前記物理ブロック内のデータが書き込まれていない前記物理ページの先頭を検索する空きページ検索ステップと、
前記アクセス指示により前記論理アクセスページに対して書き込むことが指示された一連のデータを、前記空きページ検索ステップで検出されたデータが書き込まれていない先頭の前記物理ページから、末尾の前記物理ページに向かって順次書き込んでいくデータ書き込みステップと、
前記データ書き込みステップで前記一連のデータが書き込まれた前記物理ブロック内の前記物理ページと、前記物理ブロックに対応する前記論理ブロック内の前記論理ページとの対応関係を示すページ管理情報を作成し、前記一連のデータの末尾データが書き込まれた前記物理ページの次の前記物理ページに書き込むページ管理情報書き込みステップと、
を備えることを特徴とするフラッシュメモリの制御方法。
A flash memory control method in which erasure is performed in units of physical blocks including a plurality of physical pages based on an access instruction given from a host system,
A block management step for managing a correspondence relationship between a logical block composed of a plurality of logical pages and the physical block;
A free page search step of searching for the top of the physical page in which data in the physical block corresponding to the logical block to which the logical access page designated as the logical page to be accessed by the access instruction belongs is not written;
A series of data instructed to be written to the logical access page by the access instruction is transferred from the first physical page to which the data detected in the empty page search step is not written to the last physical page. A data writing step of sequentially writing toward the
Creating page management information indicating a correspondence relationship between the physical page in the physical block in which the series of data is written in the data writing step and the logical page in the logical block corresponding to the physical block; A page management information writing step for writing to the physical page next to the physical page in which tail data of the series of data is written;
A method of controlling a flash memory, comprising:
JP2007337524A 2007-12-27 2007-12-27 MEMORY CONTROLLER, FLASH MEMORY SYSTEM HAVING MEMORY CONTROLLER, AND FLASH MEMORY CONTROL METHOD Active JP4760826B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2007337524A JP4760826B2 (en) 2007-12-27 2007-12-27 MEMORY CONTROLLER, FLASH MEMORY SYSTEM HAVING MEMORY CONTROLLER, AND FLASH MEMORY CONTROL METHOD

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2007337524A JP4760826B2 (en) 2007-12-27 2007-12-27 MEMORY CONTROLLER, FLASH MEMORY SYSTEM HAVING MEMORY CONTROLLER, AND FLASH MEMORY CONTROL METHOD

Publications (2)

Publication Number Publication Date
JP2009157807A true JP2009157807A (en) 2009-07-16
JP4760826B2 JP4760826B2 (en) 2011-08-31

Family

ID=40961733

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2007337524A Active JP4760826B2 (en) 2007-12-27 2007-12-27 MEMORY CONTROLLER, FLASH MEMORY SYSTEM HAVING MEMORY CONTROLLER, AND FLASH MEMORY CONTROL METHOD

Country Status (1)

Country Link
JP (1) JP4760826B2 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2013174975A (en) * 2012-02-23 2013-09-05 Toshiba Corp Memory system and data writing method for the same

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS6045994A (en) * 1983-08-22 1985-03-12 Tokyo Electric Co Ltd Information storing method by prom
JP2005135007A (en) * 2003-10-28 2005-05-26 Sony Corp Memory management device and memory management method
JP2008299455A (en) * 2007-05-30 2008-12-11 Sony Corp Data storage device and data management method

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS6045994A (en) * 1983-08-22 1985-03-12 Tokyo Electric Co Ltd Information storing method by prom
JP2005135007A (en) * 2003-10-28 2005-05-26 Sony Corp Memory management device and memory management method
JP2008299455A (en) * 2007-05-30 2008-12-11 Sony Corp Data storage device and data management method

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2013174975A (en) * 2012-02-23 2013-09-05 Toshiba Corp Memory system and data writing method for the same

Also Published As

Publication number Publication date
JP4760826B2 (en) 2011-08-31

Similar Documents

Publication Publication Date Title
JP4844639B2 (en) MEMORY CONTROLLER, FLASH MEMORY SYSTEM HAVING MEMORY CONTROLLER, AND FLASH MEMORY CONTROL METHOD
JP5087347B2 (en) Semiconductor memory device and method for controlling semiconductor memory device
JP4666080B2 (en) MEMORY CONTROLLER, FLASH MEMORY SYSTEM HAVING MEMORY CONTROLLER, AND FLASH MEMORY CONTROL METHOD
US8214579B2 (en) Memory controller, flash memory system with memory controller, and method of controlling flash memory
US8667348B2 (en) Data writing method for non-volatile memory module and memory controller and memory storage apparatus using the same
JP4666081B2 (en) MEMORY CONTROLLER, FLASH MEMORY SYSTEM HAVING MEMORY CONTROLLER, AND FLASH MEMORY CONTROL METHOD
JP4702387B2 (en) MEMORY CONTROLLER, FLASH MEMORY SYSTEM HAVING MEMORY CONTROLLER, AND FLASH MEMORY CONTROL METHOD
JP4488048B2 (en) MEMORY CONTROLLER, FLASH MEMORY SYSTEM HAVING MEMORY CONTROLLER, AND FLASH MEMORY CONTROL METHOD
JP4737223B2 (en) MEMORY CONTROLLER, FLASH MEMORY SYSTEM HAVING MEMORY CONTROLLER, AND FLASH MEMORY CONTROL METHOD
JP4366420B2 (en) MEMORY CONTROLLER, FLASH MEMORY SYSTEM HAVING MEMORY CONTROLLER, AND FLASH MEMORY CONTROL METHOD
JP4687720B2 (en) MEMORY CONTROLLER, FLASH MEMORY SYSTEM HAVING MEMORY CONTROLLER, AND FLASH MEMORY CONTROL METHOD
JP4636005B2 (en) MEMORY CONTROLLER, FLASH MEMORY SYSTEM HAVING MEMORY CONTROLLER, AND FLASH MEMORY CONTROL METHOD
JP4743185B2 (en) MEMORY CONTROLLER, FLASH MEMORY SYSTEM HAVING MEMORY CONTROLLER, AND FLASH MEMORY CONTROL METHOD
JP4153535B2 (en) MEMORY CONTROLLER, FLASH MEMORY SYSTEM PROVIDED WITH MEMORY CONTROLLER, AND FLASH MEMORY CONTROL METHOD
JP4760826B2 (en) MEMORY CONTROLLER, FLASH MEMORY SYSTEM HAVING MEMORY CONTROLLER, AND FLASH MEMORY CONTROL METHOD
JP4702703B2 (en) MEMORY CONTROLLER, FLASH MEMORY SYSTEM HAVING MEMORY CONTROLLER, AND FLASH MEMORY CONTROL METHOD
JP2012068765A (en) Memory controller, flash memory system with memory controller, and control method of flash memory
JP4241741B2 (en) Memory controller and flash memory system
JP2010026878A (en) Memory controller, flash memory system equipped with memory controller, and control method of flash memory
JP4636046B2 (en) MEMORY CONTROLLER, FLASH MEMORY SYSTEM HAVING MEMORY CONTROLLER, AND FLASH MEMORY CONTROL METHOD
JP2012068764A (en) Memory controller, nonvolatile memory system with memory controller, and control method of nonvolatile memory
JP4952741B2 (en) MEMORY CONTROLLER, FLASH MEMORY SYSTEM HAVING MEMORY CONTROLLER, AND FLASH MEMORY CONTROL METHOD
JP2009199242A (en) Memory controller, flash memory system equipped with memory controller, and control method for flash memory
JP4235646B2 (en) Memory controller and flash memory system
JP4952742B2 (en) MEMORY CONTROLLER, FLASH MEMORY SYSTEM HAVING MEMORY CONTROLLER, AND FLASH MEMORY CONTROL METHOD

Legal Events

Date Code Title Description
A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20101221

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20110118

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20110224

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20110510

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20110523

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20140617

Year of fee payment: 3

R150 Certificate of patent or registration of utility model

Ref document number: 4760826

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

Free format text: JAPANESE INTERMEDIATE CODE: R150

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250