Links

Images

Classifications

G—PHYSICS

G06—COMPUTING; CALCULATING; COUNTING

G06F—ELECTRIC DIGITAL DATA PROCESSING

G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements

G06F3/06—Digital input from or digital output to record carriers, e.g. RAID, emulated record carriers, networked record carriers

G06F3/0601—Dedicated interfaces to storage systems

G06F3/0628—Dedicated interfaces to storage systems making use of a particular technique

G06F3/0655—Vertical data movement, i.e. input-output transfer; data movement between one or more hosts and one or more storage devices

G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements

G06F3/06—Digital input from or digital output to record carriers, e.g. RAID, emulated record carriers, networked record carriers

G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements

G06F3/06—Digital input from or digital output to record carriers, e.g. RAID, emulated record carriers, networked record carriers

G06F3/0601—Dedicated interfaces to storage systems

G06F3/0628—Dedicated interfaces to storage systems making use of a particular technique

G06F3/0638—Organizing or formatting or addressing of data

G06F3/064—Management of blocks

G—PHYSICS

G06—COMPUTING; CALCULATING; COUNTING

G06F—ELECTRIC DIGITAL DATA PROCESSING

G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements

G06F3/06—Digital input from or digital output to record carriers, e.g. RAID, emulated record carriers, networked record carriers

Description

Translated from Japanese

この発明は、コントローラ、記憶素子を有するメモリカード及びその制御方法に関するものであり、例えば、ホスト機器からのアクセスによりデータの書き込み、読み出し、及び消去を行うメモリカード、メモリカードに搭載されたコントローラ、及びメモリカードの制御方法に関するものである。 The present invention, controller, relates the memory card and a control method thereof having a memory element, for example, data by the access from the host device writing, reading, and memory cards for erasing, the onboard controller to the memory card, and a method for controlling the memory card.

近年、パーソナルコンピュータ、ＰＤＡ、カメラ、携帯電話等の様々な携帯用電子機器においては、リムーバブル記憶デバイスの１つであるメモリカードが多く用いられている。 Recently, personal computers, PDA, cameras, in various portable electronic devices such as mobile phones, memory cards are widely used, which is one of the removable storage device.メモリカードの中には、コントローラを搭載せずＮＡＮＤ型フラッシュメモリだけを搭載したものがある。 In the memory card, there is equipped with only the NAND-type flash memory without mounting the controller.この従来のＮＡＮＤ型フラッシュメモリでは、通常、消去時の消去ブロックサイズが小さく、例えば１６kByteに定められている。 In the conventional NAND flash memory, usually, erase block size at the time of erasing is defined smaller, for example 16 kBytes.

ところで、現在、メモリカードに搭載されるＮＡＮＤ型フラッシュメモリには、大容量で安価な、消去時の消去ブロックサイズが大きいＮＡＮＤ型フラッシュメモリが用いられつつある。 However, currently, the NAND-type flash memory mounted on the memory card, inexpensive, while the used NAND type flash memory is large erase block size at the time of erasing a large capacity.このＮＡＮＤ型フラッシュメモリでは、例えば２５６kByteに消去ブロックサイズが定められている。 In the NAND type flash memory, for example, erase block size 256kByte is defined.このため、ホスト機器が、消去ブロックサイズが小さいＮＡＮＤ型フラッシュメモリであると想定してメモリカードにアクセスしてきた場合、消去ブロックサイズが大きいＮＡＮＤ型フラッシュメモリを搭載したメモリカードは正常に応答することができず、誤動作する原因となっている。 Therefore, the host device, when having accessed the memory card on the assumption that the erase block size is smaller NAND flash memory, memory card equipped with a NAND-type flash memory large erase block size to respond properly It can not, has become a cause of the malfunction.

なお、特許文献１には、複数種のメモリチップとこれらメモリチップを制御するメモリコントローラを有するメモリシステムにおいて、１つのメモリコントローラで複数種のメモリチップをアクセスできるように構成した技術が記載されている。 In Patent Document 1, in a memory system having a memory controller for controlling a plurality of types of memory chips and these memory chips, it describes a construction to techniques for access a plurality of types of memory chips in one memory controller there.特開２００２−２５９３２２号公報 JP 2002-259322 JP

そこでこの発明は、前記事情に鑑みてなされたものであり、メモリカードに搭載された不揮発性半導体メモリの仕様に合わないシーケンスでコマンドを発行してくるホスト機器に対して、正常に応答することが可能なコントローラ、メモリカード及びその制御方法を提供することを目的とする。 Therefore the present invention has been made in view of the above circumstances, the host device coming to issue commands in sequence that do not conform to the non-volatile semiconductor memory mounted on the memory card specifications, to respond normally and to provide a capable controller, a memory card and a control method thereof.

この発明の第１態様のコントローラは、ホスト機器から出力された第１の不揮発性半導体メモリに対するコマンドシーケンスを受け取るホストインタフェース部と、前記ホスト機器から出力された前記第１の不揮発性半導体メモリに対する前記コマンドシーケンスを処理し前記コマンドシーケンスに応じて、第２の不揮発性半導体メモリに対するデータの書き込み、読み出し及び消去の動作を制御する処理回路とを具備し、前記処理回路は、前記コマンドシーケンスが含むコマンドが、書き込み、読み出し、消去、ＩＤリード、ステータスリードのいずれであるか判定する処理と、前記コマンドが書き込み、読み出し、消去のいずれかであるとき、アドレスが所定数入力されたか否かを判定する処理と、前記アドレスが所定数入力されたとき The controller of the first aspect of this invention, a host interface unit for receiving a command sequence for the first nonvolatile semiconductor memory output from the host device, for the first nonvolatile semiconductor memory output from the host apparatus depending on the command sequence for processing the command sequence, write data to the second nonvolatile semiconductor memory, comprising a processing circuit for controlling the operation of the reading and erasing, wherein the processing circuit, the command sequence comprises command, write, read, erase, determination ID read, and determines processing whether it is a status read, write the command, reading, when either of the erase, whether the address is entered a predetermined number a process of, when the address is entered a predetermined number書き込み、読み出し、消去のいずれかを実行する処理と、前記アドレスが所定数入力されないとき、前記ホスト機器からコマンドが入力されたか否かを判定する処理と、前記コマンドがＩＤリード、ステータスリードのいずれかであるとき、ＩＤリード、ステータスリードのいずれかを実行する処理とを実行すること特徴とする。Writing, reading, a process of performing one of deletion, when the address is not input a predetermined number, the process of determining whether or not the command has been input from the host device, either the command ID read, the status read when it is either, ID read, and this and features and a process of performing one of the status read.

また、この発明の第２態様のメモリカードは、ホスト機器に装着され、前記ホスト機器から出力された第１の不揮発性半導体メモリに対するコマンドシーケンスを受け取るメモリカードであって、データの書き込み、読み出し及び消去が行われる第２の不揮発性半導体メモリと、前記ホスト機器から出力された前記第１の不揮発性半導体メモリに対する前記コマンドシーケンスを処理し前記コマンドシーケンスに応じて、前記第２の不揮発性半導体メモリに対するデータの書き込み、読み出し及び消去の動作を制御するコントローラとを具備し、前記コントローラは、前記ホスト機器から出力された前記コマンドシーケンスを処理する制御手段を有し、前記制御手段は、前記コマンドシーケンスが含むコマンドが、書き込み、読み出し、消去 The memory card of the second aspect of the invention is mounted on the host device, wherein a first memory card for receiving a command sequence for a non-volatile semiconductor memory output from the host device, the data write, read and a second nonvolatile semiconductor memory erasure is performed in response to the command sequence for processing the command sequence for the first nonvolatile semiconductor memory output from the host device, the second nonvolatile semiconductor memory comprising writing data, and a controller for controlling the operation of the reading and erasing of the controller includes a control means for processing the command sequence that is output from the host device, said control means, said command sequence command, writing, reading, erasing, including theＩＤリード、ステータスリードのいずれであるか判定するステップと、前記コマンドが書き込み、読み出し、消去のいずれかであるとき、アドレスが所定数入力されたか否かを判定するステップと、前記アドレスが所定数入力されたとき、書き込み、読み出し、消去のいずれかを実行するステップと、前記アドレスが所定数入力されないとき、前記ホスト機器からコマンドが入力されたか否かを判定するステップと、前記コマンドがＩＤリード、ステータスリードのいずれかであるとき、ＩＤリード、ステータスリードのいずれかを実行するステップとを具備すること特徴とする。Determining whether ID read, which of the status read, write the command, reading, when either of the erase, determining whether the address is entered a predetermined number, the address is a predetermined number when entered, write, read, and executing one of the erasing, when the address is not input a predetermined number, determining whether the command is input from the host device, the command ID read when either of the status read, ID read, characterized by comprising the steps of performing any of the status read.

