The present invention relates to a nonvolatile storage device, such as a semiconductor memory card or the like, including a flash memory as a main storage memory, and a memory controller built therein, and further to a nonvolatile storage system having an access device as its component and a memory control method describing operation of the memory controller.
There have been increasing demands for nonvolatile storage devices, mainly in semiconductor memory cards, provided with a rewritable nonvolatile memory. There have also been increasing demands for nonvolatile storage systems, mainly in digital still cameras and the like, using a semiconductor memory card. There are various kinds of semiconductor memory cards, and, for example, an SD memory card is composed of a flash memory as a main storage part and a memory controller for controlling it. The memory controller is a device which executes read and write control to the flash memory in accordance with read and write instructions provided from an access device such as a digital still camera main body or the like.
The flash memory has limitation that the guaranteed number of times of rewriting thereon is usually 100,000 times. Thus, in order to avoid rewriting concentrated on a particular area, a mechanism called wear leveling is employed. This mechanism prevents rewriting concentrated on a particular area by converting a logical address provided from an access device to the flash memory into a physical address, and the conversion is usually achieved based on an address management table inside the memory controller. Usually, after the address management information stored in the flash memory is read in initialization processing at power startup, the address management table is formed in a volatile memory, such as an SRAM or the like, based on the address management information.
As forms in which the address management information is stored in the flash memory, there are two major methods. The first method is a method which, when data are written on a page (sector) forming a physical block, writes management information, that is, status information indicating whether or not this data is valid and the like and a logical address into a redundant area of the top page of a physical block where the aforementioned page is included, reads the management information written in the redundant area of the top page of each block at initialization, and constructs an address management table in a volatile memory. Hereinafter, this method is called a distributed address management method.
The second method is a method which stores, for an entire memory area of the memory card or for each of areas obtained by dividing the entire memory area into a predetermined number, address management tables corresponding to this entire area collectively in predetermined blocks instead of storing the address management information in a distributed manner in units of blocks. Hereinafter, this method is called a concentrated address management method.
The present invention is premised on the concentrated address management method, and as conventional technique thereof, a technique is disclosed in Patent document 1 is known, for example.
In a device described in Patent document 1, an address management table is allocated to a fixed area of a flash memory. Since frequency of rewriting the address management tables is usually higher than the frequency of rewriting data, there has been a problem that the area to which the address management table is allocated exceeds the guaranteed number of times of rewriting in a short time, that is, a life time of an entire nonvolatile storage device shortens.
As a technique for solving this problem, for example, the technique described in Patent document 2 is known. Patent document 2 discloses the technique where data rewritten at high frequency, such as an address management table or the like, is not stored in a fixed area of a flash memory but stored in a nonvolatile memory, for example, a nonvolatile RAM such as an FeRAM (ferroelectric memory) or the like, whose guaranteed number of times of rewriting is larger than that of the flash memory. More specifically, both a logical-physical conversion table and a physical area management table as address management information are stored in the nonvolatile RAM, on that basis, rewriting processing is performed. The physical area management table is a table storing a valid flag indicating whether or not valid data is stored in a physical block and a bad block flag indicating whether or not the physical block is a bad block.
However, Patent document 2 has following drawbacks. First, the nonvolatile RAM such as the FeRAM is very costly compared to a flash memory, an SRAM and the like, and thus largely influences the price of the memory controller. For example, assume that a memory card of 128 MBytes is realized by using one flash memory shown in table 1.
In this case, sizes of the respective tables are as follows:
According to the formulas (1) to (3), the size of the address management table, that is, the size of the nonvolatile RAM needs to be approximately 18 kBytes. Thus, there has arisen a problem that the memory controller becomes costly.
Further, in the nonvolatile storage device disclosed in Patent document 2, in the event of power-off during data writing, a method of judging the validity of the data, that is, a method of coping with power-off is not disclosed in detail. Thus, there is a drawback that the reliability is insufficient.
The present invention has been made to solve the abovementioned problems, and intends to provide a memory controller, a nonvolatile storage device, a nonvolatile storage system, and a memory control method capable of coping with power-off appropriately and also achieving long life without involving much cost increase.
To solve the problem, a memory controller of the present invention is a memory controller for writing and reading data to a nonvolatile main storage memory in accordance with a command and a logical address provided by an access device, wherein said memory controller comprises: a read and write control means for performing read and write control on said main storage memory; a volatile memory for temporarily storing a logical-physical conversion table read from said main storage memory; a nonvolatile auxiliary storage memory for storing a physical area management table managing status of each physical address of said main storage memory, and pointers pointing a physical address of a logical-physical conversion table stored in said main storage memory; and an address management information control means for determining, based on said logical-physical conversion table, a physical address as storage position including data in said main storage memory and for performing update of said logical-physical conversion table and pointer information, wherein said auxiliary memory is a nonvolatile memory having a larger guaranteed number of times of rewriting performed thereon than a guaranteed number of times of rewriting performed on said main storage memory, and said address management information control means, by appropriately updating by said pointer the physical address as the storage position of said logical-physical conversion table, avoids the storage position of said logical-physical conversion table from being fixed, and after data in said main storage memory is changed, sets a changed physical address of the data to be a valid status in said physical area management table.
To solve the problem, a nonvolatile storage device of the present invention is a nonvolatile storage device comprising: a nonvolatile main storage memory and a memory controller for writing and reading data to said main storage memory in accordance with a command and a logical address provided from an access device, wherein said main storage memory is a nonvolatile memory composed of a plurality of physical blocks including at least one sector respectively, wherein said memory controller comprises: a read and write control means for performing read and write control on said main storage memory; a volatile memory for temporarily storing a logical-physical conversion table read from said main storage memory; a nonvolatile auxiliary storage memory for storing a physical area management table managing status of each physical address of said main storage memory, and pointers pointing a physical address of a logical-physical conversion table stored in said main storage memory; and an address management information control means for determining, based on said logical-physical conversion table, a physical address as a storage position of data in said main storage memory and for performing update of said logical-physical conversion table and pointer information, wherein said auxiliary memory is a nonvolatile memory having a larger guaranteed number of times of rewriting performed thereon than a guaranteed number of times of rewriting performed on said main storage memory, and wherein said address management information control means, by appropriately updating by said pointer the physical address as the storage position of said logical-physical conversion table, avoids the storage position of said logical-physical conversion table from being fixed, and after the data in said main storage memory is changed, sets a written physical address of the data to be a valid status in said physical area management table.
To solve the problem, a nonvolatile storage system of the present invention is a nonvolatile storage system comprising: an access device and a nonvolatile storage device having a nonvolatile main storage memory and a memory controller, for writing and reading data to said main storage memory in accordance with a command and a logical address provided from said access device, wherein said main storage memory is a nonvolatile memory composed of a plurality of physical blocks including at least one sector respectively, wherein said memory controller comprises: a read and write control means for performing read and write control on said main storage memory; a volatile memory for temporarily storing a logical-physical conversion table read from said main storage memory; a nonvolatile auxiliary storage memory for storing a physical area management table managing status of each physical address of said main storage memory, and pointers pointing a physical address of a logical-physical conversion table stored in said main storage memory; and an address management information control means for determining, based on said logical-physical conversion table, a physical address as a storage position of data in said main storage memory and for performing update of said physical area management table and pointer information, wherein said auxiliary memory is a nonvolatile memory having a larger guaranteed number of times of rewriting performed thereon than a guaranteed number of times of rewriting performed on said main storage memory, and wherein said address management information control means, by appropriately updating by said pointer the physical address as the storage position of said logical-physical conversion table, avoids the storage position of said logical-physical conversion table from being fixed, and after the data in said main storage memory is changed, sets a changed physical address of the data to be valid status in said physical area management table.
To solve the problem, a memory control method of the present invention is a memory control method for writing and reading data to a nonvolatile main storage memory in accordance with a command and a logical address provided from outside comprising steps of: performing read and write control on said main storage memory and temporarily storing a logical-physical conversion table read from said main storage memory in a nonvolatile memory; storing, in an auxiliary storage memory being nonvolatile and having a larger number of times of rewriting performed thereon than a guaranteed number of times of rewriting performed on said main storage device, a physical area management table managing status of each physical address of said main storage memory, and pointers pointing a physical address of a logical-physical conversion table stored in said main storage memory; determining, based on said logical-physical conversion table, a physical address as a storage position of data in said main storage memory and performing update of said physical area management table and pointer information; avoiding the storage position of said logical-physical conversion table from being fixed by appropriately updating by said pointer the physical address as the storage position of said logical-physical conversion table; and setting a written physical address of the data to be a valid status in said physical area management table after the data in said main storage memory is written.
The present invention is premised on the concentrated address management method and mainly has the following characteristics.
(1) Only a physical area management table of address management tables is stored on a nonvolatile auxiliary storage memory, and a logical-physical conversion table is stored in the main storage memory and once read in the volatile memory for reference.
(2) In order that the logical-physical conversion table is not rewritten for update on a fixed area of the main storage memory, a pointer indicating the storage position thereof is stored in the nonvolatile auxiliary memory and the pointer value is sequentially updated to thereby rewrite for update the logical-physical conversion table on the main storage memory in a rearranging manner. The pointer is updated on the nonvolatile auxiliary memory having a high rewriting endurance, thus causing no problems related to the number of times of rewriting the pointer.
(3) After data is written into the main storage memory, information corresponding to the data in the physical area management table is updated. Even in the event of power-off, the validity of various data can be judged if the information is checked, thus no logical inconsistency.
As described above, address management tables include two: a logical-physical conversion table; and a physical area management table. In the present invention, a main storage memory stores a logical-physical conversion table of a large storage demands and a nonvolatile auxiliary storage memory stores a physical area management table of a small storage demands, thus a lower-cost nonvolatile storage device can be achieved compared to the conventional technique described in Patent document 2. Moreover, the status of each data is stored on the physical area management table, so that the information is held even in the event of power-off, thus it can be possible to judge whether or not each data is valid after power is turned on again, which in turn permits an improvement of the reliability at power-off.
Next, an internal configuration of the memory controller 130 will be described. 101 denotes a host I/F, and a CPU 102 performs overall control inside the memory controller 130 with a work RAM 103 and a ROM 104 storing programs. A physical area management table 105 is a table storing information such as status of physical blocks as an erasing unit in the nonvolatile main storage memory 140, that is, whether or not valid data is stored. A pointer table 106 is a table storing pointers pointing the address of a physical block storing, of respective logical-physical conversion information stored in the nonvolatile main storage memory 140, at least the latest logical-physical conversion information. A nonvolatile auxiliary storage memory 107 stores the physical area management table 105 and the pointer table 106. A logical-physical conversion table 108 is a table which converts a logical address transferred by the access device 100 into a physical address in the nonvolatile main storage memory 140, and the logical-physical conversion table 108 is temporarily stored in a volatile memory 109 (for example, SRAM). A read and write controller 111 is a controller which performs reading and writing on the nonvolatile main storage memory 140, and the like. The nonvolatile main storage memory 140 is, for example, a flash memory, and the auxiliary storage memory 107 is a nonvolatile memory, for example, a ferroelectric memory (FeRAM) or the like.
Operation of the nonvolatile storage device configured as described above will be described.
After power is turned on, the CPU 102 performs initialization processing based on a program stored in the ROM 104. In the initialization, an address management information controller 110 refers to the pointer table 106. Then, as shown in
Well, the nonvolatile storage device of the present embodiment uses a nonvolatile RAM having a higher rewriting endurance and faster writing speed in small capacity than the flash memory of the main storage memory.
The nonvolatile memory RAM having the characteristics as described above can be said to be a most suitable device in terms of performance as a device for storing data which is rewritten with high frequency and which needs to be written at a high speed (for example, address management information) in a nonvolatile storage device having a flash memory or the like as a main storage memory. However, compared to the flash memory and the SRAM, the nonvolatile memory RAM is relatively costly and thus has a problem that it cannot store much data. For example, to store both the logical-physical conversion table 108 and the physical area management table 105, a cost aspect cannot be ignored. This problem becomes more notable as the storage capacity of the entire device becomes larger. Thus, in the present embodiment, in order to cope with the cost problem, data of a relatively small size, that is, the physical area management table 105 and the pointer table 106 are stored in the nonvolatile memory RAM. Under a condition that a status of each physical block is stored in 2 bits as shown in
Next, an address management method will be described. The nonvolatile main storage memory 140 is composed of a plurality of physical blocks. Each of the physical blocks stores data or logical-physical conversion information that is a part of address management information, and assume that, for example, the logical-physical conversion information is stored as logical-physical conversion information A, B, C, . . . as shown in
While power is not turned off, data read and write processing is performed with constantly referring to the logical-physical conversion table 108. At each time when the logical-physical conversion table 108 is updated in accordance with data write or the like, the logical-physical conversion table 108 is written back to the nonvolatile main storage memory 140.
Next, writing back to the nonvolatile main storage memory 140 will be described. First, an invalid block is searched for based on the physical area management table 105, and after the invalid block is erased, the logical-physical conversion table 108 is written back to the main storage memory 140. The physical address (where the physical address is X) of the invalid block described above is written into the pointer of the pointer table 106, having a value 0 set for the latest flag, and a value 1 is set for this latest flag. Then, a value 0 is set for the latest flag of the other pointer. That is, the two pointers are used alternately.
Finally in the physical area management table 105, a status flag of the physical address X is updated to a value 00 in a binary number, that is, a valid block. Operation of updating the status flag in the physical area management table 105 is performed not only at processing of writing back the logical-physical conversion table 108 but also at data writing. As can be understood from the processing described above, the physical area management table 105 and the pointer table 106 are rewritten frequently, but the nonvolatile auxiliary storage memory 107 storing them is achieved by a nonvolatile memory RAM having a very high rewriting endurance as shown in table 2 and thus has no influence on a rewrite life of the entire device.
Now, a series of the write processing described above will be described referring to
Next, data of one cluster is written into the block “a” (S805). Since it takes a time of approximately 300 psec to write one page of data, it takes roughly 10 msec to write one cluster, that is, data of 32 pages (
When the writing has been completed, the logical-physical conversion table 108 on the volatile memory 109 is written into the block “b” (S807). The address management information controller 110 judges whether or not write-back processing for all, that is, 32 pages of the logical-physical conversion table 108 has been completed (S808). Assume that a time of writing into the blocks “a” and “b” is T1 as shown in
Now, in
The processing of writing one cluster of data has been described using
The description has been given referring to an example in which a ferroelectric memory (FeRAM) is used as a nonvolatile auxiliary storage memory, but not only the FeRAM, but also a different nonvolatile RAM, such as a magnetic random access memory (MRAM), an ovonic unified memory (OUM), a resistance RAM (RRAM), or the like can be used. These nonvolatile RAMs exhibit substantially the characteristic shown in Table 2.
As described above, in the information for performing address management of the nonvolatile main storage memory 140, the logical-physical conversion information corresponding to the logical-physical conversion table 108 is stored in the main storage memory 140 achieved by a relatively low-cost flash memory, while the physical area management table 105 is stored in the auxiliary storage memory 107 achieved by a relatively high-cost nonvolatile RAM, and further approximately the pointer table 106 of several Bytes is stored in the auxiliary storage memory 107. Compared to a conventional device storing both the logical-physical conversion table 108 and the physical area management table 105 in the nonvolatile RAM, the capacity of the nonvolatile RAM can be rationalized. That is, costs of the device as a whole can be kept low.
Moreover, the address management information controller 110, based on the pointer table 106 and the physical area management table 105, performs the processing of writing the logical-physical conversion table 108 back to the nonvolatile main storage memory 140 in a rearranging manner. That is, the logical-physical conversion information is not assigned to a fixed area of the main storage memory 140, thus permitting achieving wear leveling with simple circuit configuration.
The physical area management table 105 is stored in the auxiliary storage memory 107 capable of a high-speed writing, and after the address management information controller 110 writes data and the logical-physical conversion table 108 to the nonvolatile main storage memory 140, a status flag corresponding to the physical area management table 105 is set in a valid block, thus causing no problem leading to logical inconsistency even in the event of power shut off.
A nonvolatile storage device according to the present invention uses a nonvolatile memory as a main storage memory, proposes technique which achieves a low cost and a high reliability without damaging a high-speed processing performance in a device using a nonvolatile auxiliary storage memory, and is useful as a recording medium of a portable AV equipment such as a still image recording and reproduction device, a moving image recording and reproduction device, or the like, or a portable communication appliance such as a mobile phone or the like.
Number | Date | Country | Kind |
---|---|---|---|
2004-371858 | Dec 2004 | JP | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP05/21119 | 11/17/2005 | WO | 00 | 9/21/2007 |