1. Field of the Invention
The present invention generally relates to data caches. More particularly, the present invention relates to the field of supporting speculative modification in a data cache.
2. Related Art
A data cache interacts with a processor to increase system performance. However, if the processor is speculatively executing instructions, a traditional data cache is unable to properly deal with speculative modifications.
Method and system for supporting speculative modification in a data cache are provided and described.
The accompanying drawings, which are incorporated in and form a part of this specification, illustrate embodiments of the invention and, together with the description, serve to explain the principles of the present invention.
Reference will now be made in detail to embodiments of the present invention, examples of which are illustrated in the accompanying drawings. While the invention will be described in conjunction with these embodiments, it will be understood that they are not intended to limit the invention to these embodiments. On the contrary, the invention is intended to cover alternatives, modifications and equivalents, which may be included within the spirit and scope of the invention as defined by the appended claims. Furthermore, in the following detailed description of the present invention, numerous specific details are set forth in order to provide a thorough understanding of the present invention. However, it will be recognized by one of ordinary skill in the art that the present invention may be practiced without these specific details.
The processor 10 is able to speculatively execute instructions. If the processor 10 speculatively executes instructions to a particular instruction boundary without generating errors, the speculative store operations to the data cache 20 can be made permanent with a commit operation. However, if errors occur before reaching the particular instruction boundary, the speculative store operations to the data cache 20 have to be undone with a rollback operation.
The data cache 20 includes a plurality of cache lines 25. Each cache line includes a state indicator 27 for indicating anyone of a plurality of states. The plurality of states include an invalid state, a valid state, a dirty state, and a speculative state. The invalid state indicates that the respective cache line is not being used. The valid state indicates that the respective cache line has clean data. The dirty state indicates that the respective cache line has dirty data (or the most recent data compared to other memory components such as L2 data cache, main memory, etc.). The speculative state enables keeping track of speculative modification to data in said respective cache line. The speculative state enables a speculative modification to the data in the respective cache line to be made permanent in response to a commit operation.
Moreover, the speculative state enables the speculative modification to the data in the respective cache line to be undone in response to a rollback operation. Cache lines having the speculative state cannot be drained to other memory components such as L2 data cache, main memory, etc.
Invalid State I
Assuming the cache line is in the invalid state I, there are several possibilities for this cache line. If a non-speculative store is performed by the processor 10 (
Valid State V
Assuming the cache line is in the valid state V, there are several possibilities for this cache line. If a non-speculative store is performed by the processor 10 (
Dirty State D
Assuming the cache line is in the dirty state D, there are several possibilities for this cache line. If a speculative store is performed by the processor 10 (
Speculative State S
Assuming the cache line is in the speculative state S, there are several possibilities for this cache line. If a commit operation is performed, the cache line moves to the dirty state D. If a rollback operation is performed, the cache line moves to the invalid state I.
The speculative cache buffer 50 receives cache lines which have the speculative state S or the dirty state D and are evicted or drained from the data cache 20. Hence, the data cache 20 can send cache lines having the speculative state S or the dirty state D to the speculative cache buffer 50 and retrieve them when necessary.
Moreover, the speculative cache buffer 50 has a plurality of cache lines 55. Each cache line 55 includes a state indicator 57 for indicating anyone of a plurality of states. The plurality of states includes an invalid state, a dirty state, and a speculative state. In one embodiment, the speculative cache buffer 50 is fully associative.
The data cache 20 can drain cache lines that are in the dirty state D or the speculative state S to the speculative cache buffer 50. Moreover, the speculative cache buffer 50 can drain cache lines that are in the dirty state D to a memory component such as L2 data cache, main memory, etc.
Invalid State I
Assuming the cache line is in the invalid state I, there are several possibilities for this cache line. If the data cache 20 evicts a cache line having the dirty state D, the cache line moves to the dirty state D. If the data cache 20 evicts a cache line having the speculative state S, the cache line moves to the speculative state S.
Dirty State D
Assuming the cache line is in the dirty state D, there are several possibilities for this cache line. If the speculative cache buffer 50 drains the cache line having the dirty state D to a memory component such as L2 data cache, main memory, etc., the cache line moves to the invalid state I. In case the data cache 20 requests the cache line back, the cache line moves to the invalid state I in the speculative cache buffer 50.
Speculative State S
Assuming the cache line is in the speculative state S, there are several possibilities for this cache line. If a commit operation is performed, the cache line moves to the dirty state D. If a rollback operation is performed, the cache line moves to the invalid state I. In case the data cache 20 requests the cache line back, the cache line moves to the invalid state I in the speculative cache buffer 50.
It is possible that multiple versions of a cache line in the dirty state may exist in the speculative cache buffer 50. For instance, the data cache 20 may drain the cache line having the dirty state to the speculative cache buffer 50 because a speculative store has to be performed to the cache line in the data cache 20. If the cache line having the speculative state is later drained to the speculative cache buffer 50 and if a commit operation is performed, then the speculative cache buffer 50 would have two cache lines with different versions of the data, whereas only one version of the data needs to be drained to a memory component such as L2 data cache, main memory, etc.
In an alternate embodiment of the speculative cache buffer 50, the plurality of states also includes a commit-kill state, in addition to the invalid state, the dirty state, and the speculative state. The commit-kill state indicates that the data cache 20 has evicted the respective cache line having the dirty state in response to a speculative modification operation (or speculative store) to the respective cache line in the data cache 20. The commit-kill state reduces the number of copies of a cache line in the dirty state and saves bandwidth in case of the commit operation, as detailed below.
Invalid State I
Assuming the cache line is in the invalid state I, there are several possibilities for this cache line. If the data cache 20 evicts a cache line having the dirty state D but not due to a speculative store operation, the cache line moves to the dirty state D. If the data cache 20 evicts a cache line having the speculative state S, the cache line moves to the speculative state S. If the data cache 20 evicts a cache line having the dirty state D in response to a speculative store operation to that cache line, the cache line moves to the commit-kill state K.
Dirty State D
Assuming the cache line is in the dirty state D, there are several possibilities for this cache line. If the speculative cache buffer 50 drains the cache line having the dirty state D to a memory component such as L2 data cache, main memory, etc., the cache line moves to the invalid state I. In case the data cache 20 requests the cache line back, the cache line moves to the invalid state I in the speculative cache buffer 50.
Speculative State S
Assuming the cache line is in the speculative state S, there are several possibilities for this cache line. If a commit operation is performed, the cache line moves to the dirty state D. If a rollback operation is performed, the cache line moves to the invalid state I. In case the data cache 20 requests the cache line back, the cache line moves to the invalid state I in the speculative cache buffer 50.
Commit-kill State K
Assuming the cache line is in the commit-kill state K, there are several possibilities for this cache line. If a commit operation is performed, the cache line moves to the invalid state I. If a rollback operation is performed, the cache line moves to the dirty state D. If the speculative cache buffer 50 drains the cache line having the commit-kill state K to a memory component such as L2 data cache, main memory, etc., the cache line moves to the invalid state I.
The foregoing descriptions of specific embodiments of the present invention have been presented for purposes of illustration and description. They are not intended to be exhaustive or to limit the invention to the precise forms disclosed, and many modifications and variations are possible in light of the above teaching. The embodiments were chosen and described in order to best explain the principles of the invention and its practical application, to thereby enable others skilled in the art to best utilize the invention and various embodiments with various modifications as are suited to the particular use contemplated. It is intended that the scope of the invention be defined by the Claims appended hereto and their equivalents.
The present application is a continuation application of and claims the benefit of U.S. patent application Ser. No. 10/622,028, filed Jul. 16, 2003, now U.S. Pat. No. 7,225,299, entitled “SUPPORTING SPECULATIVE MODIFICATION IN A DATA CACHE,” naming Bill Rozas, Alexander Klaiber, David Dunn, Paul Serris, and Lacky Shah as inventors, assigned to the assignee of the present invention. That application is incorporated herein by reference in its entirety and for all purposes.
Number | Name | Date | Kind |
---|---|---|---|
5155831 | Emma et al. | Oct 1992 | A |
5428761 | Herlihy et al. | Jun 1995 | A |
5548735 | Chen et al. | Aug 1996 | A |
5634073 | Collins et al. | May 1997 | A |
5701432 | Wong et al. | Dec 1997 | A |
5802574 | Atallah et al. | Sep 1998 | A |
5838934 | Ramagopal et al. | Nov 1998 | A |
5838943 | Ramagopal et al. | Nov 1998 | A |
5926645 | Williamson | Jul 1999 | A |
5930821 | Gaskins et al. | Jul 1999 | A |
5974438 | Neufeld | Oct 1999 | A |
6006299 | Wang et al. | Dec 1999 | A |
6006317 | Ramagopal et al. | Dec 1999 | A |
6119205 | Wicki et al. | Sep 2000 | A |
6134651 | Witt et al. | Oct 2000 | A |
6189074 | Pedneau | Feb 2001 | B1 |
6263407 | Arimilli et al. | Jul 2001 | B1 |
6304944 | Pedneau | Oct 2001 | B1 |
6460130 | Trull et al. | Oct 2002 | B1 |
6487639 | Lipasti | Nov 2002 | B1 |
6526480 | Naruse et al. | Feb 2003 | B1 |
6564301 | Middleton | May 2003 | B1 |
6625694 | Masri et al. | Sep 2003 | B2 |
6658536 | Arimilli et al. | Dec 2003 | B1 |
6725337 | Tan et al. | Apr 2004 | B1 |
6738864 | Chauvel | May 2004 | B2 |
6775749 | Mudgett et al. | Aug 2004 | B1 |
6779085 | Chauvel | Aug 2004 | B2 |
6839813 | Chauvel | Jan 2005 | B2 |
6877088 | Dice | Apr 2005 | B2 |
6938130 | Jacobson et al. | Aug 2005 | B2 |
6976110 | Moyer et al. | Dec 2005 | B2 |
7225299 | Rozas et al. | May 2007 | B1 |
20030014602 | Shibayama et al. | Jan 2003 | A1 |
Number | Date | Country | |
---|---|---|---|
Parent | 10622028 | Jul 2003 | US |
Child | 11807629 | US |