また、この発明の第３態様のメモリカードの制御方法は、ホスト機器に装着され、前記ホスト機器からアクセスされるメモリカードの制御方法において、 前記ホスト機器から出力された第１の不揮発性半導体メモリに対するコマンドシーケンスが含むコマンドが、書き込み、読み出し、消去、ＩＤリード、ステータスリードのいずれであるか判定するステップと、前記コマンドが書き込み、読み出し、消去のいずれかであるとき、アドレスが所定数入力されたか否かを判定するステップと、前記アドレスが所定数入力されたとき、 前記コマンドシーケンスに応じて、第２の不揮発性半導体メモリに対するデータの書き込み、読み出し、消去のいずれかを実行するステップと、前記アドレスが所定数入力されないとき、前記ホスト機器からコマ A control method for a memory card of the third aspect of the invention is mounted on the host device, a control method for a memory card to be accessed from the host device, the first nonvolatile semiconductor memory output from the host apparatus command included in the command sequence for the, writing, reading, erasing, ID read, and determining whether it is a status read, the command is a write, read, when either of the erase address is entered a predetermined number determining whether Taka whether, when the address is entered a predetermined number, comprising the steps of: in response to said command sequence, executes the data for the second nonvolatile semiconductor memory write, read, one of the erase, when the address is not input a predetermined number, the frame from the host apparatusドが入力されたか否かを判定するステップと、前記コマンドがＩＤリード、ステータスリードのいずれかであるとき、ＩＤリード、ステータスリードのいずれかを実行するステップとを具備することを特徴とする。 Determining whether de is inputted, the command ID read, when either of the status read, ID read, characterized by comprising the steps of performing any of the status read.

この発明によれば、メモリカードに搭載された不揮発性半導体メモリの仕様に合わないシーケンスでコマンドを発行してくるホスト機器に対して、正常に応答することが可能なメモリカード及びその制御方法を提供することができる。 According to the invention, to the host device coming to issue commands in sequence that do not conform to the non-volatile semiconductor memory mounted on the memory card specifications, the memory card and a control method capable of responding normally it is possible to provide.

以下、図面を参照してこの発明の実施形態について説明する。 Hereinafter, with reference to the drawings will be described embodiments of the present invention.説明に際し、全図にわたり、共通する部分には共通する参照符号を付す。 In the description, throughout the drawings, the same parts are denoted by common reference numerals.

図１は、この発明の実施形態のメモリカードの構成を示すブロック図である。 Figure 1 is a block diagram showing a configuration of a memory card of an embodiment of the present invention.

メモリカード１は、図１に示すように、ＮＡＮＤ型フラッシュメモリ３及びコントローラ４を含む。 Memory card 1, as shown in FIG. 1, includes a NAND type flash memory 3 and the controller 4.コントローラ４には、ＣＰＵ（Central Processing Unit）８やＲＯＭ（Read-Only Memory）９などの機能ブロックが搭載されている。 The controller 4, CPU functional blocks such as (Central Processing Unit) 8 and ROM (Read-Only Memory) 9 is mounted.各デバイスの詳細については後で述べる。 For details of each device will be described later.なお、ＮＡＮＤ型フラッシュメモリ３は、１つのメモリセルに１ビットの情報を記憶する２値メモリであっても良いし、１つのメモリセルに１ビットより多い情報（例えば２ビット）を記憶する多値メモリであっても良い。 Incidentally, NAND type flash memory 3, one to one bit of information in a memory cell may be a binary memory for storing a multi storing more than one bit in one memory cell information (e.g., 2 bits) it may be a value memory.またここでは、ＮＡＮＤ型フラッシュメモリを用いた例を説明するが、これに限るわけではなく、ＮＯＲ型メモリなど、その他の不揮発性半導体メモリにも適用できる。 Also here, an example will be described using a NAND flash memory, but the present invention is not limited thereto, such as NOR-type memory, can also be applied to other nonvolatile semiconductor memory.

また、図示しないが、ＮＡＮＤ型フラッシュメモリ３及びコントローラ４は、ＰＣＢ（Printed Circuit Board）基板上に配置されていても良いし、同一のＬＳＩ（Large-scale Integration）内に形成されていても良い。 Although not shown, NAND type flash memory 3 and the controller 4 may be arranged on the PCB (Printed Circuit Board) substrate, may be formed in the same LSI (Large-scale Integration) .

以下の説明において使用する用語「論理ブロックアドレス」，「物理ブロックアドレス」は、それぞれ、ブロック自体の論理アドレス，物理アドレスを意味するものである。 The following terms used in the description of the "logical block address", "physical block address", respectively, is intended to mean a logical address of the block itself, the physical address.また、「論理アドレス」，「物理アドレス」は、主に、ブロック自体の論理アドレス，物理アドレスを意味するものではあるが、ブロック単位よりも細かい分解能の単位に相当するアドレスである場合もあり得ることを示すものである。 Further, "logical address", "physical address" get primarily the logical address of the block itself, albeit imply physical addresses, sometimes the address corresponding to the unit of resolution finer than the block unit it shows the.

ホスト機器２０は、接続されるメモリカード１に対してアクセスを行うためのハードウェア及びソフトウェア（システム）を備えている。 The host apparatus 20 includes hardware and software (system) for accessing the memory card 1 connected.このホスト機器２０は、メモリカード内部の物理状態（何処の物理ブロックアドレスに、何番目の論理セクタアドレスデータが含まれているか、或いは、何処のブロックが消去状態であるか）を管理し、メモリカード１内のＮＡＮＤ型フラッシュメモリ３を直接制御するものとして構築されている。 The host apparatus 20 manages the physical state of the internal memory card (which physical block address what number logical sector address or data is included, or, where whether the block is in the erased state) and memory It is constructed as to control the NAND-type flash memory 3 of the card 1 directly.

また、ホスト機器２０は、消去時の消去ブロックサイズが１６kByteに定められているＮＡＮＤ型フラッシュメモリを使用することを前提として、１６kByte単位で論理アドレス、物理アドレスの割当を行い、多くの場合、論理アドレス１６kByte分に関してシーケンシャルにライトアクセスもしくはリードアクセスを行う（該当するコマンドを発行する）。 The host device 20, assuming the use of a NAND flash memory erase block size at the time of erasing is defined to 16 kBytes, the logical address 16 kBytes units performs allocation of physical addresses, in many cases, the logic performing a write access or read access sequentially with respect to the address 16kByte minute (to issue the appropriate command).

メモリカード１は、ホスト機器２０に接続されたときに電源供給を受けて動作し、ホスト機器２０からのアクセスに応じた処理を行う。 Memory card 1 operates by receiving power supply when connected to the host device 20 performs a process corresponding to the access from the host device 20.このメモリカード１は、前述したようにＮＡＮＤ型フラッシュメモリ３及びコントローラ４を有する。 The memory card 1 has a NAND-type flash memory 3 and the controller 4 as described above.

ＮＡＮＤ型フラッシュメモリ３は、消去時の消去ブロックサイズ（消去単位のブロックサイズ）が２５６kByteに定められている不揮発性メモリであり、例えば１６kByte単位でデータの書き込み・読み出しを行うようになっている。 NAND-type flash memory 3, the erase block size at the time of erasing (block size of the erase unit) is a nonvolatile memory which is determined to 256 kBytes, for example, so as to perform writing and reading of data in 16kByte units.このＮＡＮＤ型フラッシュメモリ３は、例えば０.０９μｍプロセス技術を用いて製作される。 The NAND type flash memory 3, for example, are fabricated using 0.09μm process technology.即ち、ＮＡＮＤ型フラッシュメモリ３のデザインルールは、０.１μｍ未満となっている。 In other words, the design rule of the NAND-type flash memory 3 is less than 0.1μm.

コントローラ４は、前述したＣＰＵ８及びＲＯＭ９のほかに、メモリインタフェース部５、ホストインタフェース部６、バッファ７、及びＲＡＭ（Random Access Memory）１０を搭載している。 Controller 4, in addition to the CPU8 and ROM9 described above, the memory interface section 5, the host interface unit 6, is equipped with a buffer 7, and RAM (Random Access Memory) 10.

