This application is based upon and claims the benefit of priority from the prior Japanese Patent Application No. 2015-183193, filed on Sep. 16, 2015, the entire contents of which are incorporated herein by reference.
An embodiment relates to a cache memory system including a nonvolatile memory.
Since a static random access memory (SRAM) is large in standby energy and high in price, cache memories using nonvolatile memories have been taken into consideration. Among the nonvolatile memories, a magnetoresistive random access memory (MRAM) has high rewriting resistance, and is capable of realizing small cell size and high integration. However, from a point of view of access speed, the SRAM is far beyond the MRAM.
Furthermore, the nonvolatile memories such as the MRAM and the like use condition varieties of configuration materials so as to retain data logics. Therefore, an occurrence rate of errors (hereinafter, error rate) becomes high due to access frequency, aged deterioration, and environmental changes such as temperatures and humidity.
According to one embodiment, a cache memory system has a nonvolatile memory which includes a first region and a second region, the first region storing readable and writable data, the second region storing an ECC (Error Correcting Code) for correcting an error of the data in the first region, an error corrector which generates the ECC and carries out an error correction of the data in the first region with the ECC, error rate determination circuitry which determines an error rate of the data in the first region, and region size adjustment circuitry which adjusts a size of the second region inside the nonvolatile memory based on the error rate.
Hereinafter, an embodiment will be described with reference to the accompanying drawings.
The cache memory 3 in
The cache memory 3 in
The data memory 4 stores data, for example, per 512-bit cache line. As described later, the data memory 4 includes a first region and a second region. The first region stores data which is to be read and written by the processor 2, while the second region stores error correcting codes for correcting data errors in the first region. The tag memory 5 stores address information and the like of each cache line of the data memory 4.
The cache controller 6 includes a cache interface unit (cache I/F) 6a which sends and receives data between the processor 2. The cache controller 6 writes data on the L2 cache and reads out data from the L2 cache in accordance with an address to which the processor 2 has issued an access request.
The reliability control unit 7 includes an error corrector 8, an error rate detector (error rate determination circuitry) 9, and a region size adjustment unit (region size adjustment circuitry) 10.
The error corrector 8 generates error correcting codes (ECC) necessary for an error correction of data of each cache line in the data memory 4. Furthermore, the error corrector 8 carries out the error correction of the data of each cache line with the ECCs.
The error rate detector 9 detects an error rate of the data of each cache line of the first region inside the data memory 4. The region size adjustment unit 10 adjusts a size of the second region inside the nonvolatile memory based on the error rate detected by the error rate detector 9.
In addition, the reliability control unit 7 may include a refresh control unit (control unit) 11. The refresh control unit 11 periodically reads out data written on the first region inside the data memory 4 and supplies the data to the error corrector 8. The error corrector 8 detects whether there is any error in the data readout by the refresh control unit 11. If there is an error, the error corrector 8 then carries out the error correction.
The cache memory 3 according to the present embodiment has a set associative structure.
In the present embodiment, among the cache lines equivalent to the plurality of way numbers selected by the index address, any numbers of ways can be used as the second region for storing ECCs. The way numbers which are to be used as the second region may be changeable per index address, that is, per set. In this manner, sizes of the first region and the second region can be made changeable and adjustable per set in each way in the present embodiment.
In a case of
In a case of
In a case of
In the present embodiment, as mentioned later, the error rate is detected per set, and the sizes (memory capacity) of the first region 4a and the second region 4b are adjusted per set in each way based on the error rates. Accordingly, with regard to a set with a high error rate, the larger the size of the second region 4b is, the more errors can be corrected. Therefore, it is possible to prevent reliability of the nonvolatile memory from falling.
The tag information storage unit 22 stores information (ECC flag information, first information) which indicates whether the data in the first region 4a has the second region 4b as well as the address information of the data in the first region 4a and also stores information (second information) which specifies a way used as the second region 4b.
The data memory 4 includes a data storage unit 26, a writing unit 27, and a reading unit 28. The data storage unit 26 has the plurality of ways divided therein and writes or reads out data per way. The writing unit 27 selects a way which should be written on the data memory 4 and supplies data which should be written on the selected way. The reading unit 28 selects a way which should be readout from the data memory 4 and supplies data which should be readout from the selected way.
The ECC generator 8a and the error correction unit 8b in
The ECC mode 1 corrects 1-bit errors in 512-bit data. In order to correct the 1-bit errors in the 512-bit data, for example, 11-bit ECCs are necessary. Therefore, in order to correct the 1-bit errors with regard to each of the 15 ways, it is necessary to store ECCs of 11×15=165 bits in the second region 4b.
The ECC mode 2 corrects 1-bit errors in 256-bit data. In order to correct the 1-bit errors in the 256-bit data, for example, 10-bit ECCs are necessary. Accordingly, in the 512-bit data, 2-bit errors can be corrected. To correct the 2-bit errors, ECCs of 10×2=20 bits are necessary. Therefore, in order to correct errors of up to 2 bits with regard to each of the 15 ways in the first region 4a, it is necessary to store ECCs of 20×15=300 bits in the second region 4b.
The ECC mode 3 corrects 1-bit errors in 128-bit data. In order to correct the 1-bit errors in the 128-bit data, for example, 9-bit ECCs are necessary. Accordingly, in the 512-bit data, 4-bit errors can be corrected. To correct the 4-bit errors, ECCs of 9×4=36 bits are necessary. Therefore, considering that the first region 4a includes 15 ways, when correcting errors of up to 4 bits per way, it is necessary to store ECCs of 36×15=540 bits in the second region 4b. In a case where the second region 4b includes one way, information of 512 bits can be stored at maximum. Accordingly, two ways are necessary for the second region 4b. In this case, the first region 4a includes 14 ways and the second region 4b stores ECCs of 36×14=504 bits.
The ECC mode 4 corrects 1-bit errors in 64-bit data. In order to correct the 1-bit errors in the 64-bit data, for example, 8-bit ECCs are necessary. Accordingly, in the 512-bit data, 8-bit errors can be corrected. To correct the 8-bit errors, ECCs of 8×8=64 bits are necessary. Considering that the first region 4a includes 14 ways, it is necessary to store ECCs of 64×14=896 bits in the second region 4b.
In this manner, necessary bit numbers of the ECCs differ depending on the performance of the error correction. Therefore, it is necessary to make the sizes of the first region 4a and the second region 4b changeable and adjustable in accordance with the performance of the error correction. This adjustment is carried out by the region size adjustment unit 10 in
The valid information 31 indicates whether the corresponding data in the first region 4a is valid. The dirty information 32 indicates whether it is necessary to write back the corresponding data in the first region 4a on a lower-level memory. The LRU information 33 indicates whether the corresponding data in the first region 4a is a least recently used (LRU) data. The sec information 34 is security information of the corresponding data in the first region 4a. The ECC flag information stores information indicating whether the corresponding data in the first region 4a also includes the second region 4b as well as the first region 4a. The ECC flag information 35 may include information specifying the error correction mode (hereinafter, ECC mode) indicating the performance of the error correction and also rotation information of the second region 4b. The ECC mode selects any one of a plurality of modes including, for example, the four modes in
Accordingly, what are necessary in the ECC flag information 35 are, for example, 3 bits for the ECC mode and 4 bits for the rotation information, that is, 7 bits at minimum.
The reliability control unit 7 detects an error rate of readout data with the error rate detector 9 when carrying out refresh for the nonvolatile memory by the refresh control unit 11. The reliability control unit 7 can adjust the sizes of the first region 4a and the second region 4b with the region size adjustment unit 10 based on the detected error rate.
In order to carry out rotation of the second region 4b, as illustrated in
Next, the data readout in step S11 is supplied to the error corrector 8. The error corrector 8 uses ECCs of the data to be refreshed so as to detect whether this data includes any error (step S12). When an error is detected, the error corrector 8 carries out the error correction with the ECCs (step S13). After finishing the process of step S13, a counter 11a which measures error frequency is counted up (step S14).
When determined in step S12 that there is no error, alternatively, when the process of step S14 is finished, the next address to be refreshed is selected (step S15).
After the process of step S1 in
Next, the region size adjustment unit 10 determines whether the error rate is less than a second threshold which is smaller than the first threshold (step S5). In a case where the error rate is less than the second threshold, the region size adjustment unit 10 changes the ECC mode so as to lower the performance of the error correction (step S6). In a case where the error rate is equal to or more than the second threshold, the ECC mode is maintained in the status quo (step S7).
Next, refresh operations with respect to all of addresses to be refreshed are determined whether they are finished (step S8). If there is still an address to be refreshed, the processes after step S1 are carried out again. After finishing the refresh operations on all of the addresses to be refreshed, the processes in
The process operations of the reliability control unit 7 are not restricted to those illustrated in
When determined in step S23 that the error rate is less than the third threshold, the error rate is successively determined whether it is equal to or more than the first threshold (step S25). Thereafter, processes similar to steps S3 to S8 in
In the aforementioned present embodiment, described is the example where the sizes of the first region 4a and the second region 4b are made changeable and adjustable per set in each way. However, as illustrated in
In this manner, in the present embodiment, the size of the second region 4b storing ECCs is adjusted based on the error rate of the data in the first region 4a of the nonvolatile memory. Therefore, in a case where the error rate of the data in the first region 4a is large, the ECCs can be increased and there is a high possibility that the error correction can be reliably carried out on the data in the first region 4a. Accordingly, even in a case where the error rate of the nonvolatile memory becomes high due to the access frequency, aged deterioration, and environmental conditions such as temperatures, it is possible to use the nonvolatile memory without any practical problem.
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 methods and systems described herein may be embodied in a variety of other forms; furthermore, various omissions, substitutions and changes in the form of the methods and systems described herein may be made without departing from the spirit 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.
Number | Date | Country | Kind |
---|---|---|---|
2015-183193 | Sep 2015 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
6804799 | Zuraski, Jr. | Oct 2004 | B2 |
6961890 | Smith | Nov 2005 | B2 |
7210077 | Brandenberger et al. | Apr 2007 | B2 |
7673216 | Hino et al. | Mar 2010 | B2 |
8719663 | Li | May 2014 | B2 |
8755233 | Nagashima | Jun 2014 | B2 |
20070266291 | Toda et al. | Nov 2007 | A1 |
20080072120 | Radke | Mar 2008 | A1 |
20080298468 | Narahari | Dec 2008 | A1 |
20100122148 | Flynn | May 2010 | A1 |
20110239081 | Hida et al. | Sep 2011 | A1 |
20120254686 | Esumi et al. | Oct 2012 | A1 |
20130138870 | Yoon et al. | May 2013 | A1 |
20140136883 | Cohen | May 2014 | A1 |
20140372831 | Oh | Dec 2014 | A1 |
20150143037 | Smith | May 2015 | A1 |
20150248328 | Yoon | Sep 2015 | A1 |
20150364218 | Frayer | Dec 2015 | A1 |
20160034344 | Hoekstra | Feb 2016 | A1 |
20160162358 | Shirai | Jun 2016 | A1 |
20160170871 | Hyun | Jun 2016 | A1 |
20170147262 | Lee | May 2017 | A1 |
Number | Date | Country |
---|---|---|
2003-131954 | May 2003 | JP |
2004-531837 | Oct 2004 | JP |
2005-216301 | Aug 2005 | JP |
2007-41932 | Feb 2007 | JP |
2007-305267 | Nov 2007 | JP |
2008-226188 | Sep 2008 | JP |
2010-256944 | Nov 2010 | JP |
2011-198272 | Oct 2011 | JP |
2012-94132 | May 2012 | JP |
2012-203692 | Oct 2012 | JP |
2013-114679 | Jun 2013 | JP |
2013-120426 | Jun 2013 | JP |
2014-186614 | Oct 2014 | JP |
WO-2014088747 | Jun 2014 | WO |
Number | Date | Country | |
---|---|---|---|
20170075756 A1 | Mar 2017 | US |