To provide a memory system which determines a memory state such as an exhaustion level and allows a memory to be efficiently used.
The memory system includes a NAND type flash memory 1 in which data can be electrically written/erased, a nonvolatile memory 2 which counts the number of erase operations of the NAND type flash memory 1 and retains the number of erase operations and a maximum number of erase operations, and a controller 3 which has a connection interface 31 to be given a self-diagnosis command from a computer 4, and retrieves the number of erase operations and the maximum number of erase operations from the nonvolatile memory 2 based on the self-diagnosis command and outputs the number of erase operations and the maximum number of erase operations to the computer 4 through the connection interface 31.
|
0. 29. A method of operating a host device capable of communicating with a memory device including 1) a semiconductor memory comprising a plurality of blocks, the semiconductor memory configured to perform an erase operation by units of the blocks, the semiconductor memory being a nonvolatile semiconductor memory, the semiconductor memory configured to store data, and 2) a random access memory, and 3) a controller configured to control transferring data to the semiconductor memory, the controller electrically connected to the host device, the controller configured to count a number of the erase operations of each of the blocks and measure a total time required for writing data in the semiconductor memory, the random access memory retaining the number of erase operations, the memory device not being included in the host device,
the method comprising:
performing a process, the process comprising:
issuing a self-diagnosis command to the memory device;
receiving from the memory device a response to the self-diagnosis command, the response comprising a total of the number of the erase operations, the measured total time required for writing the data, and a maximum number of the erase operations; and
determining based on the total of the number of the erase operations, the maximum number of the erase operations, and the measured total time whether backup of the data is needed.
0. 34. A method of operating a host device configured to communicate with a memory device including 1) a semiconductor memory comprising a plurality of blocks, the semiconductor memory configured to perform an erase operation by units of the blocks, the semiconductor memory being a nonvolatile semiconductor memory, 2) a random access memory and 3) a controller configured to control transferring data to the semiconductor memory, the controller electrically connected to the host device, the controller configured to count a number of the erase operations of each of the blocks and measure a total time required for writing data in the semiconductor memory, the random access memory retaining the number of erase operations, the memory device not being included in the host device,
the method comprising:
issuing a self-diagnosis command to the memory device;
receiving from the memory device a response to the self-diagnosis command, the response comprising a total of the number of the erase operations, the measured total time required for writing the data, and a maximum number of the erase operations;
calculating an exhaustion level based on the total of the number of the erase operations; and
determining whether the exhaustion level is greater than a first predetermined threshold and whether the measured total time required for writing the data is greater than a second predetermined threshold.
0. 24. A method of operating a host device capable of communicating with a memory device including 1) a semiconductor memory comprising a plurality of blocks, the semiconductor memory configured to perform an erase operation by units of the blocks, the semiconductor memory being a nonvolatile semiconductor memory, and 2) a random access memory, and 3) a controller configured to control transferring data to the semiconductor memory, the controller electrically connected to the host device, the controller configured to count a number of the erase operations of each of the blocks and measure a total time required for writing data in the semiconductor memory, the random access memory retaining the number of erase operations, the memory device not being included in the host device,
the method comprising:
performing a process, the process comprising:
issuing a self-diagnosis command to the memory device;
receiving from the memory device a response to the self-diagnosis command, the response comprising a total of the number of the erase operations, the measured total time required for writing the data, and a maximum number of the erase operations; and
determining whether an exhaustion level of the memory device is greater than a predetermined threshold, wherein:
the performing the process is repeated a plurality of times before the exhaustion level becomes greater than the predetermined threshold,
the process further comprises calculating the exhaustion level based on the total of the number of the erase operations and the measured total time.
0. 19. A method of operating a host device capable of communicating with a memory device including 1) a semiconductor memory comprising a plurality of blocks, the semiconductor memory configured to perform an erase operation by units of the blocks, the semiconductor memory being a nonvolatile semiconductor memory, 2) a random access memory, and 3) a controller configured to control transferring data to the semiconductor memory, the controller electrically connected to the host device, the controller configured to count a number of the erase operations of each of the blocks and measure a total time required for writing data in the semiconductor memory, the random access memory retaining the number of erase operations, the memory device not being included in the host device,
the method comprising:
performing a process, the process comprising:
issuing a self-diagnosis command to the memory device;
receiving from the memory device a response to the self-diagnosis command, the response comprising a total of the number of the erase operations, the measured total time required for writing the data, and a maximum number of the erase operations; and
determining whether an exhaustion level of the memory device is greater than a first predetermined threshold and whether the measured total time required for writing the data is greater than a second predetermined threshold, wherein:
the performing the process is repeated a plurality of times before the exhaustion level becomes greater than the first predetermined threshold; and
the exhaustion level is calculated from the total of the number of the erase operations.
0. 1. A memory system comprising:
a first memory in which data can be electrically written/erased;
a nonvolatile second memory which is random access memory and counts the number of erase operations of the first memory and retains the number of erase operations and a maximum number of erase operations of the first memory;
a controller which is connected to be given a self-diagnosis command from an outside through a connection interface, and which retrieves the number of erase operations and the maximum number of erase operations from the second memory based on the self-diagnosis command and outputs the number of erase operations and the maximum number of erase operations to the outside through the connection interface; and
a time counter which measures a total time required for writing data in the first memory,
wherein the nonvolatile second memory retains the number of erase operations, the maximum number of erase operations, and the time required for writing the data,
the controller outputs the number of erase operations, the maximum number of erase operations, and the time required for writing the data based on the self-diagnosis command, and
the time counter measures total time required for a store operation of the first memory and a verify operation for verifying whether data has been written, when the store operation and the verify operation are repeated.
0. 2. The memory system according to
0. 3. The memory system according to
0. 4. The memory system according to
a timer which measures an energization time,
wherein the second memory retains the number of erase operations, the maximum number of erase operations, and a present energization time, and the controller outputs the number of erase operations, the maximum number of erase operations, and the present energization time based on the self-diagnosis command, the present energization time representing a total time at which the first memory has been energized.
0. 5. The memory system according to
0. 6. The memory system according to
0. 7. The memory system according to
0. 8. The memory system according to
0. 9. The memory system according to
0. 10. A memory system comprising:
a first memory in which data can be electrically written/erased;
a nonvolatile second memory which is random access memory and counts the number of erase operations of the first memory and retains the number of erase operations and a maximum number of erase operations of the first memory;
a controller which is connected to be given a self-diagnosis command from an outside through a connection interface, and which retrieves the number of erase operations and the maximum number of erase operations from the second memory based on the self-diagnosis command and outputs the number of erase operations and the maximum number of erase operations to the outside through the connection interface; and
a time counter which measures a total time required for writing data in the first memory,
wherein the second memory retains the number of erase operations, the maximum number of erase operations, and the time required for writing the data,
the controller outputs the number of erase operations, the maximum number of erase operations, and the time required for writing the data based on the self-diagnosis command, and
the time counter measures total time required for a erase operation of the first memory and a verify operation for verifying whether erase data has been written, when the erase operation and the verify operation are repeated.
0. 11. The memory system according to
0. 12. The memory system according to
0. 13. The memory system according to
a timer which measures an energization time,
wherein the second memory retains the number of erase operations, the maximum number of erase operations, and a present energization time, and the controller outputs the number of erase operations, the maximum number of erase operations and the present energization time based on the self-diagnosis command, the present energization time representing a total time at which the first memory has been energized.
0. 14. The memory system according to
0. 15. The memory system according to
0. 16. The memory system according to
0. 17. The memory system according to
0. 18. The memory system according to
0. 20. The method according to claim 19, the method further comprising causing a display to show the exhaustion level.
0. 21. The method according to claim 20, wherein the exhaustion level is represented in a percentage.
0. 22. The method according to claim 20, wherein, in the causing the display to show the exhaustion level, the exhaustion level is represented by a circle graph.
0. 23. The method according to claim 20, wherein, in the causing the display to show the exhaustion level, the exhaustion level is represented by a line graph.
0. 25. The method according to claim 24, the method further comprising causing a display to show the exhaustion level.
0. 26. The method according to claim 25, wherein the exhaustion level is represented in a percentage.
0. 27. The method according to claim 25, wherein, in the causing the display to show the exhaustion level, the exhaustion level is represented by a circle graph.
0. 28. The method according to claim 25, wherein, in the causing the display to show the exhaustion level, the exhaustion level is represented by a line graph.
0. 30. The method according to claim 29, the method further comprising causing a display to show the determination whether backup of the data is needed.
0. 31. The method according to claim 30, wherein the determination whether backup of the data is needed is represented in a percentage.
0. 32. The method according to claim 30, wherein, in the causing the display to show the determination whether backup of the data is needed, the determination whether backup of the data is needed is represented by a circle graph.
0. 33. The method according to claim 30, wherein, in the causing the display to show the determination whether backup of the data is needed, the determination whether backup of the data is needed is represented by a line graph.
0. 35. The method according to claim 34, the method further comprising causing a display to show the exhaustion level.
0. 36. The method according to claim 35, wherein the exhaustion level is represented in a percentage.
0. 37. The method according to claim 35, wherein, in the causing the display to show the exhaustion level, the exhaustion level is represented by a circle graph.
0. 38. The method according to claim 35, wherein, in the causing the display to show the exhaustion level, the exhaustion level is represented by a line graph.
|
This application is a reissue application of U.S. Pat. No. 8,156,393, which issued from a U.S. national stage application of PCT Application No. PCT/JP2007/072898, filed on Nov. 28, 2007, and is based upon and claims the benefit of priority from prior Japanese Application No. 2006-322868, filed on Nov. 30, 2006, the entire content of which is incorporated herein by reference.
The present invention relates to a memory system.
In recent years, semiconductor memories have been used in various areas such as a main storage of a large-scale computer, a personal computer, a home electric appliance, a mobile phone, and the like. Particularly, a flash memory has such characteristics that data is not erased even if it is powered off, and it has a structure suitable for high integration, and used in information apparatuses such as a mobile phone and a digital camera.
Types of Flash EEPROM nonvolatile memory are mainly an NOR type and an NAND type. As for the NOR type, a read rate is high, the number of read operations is about 1013, and it is used as an instruction code storage. However, the NOR type has a small effective bandwidth for writing, and therefore not suitable for file recording. As for the NAND type, although an access rate is low compared to the NOR type, high integration is allowed, a large number of bits can be stored or erased at the same time is large, and written data can be captured in burst and programming is allowed in page units having many bits. Therefore, the NAND type memory has a large effective bandwidth, and is used for a memory card, a USB memory, a memory of a mobile phone, a memory of a portable music player, and the like. Recently, it is also considered as a replacement of a hard disk (hereinafter referred to as an HDD).
One problem in a case where the NAND type flash memory is as a replacement of an HDD is a problem of system lifetime. An HDD is equipped with a Self-Monitoring, Analysis and Reporting Technology (commonly known as SMART), which is a self-diagnosis function intended for early detection of a failure of the HDD itself and failure prediction, and thereby can notify a user of failure rate. Many of currently manufactured HDDs have this SMART, and predict a failure rate from items including a temperature, an operating time, a spin-up time, the number of alternate sectors (spare areas in which a sector causing bad data is arranged), and the like.
If an NAND type flash memory is also considered to need reliability equivalent to HDDs, it requires a self-diagnosis function like SMART. However, reason of failure in the NAND type flash memory is different from that of the HDDs. Due to characteristics of recoding media of HDDs, they have no limit on the number of write operations, but is susceptible to heat. Further, since they are machine components, there is a problem of aged deterioration of mechanical operation. On the other hand, the NAND type flash memory has little machine components, but consideration should be given to a failure caused by bad data due to an excessive number of store/erase operations. Therefore, a new criterion of system lifetime is needed in consideration of the number of store/erase operations specific to the NAND type flash memory.
A limit on the number of store/erase operations of the NAND type flash memory will be described. For writing (storing/erasing) in a flash memory, high voltage is applied between a substrate and a gate such that electrons are injected and released into a floating gate. If this is performed many times, gate oxide film around the floating gate is deteriorated, and if it is left as is for a long time, the electrons injected into the floating gate get out therefrom, and data is destroyed. In other words, as the number of write operations increases, retention characteristics degrade. The number of write operations of current flash memories is about 105, which is less than that of other nonvolatile memories. Therefore, if it is used as a replacement of an HDD, it is considered that data may be destroyed due to the limit of the number of store/erase operations, causing a trouble of the system. As a measure against such a limit on the number of store/erase operations, wear leveling is performed in which the number of erase operations is counted and a threshold value is set for each block, and physical address translation is performed between a block whose number of erase operations is large and a block whose number of erase operations is small, so that the numbers of store/erase operations are averaged.
Limit on the number of store/erase operations affects not only writing but also reading. During reading from the NAND type flash memory, high voltage is repeatedly applied to a non-selected cell (in view of block units, all pages except a target to be read), causing read disturb in which electrons enter in the floating gate through the gate oxide film and thus change a threshold voltage of a cell so that data is destroyed. In addition, during use, the gate oxide film is degraded due to storing/erasing, and accordingly read disturb occurs more frequently. Recently, NAND type flash memories have been developed to have more advanced multivalued memorization in which more than one bit information is stored in one cell, and therefore the effect of the read disturb seems to be larger. To prevent such read disturb, it is required to perform rewriting in (refresh) a block whose number of read operations is large so as to return a threshold voltage to its original state, which affects the number of store/erase operations.
There has been proposed a storage device which determines a memory state of a flash memory or the like, including: a memory having a main memory area and a spare memory area; display means; and processing means, wherein, when the number of rewrite operations in each address of the main memory area reaches a specified number, information stored in the address is transferred to the spare memory area; and when a remaining capacity of the spare memory area reaches a specified remaining capacity, the display means is driven to notify an operator or the like of a time to replace the memory (see, for example, Japanese Patent Laid-Open No. 2000-181805). However, in such a storage device, an end of memory lifetime for writing is determined to be reached and the memory is replaced in a state where the number of write operations in the spare memory area is still small. Therefore, the memory cannot be efficiently used.
An object of the present invention is to provide a memory system which determines a memory state such as an exhaustion level and allows a memory to be efficiently used.
A memory system according to one aspect of the present invention includes: a first memory in which data can be electrically written/erased; a second memory which counts the number of erase operations of the first memory and retains the number of erase operations and a maximum number of erase operations of the first memory; and a controller which is connected to be given a self-diagnosis command from an outside through a connection interface, and which retrieves the number of erase operations and the maximum number of erase operations from the second memory based on the self-diagnosis command and outputs the number of erase operations and the maximum number of erase operations to the outside through the connection interface.
Further, a memory system according to one aspect of the present invention includes: a first memory in which data can be electrically written/erased; a second memory which monitors an amount of writing and an amount of reading with respect to the first memory, and retains the amount of writing, the amount of reading, and a limiting amount of writing based on a capacity of the first memory and a limiting number of write operations; and a controller which is connected to be given a self-diagnosis command from an outside through a connection interface, and which retrieves the amount of writing, the amount of reading, and the limiting amount of writing from the second memory based on the self-diagnosis command and outputs the amount of writing, the amount of reading, and the limiting amount of writing to the outside through the connection interface.
According to the present invention, a memory state such as an exhaustion level can be determined, and a memory can be efficiently used.
Hereinafter, a memory system according to embodiments of the present invention will be described based on the drawings.
The FeRAM 2 has a counter (not shown), and for wear leveling, counts the number of erase operations in each block of the NAND type flash memory 1 as well as retaining a total of the number of erase operations. In addition, it retains a maximum number of erase operations and a threshold of exhaustion level of the NAND type flash memory 1. The exhaustion level will be described later. The maximum number of erase operations is obtained here from (limiting number of store/erase operations in each block of the NAND type flash memory 1)×(total number of blocks of the NAND type flash memory 1). In addition, FeRAM 2 also has a function as a cache for high-speed reading/writing of the NAND type flash memory 1.
The controller 3 has the connection interface 31, a processing unit (MPU) 32, a FeRAM controller 33, and a memory controller 34. The FeRAM controller 33 controls transferring data retained by the FeRAM 2, and the memory controller 34 controls transferring data to the NAND type flash memory 1. In addition, the memory controller 34 includes an error correction circuit (ECC) 35. When an incorrect value is stored in the NAND type flash memory 1, the memory controller 34 can detect this error and correct it to a correct value. In the NAND type flash memory 1, wear leveling is performed such that the number of store/erase operations in each block is averaged.
As shown in
(Step S1) The processing unit 32 accepts a self-diagnosis command issued by the computer 4.
(Step S2) A total of the number of erase operations, the maximum number of erase operations, and a threshold of exhaustion level are retrieved from the FeRAM 2 and outputted to the computer 4.
(Step S3) The exhaustion level is calculated by the computer 4.
(Step S4) Whether or not the calculated exhaustion level is greater than the threshold is determined. If it is less than or equal to the threshold, the process is terminated. If it is greater than the threshold, the process proceeds to step S5.
(Step S5) A backup alarm sound is emitted from the speaker 6.
(Step S6) The exhaustion level and a backup alarm are displayed on the display unit 5. The step S5 of emitting an alarm sound and the step S6 of displaying an alarm may be replaced with each other.
In the above description, the exhaustion level is calculated from the total of the number of erase operations. However, since the number of erase operations in each block is averaged by wear leveling, an exhaustion level may be calculated from the number of erase operations in each block and a maximum number of erase operations.
In the NAND type flash memory 1, the numbers of rewrite operations are evenly distributed among blocks by wear leveling so that the number of rewrite operations with respect to a whole memory area is increased. A notification of an exhaustion level of the NAND type flash memory 1 can be provided to a user at any time. Backup is recommended when the exhaustion level exceeds a predetermined threshold and comes close to the end of a system lifetime, so that data loss can be prevented before it happens.
As described above, according to the memory system of the first embodiment, a memory state such as an exhaustion level can be determined, and a memory can be efficiently used.
As shown in
The computer 4 calculates an exhaustion level of the NAND type flash memory 1 based on the total of the number of erase operations and the maximum number of erase operations. Further, it calculates the remaining lifetime from the exhaustion level and the energization time. The exhaustion level is a ratio of the total of the number of erase operations to the maximum number of erase operations. A remaining lifetime is represented as (100−exhaustion level)/exhaustion level×energization time. For example, when maximum number of erase operations=1,000,000, total of the number of erase operations=990,000, and energization time=9,900 hours, remaining lifetime equals 100 hours.
If the remaining lifetime is less than a predetermined threshold, the exhaustion level, the remaining lifetime, and a backup alarm are displayed on the display unit 5 as shown in
(Step S11) The processing unit 32 accepts a self-diagnosis command issued by the computer 4.
(Step S12) A total of the number of erase operations, the maximum number of erase operations, an energization time, and a threshold of a remaining lifetime are retrieved from the FeRAM 2 and outputted to the computer 4.
(Step S13) The exhaustion level and the remaining lifetime are calculated by the computer 4.
(Step S14) Whether or not the calculated remaining lifetime is less than the threshold is determined. If it is greater than or equal to the threshold, the process is terminated. If it is less than the threshold, the process proceeds to step S15.
(Step S15) A backup alarm sound is emitted from the speaker 6.
(Step S16) The exhaustion level, the remaining lifetime, and a backup alarm are displayed on the display unit 5.
In the above description, the exhaustion level is calculated from the total of the number of erase operations. However, since the number of erase operations in each block is averaged by wear leveling, an exhaustion level may be calculated from the number of erase operations in each block and a maximum number of erase operations.
In the NAND type flash memory 1, the numbers of rewrite operations are evenly distributed among blocks by wear leveling so that the number of rewrite operations with respect to a whole memory area is increased. A notification of an exhaustion level of the NAND type flash memory 1 can be provided to a user at any time. Backup is recommended when the exhaustion level exceeds a predetermined threshold and comes close to the end of a system lifetime, so that data loss can be prevented before it happens. Further, a remaining lifetime is displayed, so that the user can replace a memory system in an efficient way.
As described above, according to the memory system of the second embodiment, a memory state such as a remaining lifetime can be determined, and a memory can be efficiently used.
The FeRAM 2 has a management table of a capacity of access to the NAND type flash memory 1, which retains an amount of writing, an amount of reading, and a threshold of an exhaustion level. In addition, it retains a limiting amount of writing of the NAND type flash memory 1. As used herein, a limiting amount of writing is defined as (a limiting number of store/erase operations in each block of the NAND type flash memory 1)×(a total capacity of the NAND type flash memory 1), multiplied by an efficiency of saving data as a weight, wherein the efficiency of saving data is an amount of erasing of the NAND type flash memory with respect to an amount of writing from the computer 4, and is predicted by simulation. The limiting amount of writing may have a margin to allow a minimum backup, startup, shutdown, and the like.
As shown in
The exhaustion level (%) can be calculated as (amount of writing+amount of readingדx”)/limiting amount of writing×100, wherein “x” is derived from the number of read operations by which read disturb occurs. For example, in a case where read disturb is caused by 104 read operations, it is assumed that refresh occurs once with respect to an amount of reading which is a block capacity×104, and thus “x” can be set to 10−4.
If this exhaustion level is greater than or equal to the threshold, the exhaustion level and a backup alarm are displayed on the display unit 5 as shown in
(Step S21) The processing unit 32 accepts a self-diagnosis command issued by the computer 4.
(Step S22) A limiting amount of writing, an amount of reading, an amount of writing, and a threshold of exhaustion level are retrieved from the FeRAM 2 and outputted to the computer 4.
(Step S23) The exhaustion level is calculated by the computer 4.
(Step S24) Whether or not the calculated exhaustion level is greater than the threshold is determined. If it is less than or equal to the threshold, the process is terminated. If it is greater than the threshold, the process proceeds to step S25.
(Step S25) The exhaustion level and a backup alarm are displayed on the display unit 5.
In the NAND type flash memory 1, the numbers of rewrite operations are evenly distributed among blocks by wear leveling so that the number of rewrite operations with respect to a whole memory area is increased. A notification of an exhaustion level of the NAND type flash memory 1 can be provided to a user at any time. Backup is recommended when the exhaustion level exceeds a predetermined threshold and comes close to the end of a system lifetime, so that data loss can be prevented before it happens. Further, since refresh is also taken into account, the exhaustion level can be obtained more precisely.
As described above, according to the memory system of the third embodiment, a memory state such as an exhaustion level can be determined, and a memory can be efficiently used.
Although an exhaustion level is calculated using an amount of writing and an amount of reading in the present embodiment, an exhaustion level may be obtained from an amount of writing without use of an amount of reading.
The FeRAM 2 has a counter (not shown), and counts the number of erase operations of the NAND type flash memory 1 and retains a total of the number of erase operations. In addition, it retains a maximum number of erase operations and a threshold of exhaustion level of the NAND type flash memory 1. The maximum number of erase operations is obtained here from (limiting number of store/erase operations in each block of the NAND type flash memory 1)×(total number of blocks of the NAND type flash memory 1). In addition, the number of error bits in each block is managed, and the number of error bits in a block having a maximum number of error bits and a threshold of the number of error bits are retained. Since in the NAND type flash memory 1, wear leveling is performed such that the number of write operations in each block is averaged, the number of error bits to be retained may be the number of error bits in any block.
A self-diagnosis command is regularly issued from the computer 4 to this memory system. The processing unit 32 receives the self-diagnosis command through the connection interface 31, and performs control to output a total of the number of erase operations, a maximum number of erase operations, the number of error bits, and each threshold which are retained by the FeRAM 2 to the computer 4 through the connection interface 31. The computer 4 calculates an exhaustion level of the NAND type flash memory 1 based on the total of the number of erase operations and the maximum number of erase operations.
If this exhaustion level is greater than or equal to a predetermined threshold and the number of error bits is greater than or equal to a predetermined threshold, the exhaustion level, a backup alarm, and a message to the effect that many errors have occurred are displayed on the display unit 5 as shown in
(Step S31) The processing unit 32 accepts a self-diagnosis command issued by the computer 4.
(Step S32) A total of the number of erase operations, the maximum number of erase operations, the number of error bits, and thresholds are retrieved from the FeRAM 2 and outputted to the computer 4.
(Step S33) The exhaustion level is calculated by the computer 4.
(Step S34) Whether or not the calculated exhaustion level is greater than a predetermined threshold and whether or not the number of error bits is greater than a predetermined threshold are determined. If both the exhaustion level and the number of error bits are greater than their thresholds, the process proceeds to step S35. If at least one of them is less than or equal to its threshold, the process is terminated.
(Step S35) The exhaustion level and a backup alarm are displayed on the display unit 5.
In the above description, the exhaustion level is calculated from the total of the number of erase operations. However, since the number of erase operations in each block is averaged by wear leveling, an exhaustion level may be calculated from the number of erase operations in each block and a maximum number of erase operations.
The number of error bits in each block of the NAND type flash memory 1 may be monitored and retained in the FeRAM 2, the number of blocks in which the number of error bits exceeds a predetermined threshold may be obtained by the computer 4, and a degree of forcing of a backup alarm to be displayed may be increased in a stepwise manner according to the obtained number of blocks.
In the NAND type flash memory 1, the numbers of rewrite operations are evenly distributed among blocks by wear leveling so that the number of rewrite operations with respect to a whole memory area is increased. A notification of an exhaustion level of the NAND type flash memory 1 can be provided to a user at any time. Backup is recommended when the exhaustion level exceeds a predetermined threshold and comes close to the end of a system lifetime, so that data loss can be prevented before it happens. Further, since the number of error bits is also taken into account, timing for backup can be obtained more precisely.
As described above, according to the memory system of the fourth embodiment, a memory state such as an exhaustion level can be determined, and a memory can be efficiently used.
During a store (erase) operation of the NAND type flash memory, a verify operation for verifying whether data has been written or not is performed after data is stored (erased). If data has been incorrectly written, store (erase)/verify operations are repeated so that correct data is written. As a fatigue level of the NAND type flash memory increases (an exhaustion level increase), the number of store (erase)/verify operations increases, and with it, “tPROG” (“tERASE”) increases. In the present embodiment, these “tPROG” and “tERASE” are taken into account in addition to an exhaustion level.
A self-diagnosis command is regularly issued from the computer 4 to this memory system. The processing unit 32 receives the self-diagnosis command through the connection interface 31, and performs control to output a total of the number of erase operations, a maximum number of erase operations, a storing time (“tPROG”), an erasing time (“tERASE”), and each threshold which are retained by the FeRAM 2 to the computer 4 through the connection interface 31. The computer 4 calculates an exhaustion level of the NAND type flash memory 1 based on the total of the number of erase operations and the maximum number of erase operations.
If this exhaustion level is greater than or equal to a predetermined threshold, and the storing time (“tPROG”) and the erasing time (“tERASE”) are greater than or equal to respective predetermined thresholds, the exhaustion level, a backup alarm, and an error are displayed on the display unit 5 as shown in
(Step S41) The processing unit 32 accepts a self-diagnosis command issued by the computer 4.
(Step S42) A total of the number of erase operations, the maximum number of erase operations, a storing/erasing time (“tPROG”/“tERASE”), and thresholds are retrieved from the FeRAM 2 and outputted to the computer 4.
(Step S43) The exhaustion level is calculated by the computer 4.
(Step S44) Whether or not the calculated exhaustion level is greater than a predetermined threshold and whether or not the storing/erasing time (“tPROG”/“tERASE”) is greater than a predetermined threshold are determined. If both the exhaustion level and the storing/erasing time (“tPROG”/“tERASE”) are greater than their thresholds, the process proceeds to step S45. If at least one of them is less than or equal to its threshold, the process is terminated.
(Step S45) The exhaustion level and a backup alarm are displayed on the display unit 5.
It has been described that the exhaustion level is calculated from the total of the number of erase operations. However, since the number of erase operations in each block is averaged by wear leveling, an exhaustion level may be calculated from the number of erase operations in each block and a maximum number of erase operations.
In the NAND type flash memory 1, the numbers of rewrite operations are evenly distributed among blocks by wear leveling so that the number of rewrite operations with respect to a whole memory area is increased. A notification of an exhaustion level of the NAND type flash memory 1 can be provided to a user at any time. Backup is recommended when the exhaustion level exceeds a predetermined threshold and comes close to the end of a system lifetime, so that data loss can be prevented before it happens. Further, since a time required for the verify operation is also taken into account, timing for backup can be obtained more precisely.
As described above, according to the memory system of the fifth embodiment, a memory state such as an exhaustion level can be determined, and a memory can be efficiently used.
Any of the above described embodiments is just one example, and should not be considered to be restrictive. For example, when the number of erase operations of the NAND type flash memory 1 exceeds a limiting number of erase operations, a notification of a data retention period (a data guarantee period) may be provided to a user. As shown in
Further, in the second embodiment, an ideal frequency of use which is determined from a maximum energization time and a limiting number of store/erase operations as shown in
In the fourth and fifth embodiments, an exhaustion level based on a total of the number of erase operations is calculated, but an exhaustion level based on an amount of writing and an amount of reading may be calculated as described in the third embodiment.
The nonvolatile memory 2 in the memory system of the above described embodiments may be an MRAM, a PRAM, or an RRAM instead of the FeRAM. Or, it may be composed of a DRAM or SRAM, which is a volatile memory. However, if it is composed of a volatile memory, management information needs to be saved in the NAND type flash memory 1, which is a nonvolatile memory, each time the memory system is powered off.
A self-diagnosis command may be issued every time the computer 4 is started up.
Kanno, Shinichi, Takashima, Daisaburo, Nagadomi, Yasushi, Hatsuda, Kosuke
Patent | Priority | Assignee | Title |
11861192, | Mar 02 2021 | Samsung Electronics Co., Ltd. | Storage controller redirecting write operation and operating method thereof |
Patent | Priority | Assignee | Title |
4224506, | Mar 24 1978 | Pitney Bowes Inc. | Electronic counter with non-volatile memory |
6078520, | Apr 08 1993 | Renesas Electronics Corporation | Flash memory control method and information processing system therewith |
6249838, | Dec 28 1998 | Cisco Technology Inc | Physical medium information in file system header |
6426898, | Mar 05 2001 | U S BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT | Method of reducing trapped holes induced by erase operations in the tunnel oxide of flash memory cells |
6993690, | Dec 16 1998 | Hagiwara Sys-Com Co., Ltd. | Memory unit having memory status indicator |
7356442, | Oct 05 2006 | International Business Machines Corporation | End of life prediction of flash memory |
7447936, | Feb 07 2003 | Renesas Electronics Corporation; NEC Electronics Corporation | Nonvolatile memory system |
7512847, | Feb 10 2006 | Western Digital Israel Ltd | Method for estimating and reporting the life expectancy of flash-disk memory |
7653778, | May 08 2006 | Western Digital Technologies, INC | Systems and methods for measuring the useful life of solid-state storage devices |
20020091965, | |||
20030078741, | |||
20030217323, | |||
20040158775, | |||
20060265545, | |||
20070266200, | |||
20080126679, | |||
20080162079, | |||
CN101053041, | |||
CN1571069, | |||
CN1858855, | |||
JP2000181805, | |||
JP2001195316, | |||
JP2003216506, | |||
JP2004234052, | |||
WO2006005661, | |||
WO2006005661, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Apr 09 2014 | TOSHIBA MEMORY CORPORATION | (assignment on the face of the patent) | / | |||
Jun 14 2017 | Kabushiki Kaisha Toshiba | TOSHIBA MEMORY CORPORATION | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 043052 | /0218 | |
Aug 01 2018 | TOSHIBA MEMORY CORPORATION | K K PANGEA | MERGER SEE DOCUMENT FOR DETAILS | 055659 | /0471 | |
Aug 01 2018 | K K PANGEA | TOSHIBA MEMORY CORPORATION | CHANGE OF NAME AND ADDRESS | 055669 | /0401 | |
Oct 01 2019 | TOSHIBA MEMORY CORPORATION | Kioxia Corporation | CHANGE OF NAME AND ADDRESS | 055669 | /0001 |
Date | Maintenance Fee Events |
Oct 04 2023 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. |
Date | Maintenance Schedule |
Apr 14 2023 | 4 years fee payment window open |
Oct 14 2023 | 6 months grace period start (w surcharge) |
Apr 14 2024 | patent expiry (for year 4) |
Apr 14 2026 | 2 years to revive unintentionally abandoned end. (for year 4) |
Apr 14 2027 | 8 years fee payment window open |
Oct 14 2027 | 6 months grace period start (w surcharge) |
Apr 14 2028 | patent expiry (for year 8) |
Apr 14 2030 | 2 years to revive unintentionally abandoned end. (for year 8) |
Apr 14 2031 | 12 years fee payment window open |
Oct 14 2031 | 6 months grace period start (w surcharge) |
Apr 14 2032 | patent expiry (for year 12) |
Apr 14 2034 | 2 years to revive unintentionally abandoned end. (for year 12) |