図２は、本実施形態のメモリカードのピン配置を示す平面図であり、ピン形成面からみた図である。 Figure 2 is a plan view showing a pin arrangement of the memory card of the present embodiment, a view from the pin forming surface.ホストインタフェース部６が有するピンは、図２に示すように配置されている。 Pin host interface unit 6 has is arranged as shown in FIG.図３に、そのピンアサイン、すなわちピン番号とそのピンに割り当てられた信号を示す。 Figure 3 shows the pin assignments, i.e. the signal assigned pin number and its pin.ピン１、９は基準電圧、例えば接地電圧ＧＮＤに、ピン１８は電源電圧Ｖccに割り当てられている。 Pins 1 and 9 reference voltage, for example, the ground voltage GND, pin 18 is assigned to the power supply voltage Vcc.ピン２は、メモリカード１の内部動作状態をホスト機器２０に知らせるためのレディ・ビジー信号Ｒ／−Ｂ(Ready/Busy)に割り当てられている。 Pin 2 is assigned to the ready busy signal is used to indicate the operating state of the memory card 1 to the host device 20 R / -B (Ready / Busy).書き込み、読み出し、及び消去時など、内部で動作実行中はピン２からビジー信号が出力され、動作が完了するとレディ信号が出力される。 Writing, reading, and the like erasing, in operation performed inside the busy signal from the pin 2 is output, the ready signal is output when the operation is complete.ピン３はデータを出力させるリードイネーブル信号−ＲＥ(Read Enable)に、ピン４はメモリカード１を動作モードにするカードイネーブル信号−ＣＥ(Card Enable)に割り当てられている。 Pin 3 is the read enable signal -RE (Read Enable) to output the data, pins 4 are assigned to the card enable signal to the memory card 1 to the operation mode -CE (Card Enable).ピン５はコマンドの取り込みをコントロールするためのコマンドラッチイネーブル信号ＣＬＥ(Command Latch Enable)に、ピン６はアドレス、及び入力データの取り込みをコントロールするためのアドレスラッチイネーブル信号ＡＬＥ(Address Latch Enable)に割り当てられている。 The pin 5 is a command latch enable signal to control the uptake of commands CLE (Command Latch Enable), the pin 6 is allocated to the address, and the address to control the incorporation of the input data latch enable signal ALE (Address Latch Enable) It is.ピン７はデータをメモリカード１に書き込むためのライトイネーブル信号−ＷＥ(Write Enable)に、ピン８は書き込み、及び消去を強制的に禁止させるためのライトプロテクト信号−ＷＰ(Write Protect)に割り当てられている。 Pin 7 is in the write enable signal -WE (Write Enable) for writing data to the memory card 1, the pin 8 is assigned write, and a write protect signal -WP (Write Protect) for forcibly prohibit erasure ing.さらに、ピン１０、１１、…、１７は、コマンド、アドレス、及びデータが入出力されるピンＤ０(Data0)、Ｄ１(Data0)、…、Ｄ７(Data7)に割り当てられている。 Further, pins 10, 11, ..., 17, pin D0 of command, address, and data are input and output (Data0), D1 (Data0), ..., are assigned to D7 (Data7).このように、本実施形態のメモリカード１は、ＮＡＮＤ型フラッシュメモリ３のピン構成に対応したピン構成を有しており、ホスト機器２０がＮＡＮＤ型フラッシュメモリに対するコマンドシーケンスによりメモリカード１にアクセスを行うことが可能となっている。 Thus, the memory card 1 of this embodiment has a pin configuration which corresponds to the pin configuration of a NAND flash memory 3, the command sequence the host device 20 to the NAND type flash memory access to the memory card 1 it is possible to do.なお、コマンドシーケンスとは、コマンドとアドレスが入力される一連の順序（入力タイミング）のことをいう。 Note that the command sequence refers to a sequence of the order in which commands and address is input (input timing).なお、図３中において、“Ｓ”は電源電圧を示し、“Ｉ”はメモリカードへの入力であることを示し、“Ｏ”はメモリカードからの出力であることを示し、さらに“Ｉ／Ｏ”はメモリカードに対する入出力であることを示す。 Note that in FIG. 3, "S" indicates a power supply voltage, "I" indicates that an input to a memory card, "O" indicates that the output from the memory card, further "I / O "indicates that the input and output to the memory card.また、ピン名（信号名）の頭に付した“−”は、Low True信号であること、すなわち“Ｌ”のとき活性化を指示する信号であることを示す。 Moreover, subjected to the head of the pin name (signal name) "-" indicates that it is a Low True signal, i.e. a signal indicating the activation time of "L".

バッファ７は、ホスト機器２０から送られてくるデータをＮＡＮＤ型フラッシュメモリ３へ書き込む際に、一定量のデータ（例えば１ページ分）を一時的に記憶したり、ＮＡＮＤ型フラッシュメモリ３から読み出されたデータをホスト機器２０へ送り出す際に、一定量のデータを一時的に記憶したりするものである。 Buffer 7, when writing data sent from the host device 20 to the NAND type flash memory 3, and temporarily stores a predetermined amount of data (e.g. 1 page) read out from the NAND flash memory 3 when delivering been data to the host device 20, and to temporarily store a certain amount of data.

ＣＰＵ８は、メモリカード１全体の動作を司るものである。 CPU8 are those responsible for the overall operation of the memory card 1.ＲＯＭ９は、ＣＰＵ８により使用される制御プログラムなどを格納するメモリである。 ROM9 is a memory for storing a control program used by the CPU 8.ＲＡＭ１０は、ＣＰＵ８の作業エリアとして使用され、制御プログラムや各種のテーブルを記憶する揮発性メモリである。 RAM10 is used as a work area of ​​the CPU 8, which is a volatile memory for storing control programs and various tables.ＣＰＵ８は、例えば、メモリカード１が電源供給を受けた際に、ＲＯＭ９の中に格納されているファームウェア（制御プログラム）をＲＡＭ１０上にロードして所定の処理を実行することにより、各種のテーブルをＲＡＭ１０上で作成したり、ホスト機器２０から書き込みコマンド，読み出しコマンド，消去コマンドを受けてＮＡＮＤ型フラッシュメモリ３上の該当領域に対するアクセスを実行したり、バッファ７を通じたデータ転送処理を制御したりする。 CPU8, for example, when the memory card 1 is supplied with power by executing predetermined processing to load firmware (control program) on the RAM10 stored in the ROM 9, the various tables to create on RAM 10, a write command from the host device 20, the read command to perform the access to the appropriate area on the NAND type flash memory 3 receives the erase command, and controls a data transfer process via the buffer 7 .

図４は、前記ファームウェア（制御プログラム）によって実行される制御の一例であり、ホスト機器２０から入力されたコマンドシーケンスを処理する制御手順を示すフローチャートである。 Figure 4 is an example of a control executed the firmware (control program), which is a flow chart showing a control procedure for processing a command sequence input from the host device 20.

まず、ＣＰＵ８は、ホスト機器２０からコマンドが入力されたか否かを判定する（ステップＳ１）。 First, CPU 8 determines whether or not the command has been input from the host device 20 (step S1).続いて、コマンドが入力されたときは、そのコマンドが書き込みコマンドまたは読み出しコマンドであるか否かを判定する（ステップＳ２）。 Then, when the command is input, it determines whether the command is a write command or a read command (step S2).なお、ステップＳ１でコマンドが入力されていないと判定したときは、再びステップＳ１に戻る。 Incidentally, when it is determined that the command is not input in step S1, it returns to step S1.

次に、入力されたコマンドが、書き込みコマンドあるいは読み出しコマンドであると判定したときは、アドレスが所定のバイト数、ここでは４バイト入力されたか否かを判定する（ステップＳ３）。 Then, the input command is, when it is determined that the write command or a read command, the address is a predetermined number of bytes, here determines whether the 4-byte input (step S3).アドレスが４バイト入力されたときは、書き込みあるいは読み出しの処理を行い（ステップＳ４）、ステップＳ１に戻る。 When an address is 4 byte input, performs processing of the write or read (step S4), and returns to step S1.一方、ステップＳ３で、アドレスが所定時間内に４バイト入力されないときは、再びコマンドが入力されたか否かを判定する（ステップＳ５）。 On the other hand, in step S3, when no address is 4 byte input within the predetermined time, determines whether or not the input again command (step S5).ここで、コマンドが入力されたときは、ステップＳ２に戻り、ステップＳ２以降の処理を繰り返す。 Here, when the command is input, the flow returns to step S2, and repeats the processes in and after step S2.一方、コマンドが入力されないときは、ステップＳ３に戻り、ステップＳ３以降の処理を繰り返す。 Meanwhile, when the command is not input, the process returns to step S3, and repeats the processes in and after step S3.

また、ステップＳ２において、入力されたコマンドが書き込みコマンドあるいは読み出しコマンドでないと判定したときは、コマンドが消去コマンドであるか否かを判定する（ステップＳ６）。 Further, in step S2, when the input command is determined not to be a write command or a read command, the command determines whether the deletion command (step S6).入力されたコマンドが、消去コマンドであると判定したときは、アドレスが所定のバイト数、ここでは３バイト入力されたか否かを判定する（ステップＳ７）。 Entered command, when it is determined that the erase command, address a predetermined number of bytes, here determines whether or not a 3-byte input (step S7).アドレスが３バイト入力されたときは、消去の処理を行い（ステップＳ８）、ステップＳ１に戻る。 When an address is 3 byte input, performs processing erasure (step S8), and returns to step S1.一方、ステップＳ７で、アドレスが所定時間内に３バイト入力されないときは、再びコマンドが入力されたか否かを判定する（ステップＳ９）。 On the other hand, in step S7, when the address is not 3 byte input within the predetermined time, it determines whether or not the input again command (step S9).コマンドが入力されたときは、ステップＳ２に戻り、ステップＳ２以降の処理を繰り返す。 When a command is input, the process returns to step S2, and repeats the processes in and after step S2.一方、コマンドが入力されないときは、ステップＳ７に戻り、ステップＳ７以降の処理を繰り返す。 Meanwhile, when the command is not input, the process returns to the step S7, the step S7 and repeats the subsequent processing.

また、ステップＳ６において、入力されたコマンドが消去コマンドでないと判定したときは、コマンドがＩＤリードコマンドあるいはステータスリードコマンドであるか否かを判定する（ステップＳ１０）。 Further, in step S6, when the inputted command is determined not to be erase command, the command determines whether the ID read command or status read command (step S10).入力されたコマンドが、ＩＤリードコマンドあるいはステータスリードコマンドであると判定したときは、ＩＤリードあるいはステータスリードの処理を行い（ステップＳ１１）、ステップＳ１に戻る。 It entered command, when it is determined that the ID read command or status read command, performs processing ID read or status read (step S11), and returns to step S1.一方、入力されたコマンドがＩＤリードコマンドあるいはステータスリードコマンドでないと判定したときは、処理を行わず、そのままステップＳ１に戻る。 Meanwhile, when the input command is determined not to be ID read command or status read command does not perform the processing, the process returns to the step S1.

図５及び図６は、ホスト機器２０からコントローラ４に入力されるＩＤリードコマンドを含むコマンドシーケンスのタイミングチャートである。 5 and 6 are timing charts of the command sequence that includes the ID read command input from the host device 20 to the controller 4.図５に示すコマンドシーケンスがメモリカード１の仕様書で定義された、ＩＤリードコマンドのコマンドシーケンスであるとき、図６に示すコマンドシーケンスによってＩＤリードを実行しようとするホスト機器があると仮定する。 Command sequence shown in Figure 5 is defined in the specification memory card 1, when a command sequence of the ID read command, it is assumed that there is a host device to be executed the ID read by the command sequence shown in FIG.

