Embodiments described herein relate generally to a storage device including a nonvolatile semiconductor memory.
As such a storage device, a solid-state drive (SSD) including a nonvolatile semiconductor memory such as a flash memory is known. In line with an increase in the capacity of a flash memory, SSDs are used in place of conventional hard disk drives (HDDs). In the flash memory, a floating gate covered by an insulating film is formed in a memory cell transistor. Data is stored by applying a potential to the floating gate. The threshold voltage of the memory cell transistor is changed depending on the presence or absence of gate potential. By this change, the stored data is read. However, repetition of data erasing and writing leads to deterioration of the insulating film which covers the floating gate (the combination of erasing and writing may be referred to as rewriting). The potential applied to the floating gate is lost over time. Ultimately, no potential remains. Thus, correct data cannot be read. In other words, the stored data is lost.
To solve this problem, in the SSD, a refresh process is performed. In the refresh process, the stored data is read from the memory and is rewritten before the data is lost. For example, the refresh process is performed when the power source is switched on, or the refresh process is performed in predetermined regular time intervals while the power source is in an on-state. Potential is applied again to the floating gate by the refresh process. Thus, the loss of the stored data is prevented. However, since the refresh process requires reading and rewriting, reading and writing of the host is suspended during the refresh process. Thus, the reading and writing performance of the host is degraded.
A general architecture that implements the various features of the embodiments will now be described with reference is the drawings. The drawings and the associated descriptions are provided to illustrate the embodiments and not to limit the scope of the invention.
Various embodiments will be described hereinafter with reference to the accompanying drawings.
In general, according to one embodiment, a storage device includes a plurality of nonvolatile semiconductor memories, a sensor and a controller. The sensor is configured to measure a temperature of the nonvolatile semiconductor memories. The controller is configured to receive data from a host, determine a rewriting interval of the data and write the data to, of the nonvolatile semiconductor memories, a nonvolatile semiconductor memory having a temperature corresponding to the rewriting interval.
The controller 18 includes NAND interfaces 221, 222, 223 and 224 connected to flash memories 121, 122, 123 and 124, a DRAM interface 24 connected to the DRAM 14, and a host interface 20 connected to a host 16, for example, a personal computer. These interfaces 20, 221, 222, 223, 224and 24 are connected to the bus line of a CPU 28. A main memory 26 and a ROM 25 are also connected to the bus line. The ROM 25 stores a control program. The control program is loaded into the main memory 26 when the power source is turned on.
Flash memories 121, 122, 123 and 124 include temperature sensors 301, 302, 303 and 304. The outputs of temperature sensors 301, 302, 303 and 304 are also supplied to NAND interfaces 221, 222, 223 and 224.
The host 16 provides the controller 18 with a read command and a write command by specifying a block address. This address is called a logical block address. A physical block address is allocated for the flash memory 12. The controller 18 has an address management table in which the relationship between the logical, block address and the physical block address is recorded. The controller 18 obtains a physical block address corresponding to the logical block address specified by the host 16.
The controller 18 independently starts a refresh process at a predetermine time point regardless of the command from the host 16. The refresh process is equivalent to a process which is performed when a rewrite command is received from the host 16. In other words, the refresh process includes reading of data from a place, writing of the read data to another place, and erasing of the data from she original place. Erasing does not have to be performed immediately. Erasing may be merely applied to the state of management information related to the place (in other words, the physical block address) or the data to be erased. The actual erasing may foe collectively applied to a plurality or blocks later. Thus, the refresh process includes erasing. Therefore, the refresh process is performed in block units which are the units of erasing.
The refresh process needs to be preformed before the stored data is lost. The time limit for retaining the stored data is based on the recent writing tine or the recent erasing time, and the data retention period. Thus, the time limit for retaining data, in other words, the refresh time limit differs depending on the block. The degree of degradation of the insulating film of the flash memory 12 differs depending on she temperature. The data retention period is not constant in flash memories 121, 122, 123 and 124. The data retention period is short at high temperature and is long at low temperature. The controller 18 calculates the refresh time limit for each block according to the recent writing time or the recent erasing time, and the data retention period (which differs depending on the temperature). The controller 18 stores the refresh time limit for each block in a management table. An example of the management table is shown in Table 1.
The controller 18 refers to the management table. When the refresh time limit of a block has been reached, the controller 18 reads data from the block and stores the data in the DRAM 14. Subsequently, the controller 18 writes the data of the DRAM 14 to another block (which may be a block in the same flash memory 12 or may be a block in another flash memory 12). Subsequently, as the data of the block is unnecessary, the information related to the physical block address of the block is modified in the management information of the block address, and is changed to information indicating erasing. The data of the block may be erased immediately.
The controller 18 determines the flash memory to which data should be written in accordance with the rewriting interval of the data to be written. When the host 16 manages a data file in a multi-stream format which includes content and management information, two files are present. One of the two files is, for example, the file of document X. The other one is the file of management information of document X, such as update information, character codes and editors. The update information includes the latest rewriting time and the rewriting time immediately before the latest rewriting time. This means that the management information also includes the rewriting interval, which is the difference between the rewriting times. The controller 18 is capable of recognizing the rewriting interval of document X from the update information of the management information file of document X.
When a data file is managed in a multi-stream format, for example, management information may contain the following information: only reading is performed (in other words, rewriting is prohibited) for document Y; and document Z is rewritten at high frequency.
The flash memory to which data is to be written is determined according to the rewriting intervals. As stated above, the refresh process performed by the controller 18 is equivalent to the rewriting process performed by the host 16. Therefore, when a rewriting process is performed by the host 16 before the refresh time point, the refresh process by the controller 18 is omitted. Thus, data having a long rewriting interval is preferably written to a flash memory 12 having a long data retention period and a long refresh interval in comparison with a flash memory 12 having a short data retention period and a short refresh interval. If data having a long rewriting interval is written to a flash memory 12 having a short refresh interval, there is a high possibility that a refresh process is performed before the host 16 performs a rewriting process. On the contrary, data having a short rewriting interval is preferably written to a flash memory 12 having a short data retention period and a short refresh interval in comparison with a flash memory 12 having a long data retention period and a long refresh interval. If, in a manner opposite to the above, data having a long rewriting interval is written to a flash memory 12 having a short refresh interval, there is a high possibility that the refresh time limit is reached before a data rewrite command is generated from the host 16 after data writing. Thus, it is highly likely that a refresh process is performed. However, if data having a long rewriting interval is written to a flash memory 12 having a long refresh interval, there is a high possibility that a rewrite command is issued from the host 16 before the refresh time limit. Thus, it is highly likely that a refresh process is not performed.
As explained above, a flash memory 12 at high temperature has a short data retention period. Thus, the refresh interval is short. The refresh interval of the flash memory 12 becomes longer with decreasing temperature. In consideration of these factors, the controller 18 writes data having a long rewriting interval to a flash memory 12 having a long refresh interval and a low temperature. The controller 18 writes data having a short rewriting interval to a flash memory 12 having a short refresh interval and a high temperature. When the number of flash memories 12 is four, four categories are set for the rewriting interval. The categories are allocated for flash memories 121, 122, 123 and 124 depending on the temperature of flash memories 121, 122, 123 and 124.
When the format of data files managed by the host 16 is not a multi-stream format, the rewriting intervals of files are estimated in advance according to file type (for example, a document or image indicated by an extension, a file prepared by the user, and a downloaded file) and are stored in a table, etc. The rewriting interval is obtained from the type of a file. In a manner similar to that of the multi-stream format, the file is allocated for a flash memory 12 having a temperature corresponding to the rewriting interval. For example, a document my be set to a short rewriting interval, and an image may be set to a long rewriting interval. A file prepared by the user may be set no a short rewriting interval, and a downloaded file may be set to a long rewriting interval.
After the controller 18 determines the flash memory 12 to which data should be written, the controller 18 determines to which block of the flash memory 12 the data should be written. This determination may be performed by the known wear leveling process. In the flash memory, the upper limit of the rewritable times is determined. In some programs, data is rewritten once several seconds. Thus, the rewriting times of a specific block may have reached the upper limit. To prevent this, the number of rewrites of each physical block is counted and is stored. When a write command is received from the host, the block having the least number of rewrites is selected from the physical blocks. Data is written to the selected block. The logical block address specified by the host is allocated for the physical block address. Thus, a wear leveling process is performed. In this manner, repetitive data writing is not occurred for the same physical address. Thus, writing is equalized. It is possible to prevent the number of rewrites of some blocks from reaching the upper limit.
When the received, command is a write command or a rewrite command, the controller 18 calculates the rewriting interval of the target data file in block 48. When the data file format is a multi-stream format, the latest rewriting time and the rewriting time immediately before the latest rewriting time are read from the file of management information. The rewriting interval is calculated from the difference between the rewriting times. When the data file format is not a multi-stream format, the rewriting interval is obtained from the table according to the type of file.
In block 50, the controller 18 selects the flash memory to which the file should be written according to the rewriting interval based on the relationship shown in Table 2. When four categories are set for the rewriting interval since the number of flash memories is four, and the rewriting interval is included in the shortest interval category, the flash memory having the highest temperature is selected. When the rewriting interval is included in the second shortest interval category, the flash memory having the second highest temperature is selected. When the rewriting interval is included in the second longest interval category, the flash memory having the second lowest temperature is selected. When the rewriting interval is included in the longest interval category, the flash memory having the lowest temperature is selected. Thus, the shorter the rewriting interval is, the higher the temperature of the flash memory the controller 18 selects. The longer the rewriting interval is, the lower the temperature of the flash memory the controller 18 selects.
Alternatively, the control for 18 may select a flash memory having a temperature higher than a predetermined temperature when the rewriting interval is shorter than a predetermined interval. The controller 18 may select a flash memory having a temperature which is not higher than the predetermined temperature when the rewriting interval is not shorter than the predetermined interval.
When the remaining capacity of the selected flash memory is less than or equal to a predetermined value, a flash memory having the next lowest, or next highest temperature to that of the selected flash memory is selected regardless of the above rules.
In block 52, the controller 18 determines to which block of the flash memory selected in block 50 the data should be written. The controller 18 reads the number of rewrites/refreshes of each, block of the selected flash memory from the management table shown in Table 1, and determines the block to which the data should be written such that the number of rewrites/refreshes is equalized (wear leveling process). The data from the host 16 is written to the determined block.
In block 54, the controller 18 updates the refresh time limit, the number of rewrites/refreshes and the state of the management table.
In block 60, the controller 18 refers to the management table and determines whether or not the refresh time limit of any block has been reached. When the refresh time limit has not been reached in any block, the controller 18 performs the process of block 72.
When the refresh time limit of a block has been reacted, the controller 18 reads the data of the block and writes the data to the DRAM 14 in block 62.
In block 64, the controller 18 obtains the rewriting Interval of the read data file. In block 66, the controller 18 selects the flash memory to which the file should be written in accordance with the relationship shown in Table 2.
In block 68, the controller 18 determines to which block of the flash memory selected in block 66 the data should be written. The controller 18 reads the number of rewrites/refreshes of each block of the selected flash memory from the management table shown in Table 1, and determines the block to which the data should be written such that the number of rewrites/refreshes is equalized (wear leveling process). The data in the DRAM 14 is written to the determined block.
In block 70, the controller 13 updates the refresh time, the number of rewrites/refreshes and the state of the management table.
In block 72, the controller 18 determines whether or not a suspend command is generated. When a suspend command is generated, the controller 18 suspends the process. When a suspend command is not generated, the process of block 42 is repeated. Thus, the procedure from block 42 to block 54 is repeated until a block of a flash memory has reached the refresh time limit. When a write or a rewrite command is transmitted during this period, the data of the block is rewritten. Thus, the refresh time limit is reset, and no refresh process is performed. Data is written to a block having a temperature, that is, a refresh interval, corresponding to the rewriting interval. Therefore, there is a high possibility that a write or rewrite command is transmitted from the host before the refresh time limit is reached. Thus, it is unlikely that a refresh process is performed.
As explained above, according to the embodiment, in the SSD including a plurality of flash memories, the rewriting interval of data is obtained at the time of data writing or data rewriting. The data is written to a flash memory having a temperature corresponding to the rewriting interval. Thus, there is a high possibility chat a data rewrite command is received from the host before the refresh time limit is reached. The reading/writing of the host is suspended. In this manner, there is a low possibility that a refresh process which deteriorates the reading/writing performance of the host is performed. Since data is rewritten by the rewrite command from the host, potential is applied again to the floating gate. Thus, the stored data is not lost.
When a refresh process is performed, in a manner similar to the above, data is written to a flash memory having a temperature corresponding to the rewriting interval of the data. Thus, an effect similar to the above is obtained.
Because of the above factors, the performance of the device, and the product life of the device can be improved.
In the above explanation, a flesh memory is explained as a nonvolatile semiconductor memory. However, the present embodiment is not limited to this example. The present embodiment can be applied as long as the stored data could be lost over time in spite of the non-volatility.
In the above description, a sensor is provided for each chip of the flash memory, and a chip is selected according to the rewriting interval and the temperature. However, the temperature of each chip is based on the distance from the CPU mounted on the substrate. Therefore, only one sensor may be provided for a plurality of chips which can be considered as having the same temperature as they are provided in similar positions. A plurality of sensors may be provided in a chip such that the temperature is measured for each area in the chip.
In the above explanation, data is written to a flash memory having a temperature corresponding the rewriting interval of the data both when data is written to a flash memory for the first time by a write command from the host and when the data of a flash memory is rewritten through a refresh process toy the controller. However, only in one of the cases, data may be written to a flash memory corresponding to the rewriting interval and the temperature. For example, when data is written to a flash memory for the first time by a write command from the host, data may be written to a predefined flash memory.
The method for obtaining the rewriting interval is not limited to the above examples. The rewriting interval can be obtained according to, for example, various types of attribute information, or the type of application using the data file.
The various modules of the systems described herein can be implemented as software applications, hardware and/or software modules, or components on one or more computers, such as servers. While the various modules are illustrated separately, they may snare some or all of the same underlying logic or code.
While certain embodiments have been described, these embodiments have been presented by way of example only, and are not intended to limit the scope of the inventions. Indeed, the novel embodiments described herein may be embodied in a variety of other forms; furthermore, various omissions, substitutions and changes in the form of the embodiments described herein may be made without departing from the split of the inventions. The accompanying claims and their equivalents are intended to cover such forms or modifications as would fall within the scope and spirit of the inventions.
This application claims the benefit of U.S. Provisional Application No. 62/214,157, filed Sep. 3, 2015, the entire contents of which are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
7403440 | Perner | Jul 2008 | B2 |
20080169860 | Song | Jul 2008 | A1 |
20160117216 | Muchherla | Apr 2016 | A1 |
Number | Date | Country |
---|---|---|
2008-310888 | Dec 2008 | JP |
2009-003843 | Jan 2009 | JP |
2011-081694 | Apr 2011 | JP |
Number | Date | Country | |
---|---|---|---|
20170068466 A1 | Mar 2017 | US |
Number | Date | Country | |
---|---|---|---|
62214157 | Sep 2015 | US |