図５に示すコマンドシーケンスでは、以下のようなタイミングでコマンド、アドレス、及びデータが入出力される。 In the command sequence shown in Figure 5, the command in the following timing, address, and data are inputted and outputted.

コマンドラッチイネーブル信号ＣＬＥが“ハイレベル（以下、Ｈと記す）”で、カードイネーブル信号−ＣＥが“ロウレベル（以下、Ｌと記す）”、及びアドレスラッチイネーブル信号ＡＬＥが“Ｌ”のとき、ライトイネーブル信号−ＷＥの立ち上がりエッジにて、ピンＤ０〜Ｄ７からＩＤリードコマンドＣＯＭがコントローラ４に取り込まれる。 Command latch enable signal CLE is "high level (hereinafter, referred to as H)", the card enable signal -CE is "low level (hereinafter, referred to as L)", and when the address latch enable signal ALE is "L", the write at the rising edge of the enable signal -WE, ID read command COM from the pin D0~D7 is taken into the controller 4.次に、コマンドラッチイネーブル信号ＣＬＥが“Ｌ”で、カードイネーブル信号−ＣＥが“Ｌ”、及びアドレスラッチイネーブル信号ＡＬＥが“Ｈ”のとき、ライトイネーブル信号−ＷＥの立ち上がりエッジにて、ピンＤ０〜Ｄ７からアドレス“００（１６進数）”がコントローラ４に取り込まれる。 Next, the command latch enable signal CLE is "L", at the card enable signal -CE is "L", and when the address latch enable signal ALE is "H", the rising edge of the write enable signal -WE, pins D0 address -D7 "00 (16 decimal)" is taken into the controller 4.さらに、コマンドラッチイネーブル信号ＣＬＥが“Ｌ”で、カードイネーブル信号−ＣＥが“Ｌ”、及びアドレスラッチイネーブル信号ＡＬＥが“Ｌ”のとき、リードイネーブル信号−ＲＥの立ち上がりエッジにて、ピンＤ０〜Ｄ７からデータ０〜データ３がホスト機器２０に取り込まれる。 Further, the command latch enable signal CLE is "L", the card enable signal -CE is "L", and when the address latch enable signal ALE is "L", at a rising edge of the read enable signal -RE, pins D0~ D7 data 0 data 3 is taken to the host device 20 from.

また、図６に示すコマンドシーケンスでは、以下のようなタイミングでコマンド、アドレス、及びデータが入出力される。 Further, the command sequence shown in FIG. 6, command the following timing, address, and data are inputted and outputted.

コマンドラッチイネーブル信号ＣＬＥが“Ｈ”で、カードイネーブル信号−ＣＥが“Ｌ”、及びアドレスラッチイネーブル信号ＡＬＥが“Ｌ”のとき、ライトイネーブル信号−ＷＥの立ち上がりエッジにて、ピンＤ０〜Ｄ７からＩＤリードコマンドＣＯＭがコントローラ４に取り込まれる。 A command latch enable signal CLE is "H", at the card enable signal -CE is "L", and when the address latch enable signal ALE is "L", the rising edge of the write enable signal -WE, the pin D0~D7 ID read command COM is incorporated into the controller 4.次に、コマンドラッチイネーブル信号ＣＬＥが“Ｌ”で、カードイネーブル信号−ＣＥが“Ｌ”、及びアドレスラッチイネーブル信号ＡＬＥが“Ｈ”のとき、ライトイネーブル信号−ＷＥの立ち上がりエッジにて、ピンＤ０〜Ｄ７からアドレスａｄｒ１〜ａｄｒ３がコントローラ４に取り込まれる。 Next, the command latch enable signal CLE is "L", at the card enable signal -CE is "L", and when the address latch enable signal ALE is "H", the rising edge of the write enable signal -WE, pins D0 address adr1~adr3 is taken into the controller 4 from -D7.さらに、コマンドラッチイネーブル信号ＣＬＥが“Ｌ”で、カードイネーブル信号−ＣＥが“Ｌ”、及びアドレスラッチイネーブル信号ＡＬＥが“Ｌ”のとき、リードイネーブル信号−ＲＥの立ち上がりエッジにて、ピンＤ０〜Ｄ７からデータ０〜データ３がホスト機器２０に取り込まれる。 Further, the command latch enable signal CLE is "L", the card enable signal -CE is "L", and when the address latch enable signal ALE is "L", at a rising edge of the read enable signal -RE, pins D0~ D7 data 0 data 3 is taken to the host device 20 from.

図６に示すような、ＩＤリードコマンドのコマンドシーケンスではアドレスａｄｒ１〜ａｄｒ３の入力は無視すべきである。 As shown in FIG. 6, the command sequence ID read command input address adr1~adr3 should ignore.しかし、図４に示した制御手順を実行するための制御プログラムを持たない従来のメモリカードでは、書き込み時及び読み出し時と同様に４サイクルのアドレスがホスト機器２０から発行されるため、本来、無視すべきアドレスａｄｒ１〜ａｄｒ３の入力をコントローラ内のシーケンサが書き込み時や読み出し時のアドレス入力と解釈して誤動作する可能性がある。 However, in the conventional memory card not having a control program for executing a control procedure shown in FIG. 4, the address of the 4-cycle in the same manner as when writing and when reading is issued from the host device 20, originally ignored sequencer in the controller inputs should do address adr1~adr3 is likely to malfunction by interpreting an address input at the time of or during reading and writing.

そこで、本実施形態のメモリカード１では、図４に示した制御手順を用いて図６に示したコマンドシーケンスを処理する。 Therefore, the memory card 1 of this embodiment, processes the command sequence shown in FIG. 6 using the control procedure shown in FIG.これにより、ステップＳ１、Ｓ２、Ｓ６、Ｓ１０、Ｓ１１の順序で処理が移行し、ＩＤリードの処理が実行される。 Accordingly, step S1, S2, S6, S10, the order in the processing of S11 is shifted, the processing of ID read is performed.すなわち、アドレスａｄｒ１〜ａｄｒ３が入力されても、書き込み時や読み出し時であるとして誤動作することなく、正常にＩＤリードの処理を実行することできる。 That is, even if the address adr1~adr3 is input, without malfunction as a time or during reading and writing, can be executing a process of successfully ID read.

なおここでは、ＩＤリードコマンドの入力後に、アドレスが４サイクル入力される例を示したが、これに限るわけではなく、ホスト機器２０から仕様書に従ったコマンドシーケンスが入力されないその他の場合でも、誤動作することなく本来の処理を実行することが可能である。 Note here, after the input of the ID read command, an example in which addresses are 4-cycle input, but the present invention is not limited thereto, even when the host device 20 of the other of the command sequence is not entered in accordance with the specifications, it is possible to run the original process without malfunction.また、図４に示した制御手順をファームウェア（制御プログラム）によって実行した例を示したが、コントローラ４内に形成したハードウェア（シーケンサ）によって実行するようにしてもよい。 Also, although an example of executing the control procedure shown in FIG. 4 by the firmware (control program), may be performed by hardware (PLC) formed in the controller 4.

ホスト機器２０が想定しているフラッシュメモリでは、各ページは５２８Byte（５１２Byte分のデータ記憶部＋１６Byte分の冗長部）を有しており、３２ページ分が１つの消去単位（即ち、１６kByte＋０.５kByte（ここで、kは１０２４））となる。 In the flash memory by the host device 20 is assumed, each page has 528 Bytes (data storage unit of 512Byte min + 16 Bytes of redundant section), 32 pages are one erase unit (i.e., 16kByte + 0.5kByte ( here, k is the 1024)).以下では、このようなフラッシュメモリを搭載したカードを、「小ブロックカード」と称す場合がある。 In the following, a card equipped with such a flash memory, sometimes referred to as "small block card".

一方、実際に使用するフラッシュメモリ３では、各ページは２１１２Byte（例えば５１２Byte分のデータ記憶部×４＋１０Byte分の冗長部×４＋２４Byte分の管理データ記憶部）を有しており、１２８ページ分が１つの消去単位（即ち、２５６kByte＋８kByte）となる。 On the other hand, in the flash memory 3 actually used, each page has 2112Byte (e.g. 512Byte of data storage unit × 4 + 10 bytes worth of management data storage unit of the redundant section × 4 + 24 Bytes minute), is one 128 page erase unit (ie, 256kByte + 8kByte) becomes.以下では、このようなフラッシュメモリ３を搭載したカードを、「大ブロックカード」と称す場合がある。 In the following, a card equipped with such a flash memory 3, sometimes referred to as "large block card".なお、以下の説明においては、便宜上、小ブロックカードの消去単位を１６kByteと呼び、大ブロックカードの消去単位を２５６kByteと呼ぶ。 In the following description, for convenience, referred to as 16kByte the erase unit of the small block card, called the erase unit of the large block card with 256 kBytes.

また、ホスト機器２０が想定しているフラッシュメモリと、実際に使用するフラッシュメモリ３は、それぞれ、フラッシュメモリへのデータ入出力を行うためのページバッファを備えている。 Further, the flash memory by the host device 20 is assumed, the flash memory 3 actually used, respectively, and a page buffer for inputting and outputting data to the flash memory.ホスト機器２０が想定しているフラッシュメモリに備えられるページバッファの記憶容量は、５２８Byte（５１２Byte＋１６Byte）である。 Storage capacity of the page buffer provided in the flash memory by the host device 20 is assumed is 528Byte (512Byte + 16Byte).一方、実際に使用するフラッシュメモリ３に備えられるページバッファの記憶容量は、２１１２Byte（２０４８Byte＋６４Byte）である。 On the other hand, the storage capacity of the page buffer provided in the flash memory 3 actually used is 2112Byte (2048Byte + 64Byte).データ書き込みなどの際には、各ページバッファは、フラッシュメモリに対するデータ入出力処理を、自身の記憶容量に相当する１ページ分の単位で実行する。 When such data writing, each page buffer, the data input and output processing to the flash memory in units of one page corresponding to its own storage capacity.

図７に示した例では、実際に使用するフラッシュメモリ３の消去ブロックサイズが、ホスト機器２０が想定しているフラッシュメモリの消去ブロックサイズの１６倍である場合を示したが、本発明はこれに限定されるものではなく、略整数倍であれば別の倍率となるように構成することも可能である。 In the example shown in FIG. 7, the erase block size of the flash memory 3 actually used, the case the host device 20 is 16 times the erase block size of the flash memory is assumed, the present invention will now is not limited to, it can be configured to be a different magnification if substantially integral multiple.

大ブロックカードを実用上有効な製品とするためには、図７に示したフラッシュメモリ３の記憶容量は１Ｇビット以上であることが望ましい。 To a large block card and practically effective product, it is desirable storage capacity of the flash memory 3 shown in FIG. 7 is 1G bit or more.フラッシュメモリ３の記憶容量が例えば１Ｇビットである場合、２５６kByteブロック（消去単位）の数は、５１２個となる。 If the storage capacity of the flash memory 3 is, for example, 1G bits, the number of 256kByte blocks (erase unit) is 512..また、図７においては消去単位が２５６kByteブロックである場合を例示しているが、消去単位が例えば１２８kByteブロックとなるように構築することも実用上有効である。 Although in FIG. 7 illustrates that the erase unit is a 256kByte block, it is practically effective to build so that the erase unit becomes, for example, 128kByte block.この場合、１２８kByteブロックの数は、１０２４個となる。 In this case, the number of 128kByte block is a 1024.

また、図７に示した例では、実際に使用するフラッシュメモリ３の消去ブロックサイズが、ホスト機器２０が想定しているフラッシュメモリの消去ブロックサイズよりも大きい場合を示したが、本発明はこれに限定されるものではなく、実際に使用するフラッシュメモリ３の消去ブロックサイズが、ホスト機器２０が想定しているフラッシュメモリの消去ブロックサイズよりも小さいものとして構成することも可能である。 In the example shown in FIG. 7, the erase block size of the flash memory 3 actually used, the case the host device 20 is greater than the erase block size of the flash memory is assumed, the present invention will now is not limited to, the erase block size of the flash memory 3 actually used, it is also possible to configure a smaller than the erase block size of the flash memory by the host device 20 is assumed.

図８は、ホスト機器２０側システム及びメモリカード１（大ブロックカード）における各コミュニケーション階層を示す図である。 Figure 8 is a diagram showing each communication hierarchy in the host device 20 side system and the memory card 1 (large block card).

ホスト機器２０側のシステムは、アプリケーションソフト２１、ファイルシステム２２、ドライバソフト２３、及び小ブロックカード物理アクセス層２４を有する。 Host device 20 side of the system has application software 21, file system 22, driver software 23, and a small block card physical access layer 24.一方、メモリカード１（大ブロックカード）は、小ブロックカード物理アクセス層１１、小ブロックカード物理・小ブロックカード論理変換層１２、小ブロックカード論理・大ブロックカード物理変換層１３、及び大ブロックカード物理アクセス層１４を有する。 On the other hand, the memory card 1 (large block card) is a small block card physical access layer 11, the small block card physical and small block card logical conversion layer 12, the small block card logic and large block card physical conversion layer 13, and the large block card having physical access layer 14.

例えば、ホスト機器２０側のアプリケーションソフト２１がファイルの書き込みをファイルシステム２２に要求すると、ファイルシステム２２は、小ブロックカードの論理ブロックアドレスに基づきシーケンシャルなセクタ書き込みをドライバソフト２３に指示する。 For example, if the application software 21 of the host device 20 side is required to write a file to the file system 22, the file system 22 instructs the sequential sector write the driver software 23 based on the logical block address of the small block card.これを受けて、ドライバソフト２３は、小ブロックカードの論理ブロックアドレスに基づく１６kByteブロック毎のシーケンシャルな書き込みを実現するにあたり、論理・物理ブロック変換を行い、小ブロックカード物理アクセス層２４を通じて、小ブロックカードの物理ブロックアドレスによるランダムな書き込みコマンドを大ブロックカードに対して発行し、データ転送を行う。 In response to this, the driver software 23, when implementing the sequential writing of each 16kByte block based on the logical block address of the small block card, performs logical-physical block conversion, through a small block card physical access layer 24, the small block the random write command by the physical block address of the card issued to the large block card, to transfer data.

なお、ライトアクセスにおいては、小ブロックカードの場合も大ブロックカードの場合も、プロトコル上、（１）コマンド、（２）ページアドレス（ロウアドレス）、（３）カラムアドレス、（４）データ、（５）プログラム確認コマンド、といった順序で情報の送受が行われることが前提となっている。 In the write access, in the case of even a large block card for small block card, the protocol, (1) command (2) page address (row address), (3) the column address, (4) data, ( 5) the program confirmation command, the transmission and reception of information in the order such is performed based on the premise.

大ブロックカード側における小ブロックカード物理アクセス層１１は、ホスト機器２０から小ブロックカードの物理ブロックアドレスによる書き込みコマンドを受けると、物理ブロックアドレスやデータのほか、これに付随する付随データに含まれている論理ブロックアドレスを取得する。 Small block card physical access layer 11 in the large block card side receives the write command by the physical block address of the small block card from the host device 20, in addition to the physical block addresses and data, contained in the accompanying data associated therewith get the logical block address you are.

小ブロックカード物理・小ブロックカード論理変換層１２は、データ読み出しなどの際に小ブロックカードの物理ブロックアドレス（１６kByteブロック分に対応）から小ブロックカードの論理ブロックアドレス（１６kByteブロック分に対応）への変換処理を行うための第１のテーブルを有している。 Small block card physical and small block card logical conversion layer 12, when such data read from the physical block address of the small block card (corresponding to 16kByte block) to the logical block address of the small block card (corresponding to 16kByte block) and a first table for the conversion process.変換層１２は、小ブロックカード物理アクセス層１１が書き込みコマンドを受けて小ブロックカードの論理ブロックアドレスを取得したときにはこれを上記第１のテーブルに反映させる。 Converting layer 12 reflects to the first table when the small block card physical access layer 11 acquires the logical block address of the small block card receives the write command.物理ブロックアドレスに関しても、上記第１のテーブルに反映させる。 Regard the physical block address, it is reflected in the first table.

小ブロックカード論理・大ブロックカード物理変換層１３は、データ読み出しなどの際に小ブロックカードの論理ブロックアドレス（シーケンシャルな１６kByteブロック×１６個分に対応）から大ブロックカードの物理ブロックアドレス（２５６kByte物理ブロック分に対応）への変換処理を行うための第２のテーブルを有している。 Small block card logic and large block card physical conversion layer 13, when such data read from the logical block address of the small block card (corresponding to the sequential 16kByte blocks × 16 pieces of) the large block card physical block address (256 kBytes physical and a second table for performing conversion into corresponding blocks).変換層１２は、小ブロックカード物理アクセス層１１が書き込みコマンドを受けて小ブロックカードの論理ブロックアドレスを取得したときにはこれを上記第２のテーブルに反映させる。 Converting layer 12 reflects to the second table when the small block card physical access layer 11 acquires the logical block address of the small block card receives the write command.

大ブロックカード物理アクセス層１４は、小ブロックカード物理アクセス層１１が書き込みコマンドを受けて取得した小ブロックカードの論理ブロックアドレスに基づき、フラッシュメモリ３内部のデータ配置を決定し、２５６kByte物理ブロック内において２kByte（１ページ）単位でシーケンシャルに１６kByte分のデータを書き込む。 Large block card physical access layer 14, based on the logical block address of the small block card small block card physical access layer 11 is acquired by receiving the write command, it determines the flash memory 3 inside the data arrangement in 256kByte physical block and writes the data of 16kByte worth sequentially in 2kByte (1 page) units.また、大ブロックカード物理アクセス層１４は、取得した小ブロックカードの論理ブロックアドレスや物理ブロックアドレスをフラッシュメモリ３内部における管理データ領域内の所定の領域に格納する。 Further, the large block card physical access layer 14 stores logical block addresses and physical block addresses of the acquired small block card in a predetermined area of ​​the management data area in the internal flash memory 3.

このようにホスト機器２０は小ブロックカードの物理ブロックアドレスに基づくコマンドを発行するので、大ブロックカード側では、小ブロックカードの物理ブロックアドレスに対応するデータがどの２５６kByte物理ブロックの中に存在するのかが分かるように管理する。 Since the host apparatus 20 issues a command based on the physical block addresses of the small block card, the large block card side, whether present in any 256kByte physical block data corresponding to the physical block address of the small block card to manage as can be seen.具体的には、１６kByteブロック毎に小ブロックカードの論理・物理ブロックアドレスの対応関係を管理すると共に、小ブロックカードの連続した２５６kByteブロック分の論理ブロックアドレスに対応するデータが大ブロックカード内のどの２５６kByte物理ブロックに格納されているかが分かるように管理する。 Specifically, what manages the correspondence between the logical-physical block address of the small block card for each 16kByte block, data corresponding to consecutive 256kByte block of logical block addresses of the small block card in the large block card 256kByte or stored in the physical block is managed as seen.

図９（ａ）、図９（ｂ）は、ホスト機器２０側から送られてくるコマンドのフォーマットを示す図である。 FIG. 9 (a), the FIG. 9 (b) is a diagram showing a format of a command sent from the host device 20 side.

ホスト機器２０側から送られてくるコマンドのパケットは、図９（ａ）に示すように、コマンド種別情報（ここでは「書き込み」），アドレス（物理ブロックアドレス），データ（コンテンツなどの実データ及び付随データ（５１２Byte＋１６Byte））といった各種情報を含んでいる。 The packet command transmitted from the host device 20 side, as shown in FIG. 9 (a), the command type information ( "write" in this case), the address (physical block address), the actual data, such as data (content and it includes various kinds of information such as associated data (512Byte + 16Byte)).

このようなフォーマットのパケットにおいては、図９（ｂ）に示すように、付随データ１６Byte中の所定の位置に小ブロックカードの「論理ブロックアドレス」（アクセス対象となる１６kByteブロックに対応する論理アドレス）が配置されている。 In a packet of such format, as shown in FIG. 9 (b), "logical block address" (logical address corresponding to 16kByte block to be accessed) of the small block card in place in the accompanying data 16Byte There has been placed.大ブロックカードは、コマンド種別情報，物理ブロックアドレス，データを取得するほか、特に上記「論理ブロックアドレス」を取得する。 Large block card, the command type information, a physical block address, in addition to retrieve the data, in particular, acquire the "logical block address".なお、この「論理ブロックアドレス」は、読み出しコマンドの場合には付加されない。 Incidentally, the "logical block address" is not added in the case of the read command.

図１０は、ホスト機器２０側が想定しているブロック書き込み操作と、メモリカード１（大ブロックカード）側が実際に行う書き込み処理とを対比して示す図である。 Figure 10 is a diagram illustrating by comparison a block write operation by the host device 20 side is assumed, and a write process a memory card 1 (large block card) side actually performed.

ホスト機器２０側（同図の左側）では、小ブロックカードの論理アドレスに基づく１６kByteブロック単位のシーケンシャルな書き込み操作の発生時に、小ブロックカードの物理ブロックアドレスによる１６kByteブロック単位のランダムな書き込み操作を行う。 In the host device 20 side (left side in the figure), in the event of sequential write operations 16kByte block units based on the logical address of the small block card, performs random write operations 16kByte blocks by physical block address of the small block card .

一方、大ブロックカード側（同図の右側）では、ホスト機器２０側から書き込みコマンドを受けた場合、小ブロックカードの論理ブロックアドレスに基づく１６kByteブロック単位のデータをフラッシュメモリ３内にシーケンシャルに書き込む。 On the other hand, the large block card side (right side in the figure), when receiving a write command from the host device 20 side, sequentially writes the data of 16kByte block units based on the logical block address of the small block card into the flash memory 3.

前述のように、ホスト機器２０は、小ブロックの物理アドレスによる１６Byte単位のランダムな書き込み操作を行う。 As described above, the host device 20 performs a random write operations 16Byte unit by the physical address of the small block.このようなランダムな書き込み操作では、一般に、大ブロック（２５６kByte）の一部のみを書き換えるための処理が多発する。 In such a random write operation, in general, processing of rewriting only a part of a large block (256 kBytes) occurs frequently.ＮＡＮＤ型フラッシュメモリではブロック単位でしか消去を行えないため、ブロックの一部のみを書き換える場合は、書き換える新データを消去済みの新ブロックに書き込み、新データに書き換えられる旧データを含む旧ブロックから、書き換えられない残りのデータを新ブロックにコピーする必要がある。 Since the NAND type flash memory can not be performed erased only in blocks, when rewriting only a part of the block, the new data written into the new block erased, and the old block containing old data to be rewritten to new data to be rewritten, it is necessary to copy the remaining data not rewritten to the new block.このように、ブロックの一部のみを書き換える処理は、書き換えられないデータのコピー動作（巻き添えデータコピー）を伴うため、ブロックの一部のみを書き換える処理が多発すると、オーバーヘッドが非常に増大することになる。 Thus, the process of rewriting only a part of the block, to accompany rewritten without data copy (collateral data copy), the process is frequently rewritten only a part of the block, that the overhead is greatly increased Become.そこで、本実施形態では、ホスト機器２０側から得られる論理アドレスの順序に従って、大ブロックカード側で物理アドレスを再度割り当てることにより、ブロックの一部のみの書き込みの発生を低減し、オーバーヘッドの増大を抑制している。 Therefore, in this embodiment, according to the order of the logical address obtained from the host device 20 side, by the large block card side allocates the physical address again, to reduce the occurrence of writing of only a part of the block, the increase in the overhead It is suppressed.

図１１は、大ブロックカード内のＮＡＮＤ型フラッシュメモリ３のブロックフォーマット（消去単位である２５６kByte物理ブロック分）の一例を示す図である。 Figure 11 is a diagram showing an example of a (256 kBytes physical block is erased units) block format of the NAND flash memory 3 in the large block card.

大ブロックカードでは、消去単位である２５６kByte物理ブロックの中に、ホスト機器２０側が管理する単位である１６kByteに相当するデータを書き込むためのブロック（以下、ホスト管理ブロックと称す）が１６個分含まれている。 The large block card, in 256kByte physical block is the erase unit, the host device 20 side for writing data corresponding to 16kByte is a unit for managing blocks (hereinafter, referred to as a host management block) contains 16 min ing.データ書き込みの際には、小ブロックカードにおける論理ブロックアドレスの順に個々のデータが配置される。 During data writing, it is disposed individual data in the order of the logical block addresses in the small block card.

各ホスト管理ブロックは、８個のページで構成される。 Each host management block is composed of eight pages.各ページは、５１２Byteデータ領域を４個分含むと共に、各データ領域に対応する１０ByteＥＣＣ領域を含んでいる。 Each page, with includes 4 pieces of the 512Byte data area includes 10ByteECC region corresponding to each data region.また、ページ中の最後の５１２Byteデータ領域（４番目の５１２Byteデータ領域）の後には、２４Byte管理データ領域も設けられる。 Further, after the last 512Byte data area in the page (fourth 512Byte data area), 24 Bytes management data area is also provided.このため、ページ中の最後の１０ByteＥＣＣ領域は、４番目の５１２Byteデータ領域と２４Byte管理データ領域の両方に対応する構成となっている。 Therefore, the last 10ByteECC area in the page is configured for both the fourth 512Byte data area and 24Byte management data area.

消去単位である２５６kByte物理ブロックに含まれる１２８個の２４Byte管理データ領域のうち、例えば最後の２４Byte管理データ領域には、ホスト機器２０側から送られてくるコマンドから取得された物理ブロックアドレスに相当するアドレス情報、及び論理ブロックアドレスに相当するアドレス情報がまとめて格納されるようになっている。 Of the 128 24Byte management data area included in 256kByte physical block is the erase unit, for example at the end of 24Byte management data area, corresponding to physical block addresses obtained from the command sent from the host device 20 side address information, and address information corresponding to the logical block address is adapted to be stored together.これらのアドレス情報は、図８で説明した小ブロックカード物理・小ブロックカード論理変換層１２が有する第１のテーブルと、小ブロックカード論理・大ブロックカード物理変換層１３が有する第２のテーブルとを作成する際に使用される。 This address information includes a first table having the small block card physical and small block card logical conversion layer 12 described in FIG. 8, a second table having the small block card logic and large block card physical conversion layer 13 It is used to create.

図１２は、大ブロックカード内のＮＡＮＤ型フラッシュメモリ３のブロックフォーマットの他の例を示す図である。 Figure 12 is a diagram showing another example of the block format of the NAND type flash memory 3 in the large block card.

図１２に示すフロックフォーマットは、図１１に示したブロックフォーマットに比べると、各ページにおけるＥＣＣ０、ＥＣＣ１、ＥＣＣ２の領域の配置位置が異なる。 Floc format shown in FIG. 12, as compared to the block format shown in FIG. 11, ECC0 in each page, ECC1, positions of regions of ECC2 is different.ただし、各ページにおけるユーザデータの記憶容量は、図１１に示したブロックフォーマットと図１２に示すブロックフォーマットとで同じである。 However, the storage capacity of the user data in each page is the same in the block format shown in block format and 12 shown in FIG. 11.すなわち、図１１に示したブロックフォーマットでは、各ページに２０４８Byte（５１２Byte＋５１２Byte＋５１２Byte＋５１２Byte）の記憶領域が設けられており、図１２に示すブロックフォーマットでは、各ページに２０４８Byte（５１８Byte＋５１８Byte＋５１８Byte＋４９４Byte）の記憶領域が設けられている。 In other words, in the block format shown in FIG. 11, the storage area is provided in 2048Byte (512Byte + 512Byte + 512Byte + 512Byte) on each page, in the block format shown in FIG. 12, the storage area of ​​2048Byte (518Byte + 518Byte + 518Byte + 494Byte) is provided on each page .以下では、図１２に示したブロックフォーマットを採用した場合を前提にして説明を行う。 The following description assumes a case of adopting the block format shown in FIG. 12.

ホスト機器２０は、メモリカード１が１６kByteの消去ブロックサイズを有する不揮発性メモリであると仮定してメモリカードを制御している。 The host device 20 controls the memory card on the assumption that the memory card 1 is a non-volatile memory having an erase block size of 16 kBytes.例えば、メモリカード１に対する書き込みの際には、ホスト機器２０は、シリアルデータインプットコマンド“８０Ｈ（Ｈは１６進を示す）”をＩ／Ｏピン（ピン１０〜ピン１７）へ入力する。 For example, when writing to the memory card 1, the host apparatus 20, the serial data input command "80H (H represents a hexadecimal)" to a to I / O pin (pin 10 pin 17).次に、ホスト機器２０は、カラムアドレス“Ｃ／Ａ”およびページアドレス“Ｐ／Ａ”を、Ｉ／Ｏピンへ入力する。 Next, the host apparatus 20, the column address "C / A" and page address "P / A", to the I / O pins.なお、ここでカラムアドレス“Ｃ／Ａ”およびページアドレス“Ｐ／Ａ”は、ホスト機器２０がメモリカード１に対して想定している仮想物理アドレス空間におけるカラムアドレスおよびページアドレスである。 Here, the column address "C / A" and page address "P / A" is a column address and a page address in the virtual physical address space by the host device 20 is assumed with respect to the memory card 1.

更に、ホスト機器２０は、書き込みデータを、Ｉ／Ｏピン（ピン１０〜ピン１７）の個々に対し、５２８回入力する。 Further, the host apparatus 20, the write data to each of the I / O pins (pins 10 to pin 17), and inputs 528 times.具体的には、ホスト機器２０はライトイネーブルピンへの入力信号を５２８回クロッキングしながら、それぞれのＩ／Ｏピンに対し５２８ビット（すべてのＩ／Ｏピン合計で５２８バイト）のデータを順次シフトインする。 Specifically, while the host device 20 is 528 times clocking input signal to the write enable pin, the data of 528 bits for each I / O pin (all I / O pins in total 528 bytes) sequentially to shift in.データのシフトインが完了すると、ホスト機器２０は、プログラムコマンド“１０Ｈ”をＩ／Ｏピンへ入力する。 When the shift-in of data is completed, the host device 20, to enter a program command "10H" to the I / O pin.これに応答してメモリカード１は、そのＲ／−Ｂピンに“Ｌ”の信号を出力し、メモリカード１がビジー状態であることを示す。 Memory card 1 in response thereto outputs a signal of "L" to the R / -B pin, indicating that the memory card 1 is busy.その後、所定期間後にＲ／−Ｂピンに“Ｈ”の信号を出力することでメモリカードがレディ状態になったことを示す。 Thereafter, indicating that the memory card is ready by outputting a signal of "H" to R / -B pin after a predetermined period of time.

しかしながら、図１３におけるＲ／−Ｂピンの状態は、あくまでもホスト機器２０に対してメモリカード１がどのような状態かを示すものである。 However, the state of the R / -B pin in FIG. 13 is merely intended to indicate what state the memory card 1 to the host device 20.つまり、図１３において、プログラムコマンド“１０Ｈ”の入力に応答して、Ｒ／−Ｂピンがビジー状態（つまり“Ｌ”を出力）を示したとしても、内部でＮＡＮＤ型フラッシュメモリ３に対する書き込み動作（つまり、ページバッファからメモリセルアレイへのデータ転送）が実際に行われているとは限らない。 That is, in FIG. 13, in response to an input of the program command "10H", R / -B pin even showed busy (output clogging "L"), the write operation to the NAND type flash memory 3 inside (i.e., data transfer from the page buffer to the memory cell array) is not always actually performed.また、Ｒ／−Ｂピンがレディ状態に復帰したとしても、内部でＮＡＮＤ型フラッシュメモリ３に対する書き込み動作が実際に完了しているとは限らない。 Further, R / -B even pin is returned to the ready state, not necessarily write operation to the NAND flash memory 3 inside has actually been completed.

図１４は、本実施形態のメモリカード１内のＮＡＮＤ型フラッシュメモリ３に対して、メモリカード１内のコントローラ４が書き込みを行う際に、ＮＡＮＤ型フラッシュメモリ３のＩ／Ｏピン１〜８とＲ／−Ｂ(Ready/Busy)ピンに入出力される信号例を示すタイミングチャートである。 14, the NAND flash memory 3 of the memory card 1 of this embodiment, the controller 4 in the memory card 1 when writing, the I / O pins 1-8 of the NAND flash memory 3 a R / -B (Ready / Busy) a timing chart showing an example of a signal input to and output from the pin.なお、ＮＡＮＤ型フラッシュメモリ３、及びメモリインタフェース部５は、図３に示したホストインタフェース部６が有するピンと同様に、コマンド、アドレス、及びデータが入出力されるＩ／Ｏピン１〜８、レディ・ビジー信号を出力するＲ／−Ｂ(Ready/Busy)ピン、データを出力させるリードイネーブル信号が入力される−ＲＥ(Read Enable)ピンを有している。 Incidentally, NAND type flash memory 3, and memory interface unit 5, similar to the pin having the host interface unit 6 shown in FIG. 3, the command, address, and I / O pins 1-8 which data is input and output, the ready busy signal and outputs the R / -B (Ready / busy) pin, the read enable signal for outputting data has a -RE (read enable) pin input.さらに、ＮＡＮＤ型フラッシュメモリ３を動作モードにするチップイネーブル信号が入力される−ＣＥ(Card Enable)ピン、コマンドの取り込みをコントロールするためのコマンドラッチイネーブル信号が入力されるＣＬＥ(Command Latch Enable)ピン、アドレス、及び入力データの取り込みをコントロールするためのアドレスラッチイネーブル信号が入力されるＡＬＥ(Address Latch Enable)ピンを有している。 Furthermore, CLE of -CE (Card Enable) pin chip enable signal to the NAND type flash memory 3 to the operation mode is entered, a command latch enable signal to control the uptake of command input (Command Latch Enable) pin has address, and the ALE (address latch enable) pin address latch enable signal to control the incorporation of the input data is input.さらに、データをＮＡＮＤ型フラッシュメモリ３に書き込むためのライトイネーブル信号が入力される−ＷＥ(Write Enable)ピン、書き込み、及び消去を強制的に禁止させるためのライトプロテクト信号が入力される−ＷＰ(Write Protect)ピンを有している。 Furthermore, -WP -WE the write enable signal for writing data to the NAND type flash memory 3 is input (Write Enable) pin, write, and the write protect signal for forcibly prohibit erasing is inputted ( It has a Write Protect) pin.

更に、コントローラ４は、書き込みデータを、Ｉ／Ｏピン１〜８の個々に対し、２１１２回入力する。 Furthermore, the controller 4, the write data to each of the I / O pins 1-8, inputs 2112 times.具体的には、コントローラ４は、ライトイネーブルピンへの入力信号を２１１２回クロッキングしながら、それぞれのＩ／Ｏピンに対し２１１２ビット（すべてのＩ／Ｏピン合計で２１１２バイト）のデータを順次シフトインする。 Specifically, the controller 4, while 2112 times clocking input signal to the write enable pin, the data of 2112 bits for each I / O pin (all I / O pins in total 2112 bytes) sequentially to shift in.データのシフトインが完了すると、コントローラ４は、プログラムコマンド“１０Ｈ”をＩ／Ｏピン１〜８へ入力する。 When the shift-in data is completed, the controller 4 inputs a program command "10H" to the I / O pins 1-8.これに応答してメモリカード１は、そのＲ／−Ｂピンに“Ｌ”の信号を出力し、メモリカードがビジー状態であることを示す。 Memory card 1 in response thereto outputs a signal of "L" to the R / -B pin, indicating that the memory card is busy.その後、所定期間後にＲ／−Ｂピンに“Ｈ”の信号を出力することでメモリカードがレディ状態になったことを示す。 Thereafter, indicating that the memory card is ready by outputting a signal of "H" to R / -B pin after a predetermined period of time.図１４におけるＲ／−Ｂピンの状態は、コントローラ４に対してＮＡＮＤ型フラッシュメモリ３が実際にどのような状態かを示すものである。 State of R / -B pin in Figure 14, the NAND type flash memory 3 illustrates actually what state the controller 4.

なお、前記図１３および図１４においては、カラムアドレス“Ｃ／Ａ”およびページアドレス“Ｐ／Ａ”の入力をそれぞれ１つのサイクルで示しているが、メモリカード１の容量またはＮＡＮＤ型フラッシュメモリ３の容量に応じて、適宜２サイクル以上になる場合もある。 Incidentally, FIG. 13 in FIG. 14 and are shown column address "C / A" and an input page address "P / A" in each one cycle, the capacity of the memory card 1 or NAND type flash memory 3 depending on the capacity, it may become more suitably 2 cycles.

この発明の実施形態のメモリカード及びその制御方法によれば、メモリカードが搭載したＮＡＮＤ型フラッシュメモリの仕様に明記されておらず、かつ禁止もされていないシーケンスでコマンドを発行してくるホスト機器に対して、正常に応答すること可能である。 According to the memory card and its control method according to the embodiment of the invention, the host device coming to issue commands in the sequence memory card has not been specified in the specification of NAND-type flash memory mounted, and not also prohibited respect, it is possible to respond normally.

なお、前述した実施形態は唯一の実施形態ではなく、前記構成の変更あるいは各種構成の追加によって、様々な実施形態を形成することが可能である。 The embodiments described above are not the only embodiment, the additional changes or various configurations of the arrangement, it is possible to form various embodiments.

この発明の実施形態のメモリカードの構成を示すブロック図である。 Is a block diagram showing the configuration of an embodiment a memory card of the present invention.本実施形態のメモリカードの外形とピン配置を示す平面図である。 Is a plan view showing the outer shape and pinout of the memory card of the present embodiment.本実施形態のメモリカードのピンアサインを示す図表である。 It is a table showing pin assignment of a memory card of the present embodiment.本実施形態のメモリカードに入力されたコマンドシーケンスを処理する制御手順の一例を示すフローチャートである。 It is a flowchart illustrating an example of a control procedure for processing a command sequence input to the memory card of the present embodiment.本実施形態のメモリカードに入力されるＩＤリードコマンドのコマンドシーケンスの一例を示すタイミングチャートである。 An example of a command sequence ID read command is input to the memory card of the present embodiment is a timing chart showing.本実施形態のメモリカードに入力されるＩＤリードコマンドのコマンドシーケンスの他の例を示すタイミングチャートである。 Another example of a command sequence ID read command is input to the memory card of the present embodiment is a timing chart showing.ホスト機器が想定しているフラッシュメモリと、メモリカード内のＮＡＮＤ型フラッシュメモリのデータ配置を示す図である。 The flash memory by the host device is assumed, it is a diagram showing a data arrangement of a NAND type flash memory in the memory card.ホスト機器側システム及びメモリカードにおける各コミュニケーション階層を示す図である。 Is a diagram showing each communication layer in the host equipment side system and a memory card.ホスト機器から送られてくるコマンドのフォーマットを示す図である。 It is a diagram showing a format of a command sent from the host device.ホスト機器が想定しているブロック書き込み操作と、メモリカードが実際に行う書き込み処理とを対比して示す図である。 A block write operation by the host device is assumed illustrates by comparing the write processing memory card actually performed.メモリカード内のＮＡＮＤ型フラッシュメモリのブロックフォーマットの一例を示す図である。 Is a diagram illustrating an example of a block format of the NAND type flash memory in the memory card.メモリカード内のＮＡＮＤ型フラッシュメモリのブロックフォーマットの他の例を示す図である。 It is a diagram showing another example of the block format of the NAND type flash memory in the memory card.本実施形態のメモリカードに対してホスト機器が書き込みを行う際に、メモリカードのＩ／ＯピンとＲ／−Ｂピンに入出力される信号例を示すタイミングチャートである。 When the host device to the memory card of the present embodiment writes a timing chart showing an example of a signal input to and output from the I / O pins and R / -B pin of the memory card.本実施形態のメモリカード内のＮＡＮＤ型フラッシュメモリに対してコントローラが書き込みを行う際に、ＮＡＮＤ型フラッシュメモリのＩ／ＯピンとＲ／−Ｂピンに入出力される信号例を示すタイミングチャートである。 When the controller writes to the NAND flash memory in the memory card of this embodiment is the timing chart showing an example of a signal input to and output from the I / O pins and R / -B pin of the NAND flash memory .

Claims (5)

Translated from Japanese

ホスト機器から出力された第１の不揮発性半導体メモリに対するコマンドシーケンスを受け取るホストインタフェース部と、 A host interface unit for receiving a command sequence for the first nonvolatile semiconductor memory output from the host device,前記ホスト機器から出力された前記第１の不揮発性半導体メモリに対する前記コマンドシーケンスを処理し前記コマンドシーケンスに応じて、第２の不揮発性半導体メモリに対するデータの書き込み、読み出し及び消去の動作を制御する処理回路と、 Processing said for the first nonvolatile semiconductor memory output from the host device in response to processing the command sequence the command sequence, the data for the second nonvolatile semiconductor memory write, controls the operation of the read and erase and the circuit,を具備し、Equipped with,前記処理回路は、Wherein the processing circuit includes前記コマンドシーケンスが含むコマンドが、書き込み、読み出し、消去、ＩＤリード、ステータスリードのいずれであるか判定する処理と、Command including said command sequence, write, read, erase, ID read, and determines processing whether it is a status read,前記コマンドが書き込み、読み出し、消去のいずれかであるとき、アドレスが所定数入力されたか否かを判定する処理と、Writing the command, reading, when either of the erasure, the process of determining whether or not the address has been entered a predetermined number,前記アドレスが所定数入力されたとき、書き込み、読み出し、消去のいずれかを実行する処理と、When the address is entered a predetermined number, the processing to be executed write, read, one of the erase,前記アドレスが所定数入力されないとき、前記ホスト機器からコマンドが入力されたか否かを判定する処理と、When the address is not input a predetermined number, the process of determining whether or not the command has been input from the host device,前記コマンドがＩＤリード、ステータスリードのいずれかであるとき、ＩＤリード、ステータスリードのいずれかを実行する処理と、The command ID read, when either status read, the process for executing any of the ID read, status read,を実行すること特徴とするコントローラ。 Controller to a child and features to run.

ホスト機器に装着され、前記ホスト機器から出力された第１の不揮発性半導体メモリに対するコマンドシーケンスを受け取るメモリカードにおいて、 Is mounted on the host device, the memory card receives a command sequence for the first nonvolatile semiconductor memory output from the host device,データの書き込み、読み出し及び消去が行われる第２の不揮発性半導体メモリと、 A second nonvolatile semiconductor memory of the data write, read and erase is carried out,前記ホスト機器から出力された前記第１の不揮発性半導体メモリに対する前記コマンドシーケンスを処理し前記コマンドシーケンスに応じて、前記第２の不揮発性半導体メモリに対するデータの書き込み、読み出し及び消去の動作を制御するコントローラと、 Wherein for said first non-volatile semiconductor memory output from the host device to process the command sequence in response to said command sequence, the second data to the non-volatile semiconductor memory write, controls the operation of the read and erase and a controller,を具備し、Equipped with,前記コントローラは、前記ホスト機器から出力された前記コマンドシーケンスを処理する制御手段を有し、前記制御手段は、The controller includes a control means for processing the command sequence that is output from the host device, wherein,前記コマンドシーケンスが含むコマンドが、書き込み、読み出し、消去、ＩＤリード、ステータスリードのいずれであるか判定するステップと、Command said command sequence comprises is a write, read, erase, and determining whether it is ID read, the status read,前記コマンドが書き込み、読み出し、消去のいずれかであるとき、アドレスが所定数入力されたか否かを判定するステップと、Writing the command, reading, when either of the erase, determining whether the address is entered a predetermined number,前記アドレスが所定数入力されたとき、書き込み、読み出し、消去のいずれかを実行するステップと、When the address is entered a predetermined number, and executing write, read, one of the erase,前記アドレスが所定数入力されないとき、前記ホスト機器からコマンドが入力されたか否かを判定するステップと、When the address is not input a predetermined number, and determining whether the command is input from the host device,前記コマンドがＩＤリード、ステータスリードのいずれかであるとき、ＩＤリード、ステータスリードのいずれかを実行するステップと、When the command is either ID read, status read, and executing one of the ID read, status read,を具備すること特徴とするメモリカード。 Memory card, characterized by comprising a.

前記第１の不揮発性半導体メモリが有する第１の消去ブロックサイズは、前記第２の不揮発性半導体メモリが有する第２の消去ブロックサイズとは異なることを特徴とする請求項２に記載のメモリカード。 The first erase block size having a first nonvolatile semiconductor memory is a memory card of claim 2, wherein different from the second erase block size in the second nonvolatile semiconductor memory having .

ホスト機器に装着され、前記ホスト機器からアクセスされるメモリカードの制御方法において、 Is attached to a host device, a control method for a memory card to be accessed from said host device,前記ホスト機器から出力された第１の不揮発性半導体メモリに対するコマンドシーケンスが含むコマンドが、書き込み、読み出し、消去、ＩＤリード、ステータスリードのいずれであるか判定するステップと、First nonvolatile semiconductor memory command sequence includes for command, writing, reading, erasing, and determining whether it is ID read, the status read output from the host device,前記コマンドが書き込み、読み出し、消去のいずれかであるとき、アドレスが所定数入力されたか否かを判定するステップと、 Writing the command, reading, when either of the erase, determining whether the address is entered a predetermined number,前記アドレスが所定数入力されたとき、 前記コマンドシーケンスに応じて、第２の不揮発性半導体メモリに対するデータの書き込み、読み出し、消去のいずれかを実行するステップと、 When the address is entered a predetermined number, comprising the steps of: in response to the command sequence to perform the data for the second nonvolatile semiconductor memory write, read, one of the erase,前記アドレスが所定数入力されないとき、前記ホスト機器からコマンドが入力されたか否かを判定するステップと、 When the address is not input a predetermined number, and determining whether the command is input from the host device,前記コマンドがＩＤリード、ステータスリードのいずれかであるとき、ＩＤリード、ステータスリードのいずれかを実行するステップと、 When the command is either ID read, status read, and executing one of the ID read, status read,を具備することを特徴とするメモリカードの制御方法。 Control method for a memory card, characterized by comprising.

前記第１の不揮発性半導体メモリが有する第１の消去ブロックサイズは、前記第２の不揮発性半導体メモリが有する第２の消去ブロックサイズとは異なることを特徴とする請求項４に記載のメモリカードの制御方法。The first erase block size having a first nonvolatile semiconductor memory is a memory card of claim 4, wherein different from the second erase block size in the second nonvolatile semiconductor memory having control method of.

JP2004273895A2004-09-212004-09-21 Controller, memory card and a method of controlling the same Expired - Fee RelatedJP4406339B2
(en)