WO2005029336A1 - キャッシュメモリおよびキャッシュメモリ制御方法 - Google Patents
キャッシュメモリおよびキャッシュメモリ制御方法 Download PDFInfo
- Publication number
- WO2005029336A1 WO2005029336A1 PCT/JP2004/012421 JP2004012421W WO2005029336A1 WO 2005029336 A1 WO2005029336 A1 WO 2005029336A1 JP 2004012421 W JP2004012421 W JP 2004012421W WO 2005029336 A1 WO2005029336 A1 WO 2005029336A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- cache
- access
- information indicating
- access information
- new
- Prior art date
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/12—Replacement control
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/12—Replacement control
- G06F12/121—Replacement control using replacement algorithms
- G06F12/126—Replacement control using replacement algorithms with special data handling, e.g. priority of data or instructions, handling errors or pinning
- G06F12/127—Replacement control using replacement algorithms with special data handling, e.g. priority of data or instructions, handling errors or pinning using additional replacement algorithms
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/12—Replacement control
- G06F12/121—Replacement control using replacement algorithms
- G06F12/123—Replacement control using replacement algorithms with age lists, e.g. queue, most recently used [MRU] list or least recently used [LRU] list
- G06F12/124—Replacement control using replacement algorithms with age lists, e.g. queue, most recently used [MRU] list or least recently used [LRU] list being minimized, e.g. non MRU
Definitions
- the present invention relates to a cache memory for accelerating processor memory access and a control method thereof.
- LRU Least Recently Used
- Fo First In First Out
- the L RU method is a method of deciding on the replacement target that has the oldest order of coverage in the queue.
- This L RU method is, for example, the most common> J place algorithm adopted in the cache memory disclosed in Japanese Patent Application Laid-Open No. 20000-472, etc. o
- the cache memory is full-associative and has (2 to the power of 2) entries, then k bits for each entry will be used as data indicating the access order. I need.
- Access order data Disclosure of the Invention There is a problem that the scale of a circuit for updating memory (register or RAM) and access order data is large.
- the cache memory of the present invention stores 1-bit access information indicating presence / absence of access for each cache holding data serving as a cache unit. It has a storage means and a selection means for selecting the target server to be replaced from among the certificates corresponding to the access information indicating no access.
- the selection unit may be configured to select one cache unit ⁇ one randomly or in a round ⁇ type from cache units corresponding to access information indicating no access.
- the storage means caches access information that can be represented by one bit, instead of ad-terminating data indicating access order in the conventional LRU method on a case-by-case basis. Since each memory stores it, it is possible to reduce its storage capacity and to reduce the size of the hardware.
- the selection means uses the access information to indicate that there is no access, which is the target of the replay. This can be easily determined by selecting one of the corresponding caches, and the cabinet can also obtain a hit rate substantially equivalent to that of the conventional RU.
- the cache memory when the cache memory is hit in the cache entry, the cache memory also renews access information corresponding to the cache, and at that time, the cache memory is updated.
- the access information indicates that there is access, it may be configured to have an update means for setting access information corresponding to all the other cash cases ⁇ u without access.
- the »update means may further be configured to set the access information corresponding to the hit search entry at the time of the reset without any access.
- the storage means further stores new information indicating whether or not the data is in a new state immediately after the data is stored in the cache entry for each cache ⁇ U, and the update means is In addition, when the user clicks on the cache, the corresponding information on the cache will be reset to indicate that it is not in the new state.
- a configuration in which a cache entry to be replaced is selected from the cache entries corresponding to access information indicating access and indicating that the access state is not new. May
- the selection means corresponds to the access information indicating no access, and ignores the new information if there is no answer corresponding to the new information indicating that the access is not in the new state. It may be configured to select the cache entry to be replicated.
- the selection means ignores the access information. It may be configured to select one of the target documents.
- the method of controlling cache memory is a method of controlling cache memory having a memory for storing access information indicating presence or absence of access for each cache memory in cache memory.
- a detection step for detecting a search error and a mistake, and an update step for updating access information corresponding to a cache entry for which a hit detection has been detected.
- a determination step of determining whether access information corresponding to all other cache entries other than the cache entry where the hit is detected is indicated that the access is present or not; If the judgment result is positive, the access information corresponding to all other caches is updated to indicate no access.
- 2Selection step to select the cache object to be rebuilt from the cache entries corresponding to the access information indicating no access when the update step and miss entry are detected.
- FIG. 1 shows the processor and cache according to the first embodiment of the present invention.
- Figure 2 is a block diagram showing the configuration of the camera memory.
- Figure 3 is an explanatory diagram showing the bit configuration of the system entry.
- Figure 4 is a block diagram showing the configuration of the control unit? Ru.
- FIG. 6 is a diagram showing the flag updating process.
- Fig. 7 is a diagram showing a truth table showing input / output logic of the flag management unit.
- Fig. 8 is a diagram showing a circuit example of the flag management unit.
- Figure 9 shows the U-place processing flow.
- Fig. 10 is an explanatory view showing an example of flag updating in the modification.
- Fig. 1 1 is a diagram showing a flow of flag updating processing in the modification.
- Fig. 12 A is other than the selection processing in the modification.
- Fig. 12 B is a diagram showing another example of the selection process in the modification.
- Fig. 13 B is a diagram showing a configuration of a cache memory in the second embodiment of the present invention P ⁇ o o
- Fig.14 is an explanatory diagram showing the bit configuration of the cache entry.
- Fig.15 is a block diagram showing the configuration of the control unit.
- Figure 16 shows the flow of> J-place processing.
- Figure 17 shows the flag update process flow.
- Fig. 1 is a block diagram showing a schematic configuration of a system including processor 1, cache memory 3 and memo 2 according to the first embodiment of the present invention.
- ⁇ As shown in the figure, a cash memory 3 of the present invention Is provided in a system having a processor 1 and a memory 2 and is used as a replacement algorithm.
- pseudo LRU method data indicating the access order of the cache is represented by only one bit per cache memory, and the corresponding bit is 0.
- One of the target entries from within the library The method of choice is adopted.
- cache memory 3 As a specific example of cache memory 3, the configuration in the case where the above-mentioned pseudo-LRU is applied to 4-way set-associative cache memory will be described.
- FIG. 2 is a block diagram showing an example of the configuration of cache memory 3.
- cache memory 3 has an address register 20, a decoder 30 and four ways 31a to 31d (hereinafter referred to as ways 0 to 3) and a ratio of four.
- the address register 2 0 holds the access address to memory 2
- This access address shall be 32 bits. As shown in the figure, the access address is, in order from the most significant bit, a 21-bit tag address, a bit, a 4-bit set index (SI in the figure),
- One of the 5 bits-contains the index (W I in the figure).
- the tag word and the letter “less” refer to the area in the memory to be mapped to X (the size is set number X task).
- the size of this area is the size of one way, which is a size of 2 k bytes determined by the address below the tag address and the res bit (A 10 to A O).
- I points to one of multiple sets ranging from 0 to 3.
- the number of sets is 16 because the setting index is 4 bits.
- the protocol specified by the tag address and index is a replacement unit, and if it is stored in the cache memory, the size of the line data or line data called line is larger than that of the set index.
- the size is 1 2 8 bytes, which is determined by the lower address bit. 1 ⁇ If the data is 4 bytes, 1 line data is 32 words.
- the word index (WI) refers to a single word in multiple words that compose line data.
- the least significant 2 bits (A 1 AO) in address register 2 0 are ignored at single access.
- the coder 30 decodes the 4 bits of the set index, and selects one of 16 sets that spans four strings 0 to 3.
- one cache entry is a flag flag V 2.
- the no lead flag V indicates whether or not the cache ⁇ U is valid.
- the tag is a 21 bit tag pad and a copy of mless.
- Line data is a copy of 128-byte data in a block identified by tag address and setting information.
- the duty flag is whether or not the cache has been written, because the cache that has been cached in one place is different from the data in the memory by writing. Indicates that writing back to memory is required o
- the use flag U indicates whether or not there is an access to the cache entry, and the four keys in the set at the time of replacement by a miss hit Used instead of access order in cache entry • 3 ⁇ Precisely, 1 of use flag U means that 0 has not been accessed. If all four use flags in the set become 1, it will be 0
- the use flag u is Indicates whether the accessed time is old or new or two relative states.
- a cache entry with a usage flag U of 1 means that a cache entry with a usage flag of 0 has been accessed more recently.
- One of four cache entries is called a set.
- the comparator 32a includes the tag address in the address register 20 and the way in the four tags included in the set selected by the set index.
- the comparators 3 2 b to 3 2 c are the same except that they correspond to the ways 3 1 b to 3 1 d.
- the AND circuit 33a has the parity flag and the comparison result of the comparator 32a.
- a value of 0 means hit. If the comparison result h 0 is 0, it means that a miss hit has occurred. And circuits 3 3 b to 3 3 (about the same, except that they correspond to way 3 1 b 3 1 d. Comparison results h 1 to h 3 were hit in ways 1 to 3) OR circuit 3 or 4 takes the comparison result h 0 to h 3. The result of this or is the hit The hit is whether or not the hit is made to the cache memory Show.
- the selector 35 selects the line data of the hit way among the line data of ways 0 to 3 in the selected set.
- Selector 36 selects one of the line data of 32 words selected by selector 35, as shown in the end index.
- Demultiplexer 3 7 writes data to the cache. Output the write data to one of ways 0 to 3
- the word may be in word units.
- the control unit 38 performs overall control of the cache memory 3 and, in particular, determines the update of the use flag U and the cache memory to be replaced.
- control unit 38 has a flag updating unit 39 and a replacement unit 40.
- the flag updating unit 39 updates the valid flag, the used flag U, and the dirty flag D. It is well known that the read flag V and the duty flag D are updated.
- the flag updating unit 3 9 updates the use flag at the time of cache hit.
- FIG. 5 shows an example of updating of the use flag by the flag updating unit 3 9.
- the upper part and the lower part of the figure show the four cache entries that make up the set N that straddles the lines 0-3.
- the cache entry in 3 means that there is no access.
- the pre-processing unit 40 performs the re-presence by determining the cancellation target ⁇ one based on the use flag at the time of the cancellation 3 ⁇ 4. For example, in the upper part of FIG. 5, place part 40 determines either of process 1 or 3 as a target to be replayed, and in the middle part of FIG. 5 determines that 3 is a target of replay, In the lower part of Fig. 5, one of X X 2 and 2 2 is determined to be a target for replacement.
- FIG. 6 is a flowchart showing flag update processing in the flag update unit 3 9
- Step S 61 when the flag update unit 39 performs a cache hit (step S 61), the flag u of the way used in the set selected by the setup flag is used. Set it to 1 (Step S 6 2), read the use flag u of other ways in the set (Step S 6 3), and check whether the read use flag U is all 1 or not. (Step S 6 4), and if not all 1, the process ends. If all 1, all use flags u of other ways are reset to 0 (step S 6 5).
- the flag updating unit 3 9 can update the usage flag as in the example of updating shown in FIG.
- FIG. 7 is a diagram showing a truth table showing the input / output logic of the flag updating unit 39.
- H 0 h 3 in the input column of the figure is a hit signal in the ways 0 to 3 shown in FIG.
- U O i i n to U 3 _ i n indicate the values (values before update) of the use flags of way 0 to way 3 read from the set selected by the set index.
- the flag updating unit 3 9 in the same figure is an AND circuit 80 to 8 3, an AND circuit 8 4 to 8 7, an OR circuit 8 8, an OR circuit 8 9 to 9 2, a selector.
- the use circuits 8 0 to 8 3 are the set selected by the index. • The use flags of 0 to 3 3 U 0-i 3 to 4 ⁇ are used. U 0 — i n to U
- the cache flag whose buffer flag V is 1 (valid) 'J1's use flag U 0 i 1 to U 3 _ i n is output.
- the NAND circuits 8 4 to 8 7 and the inverter circuit 8 8 are the same as in FIG. 7 unless the output of the AND circuit 8 0 8 3 shown in FIG. Detect the case of the mouth mark of the input column of. Use flag of other ways in hit, hit way U — detect all cases where i is 1
- Circuits 8 9 to 9 2 respectively have hit signals h 0 to h 3 and use flags
- Selectors 9 3 to 9 6 are on the 1 side if the case marked above is detected.
- a circuit like this makes it possible to convert the truth table in Fig. 7 into one. Reduced hardware size, as it is not necessary to indicate the access order of individual ways, and it is only necessary to update the 1-bit usage flag for each way. can do.
- FIG. 9 is a flowchart showing the replacement process in the replacement unit 40.
- the replay process unit 40 reads the use flag U of the four ways in the memory access miss (step S 91) and the setup selected again by the setup index. Exit (Step S 9 2) and select one way whose usage flag U is 0 (Step S 9 3). At this time, if there is more than one queue whose use flag U is 0, the replay unit 40 randomly selects one. Furthermore, the replacement unit 40 applies the replacement to the selected cache in the set (step S94), and the replacement after the replacement. Initialize the usage flag U to 1 (step S95). Note that, at this time, the U flag U and the flag D are initialized to 1 and 0, respectively.
- the target for replacement is determined by selecting one of the cache entries whose usage flag is 0. This replacement algorithm is used instead of data indicating access order in the conventional LRU method.
- the cache memory of the present invention is not limited to the configuration of the above embodiment, and various modifications are possible. Any of the modifications will be described below.
- the flag updating unit 3 9 sets the use flags U 0 to U 3 of the other ways in the vehicle V to 0 if all the flags are 0, as shown in the lower part of FIG. It is possible to update its own use flag to 1, but instead it may be configured to update its own use flag to 0 as well.
- Figure 1 0 shows an example of flag update in the case of ⁇ . .
- FIG. 10 is different from FIG. 5 in that the lower row 3 is 0 instead of 1.
- FIG. 11 is a chart showing the flag update process in this modification. This figure is different from FIG. 6 in that Step S 65 instead of Step S 65
- step S 65 a the flag updating unit 3 9 resets all use flags u 0 to U 3 in the set to 0.
- step S 9 3 shown in FIG. If there is more than one candidate flag with a use flag of 0, select 1 for random, but instead of> ⁇ , select regularly.
- the u-pres unit 4 0 may be selected in such a case that y (L) or P (L) is selected as the way number is smaller (larger).
- Fig. 12 A shows the process 3 ⁇ 4 r to select the random and ⁇ bin expressions.
- the U-pres portion 40 determines the number of the way that was previously replaced when there are multiple caches with a use flag of 0 in the memory and the memory (step S). 1 2 1) Select a cache entry with a number with a use flag of 0 and a cache with a number larger than the determined number (step S 12 2).
- the number replaced last may be determined, for example, by providing a register that holds the number of the tray placed in the entire cache memory and referencing the relevant lister.
- ⁇ ⁇ ⁇ ⁇ registers may indicate replaced ques by bit position.
- An example of the register in this case is shown in Figure 12 ⁇ .
- the figure shows the transition of the 4-bit field in the register. Bit positions of 4 bits of, _> correspond to way 0 to way 3. Of the four bits, the “1” bit indicates the previously replaced key 3 ⁇ 4 :.
- the rib race 40 is the closest to the direction in which the bit "1" is rotated to the right from among the cache entries whose use flag in the set is 0 in the set. Determine the bit and select the cache of the key corresponding to the bit position. In the example of the figure, ways 0, 1,
- V, and 2 are selected in the order of V.
- Figure 12 shows the common registers for all the sets, it is also possible to have individual registers for each set.
- the 4-way ⁇ set ⁇ association key The cache memory has been described as an example, but the number of entries may be 8 to 16 and 3 may be 3, and in the above embodiment, an example in which the number of sets is 16 has been described. Any number of sets may be used
- the cache memory of the setup-association is described as an example, but it may be a cache memory of a full-system cache type.
- the use flag U may be 1 bit or 2 bits. For example, in the case of 2 bits, it is not necessary to completely indicate the access order of each cache memory, but it is preferable to be able to determine whether 2 states are less or less or old or new. You may define the third state and the four hundredth state that can be represented by a bit.
- step S955 shown in FIG. 9 the use flag U immediately after the reply is initialized to 1, but it may be initialized to 0 instead of «. However, if the initial value of the usage flag is set to 0, there is a possibility that the printer may be re-bleaked again due to a cache miss that occurred after the reload.
- FIG. 13 is a block diagram showing the configuration of the cache memory according to the second embodiment of the present invention.
- the cache memory of the figure shows that the control section 38 has the secret of storing the 1 13 1 a 1 3 1 d instead of the 3 1 a to 3 1 d.
- the difference from the point having the control unit 1 3 8 is the same.
- the explanation of the same points is omitted, and the explanation will be made centering on the 3 ⁇ 4 point. In each case, there will be a point where a two-way flag is added
- Figure 14 shows the bit configuration of one cache within the key 1 3 1 a. As shown in the figure, the difference is that the second flag N is added. It has become. The second flag N is set to 1 as an initial value immediately after (or immediately after) filling, and is set to 0 when the corresponding computer is accessed. “1” in the “n” flag means that the word has been placed (or filled) and has not been accessed even once, and that it is in a new state.
- control unit 1 38 has a flag updating unit 1 3 9 and a release unit 1 40 0, and as compared with the control unit 3 8
- the setting and updating of flag N is different from the point of excluding a cache memory with a new flag of 1 at U place from U place.
- Figure 16 is a step-by-step chart showing the replacement process in the replacement section 140.
- pj Figure is compared with Figure 9 and step S 92 instead of step S 92 9 2 a and a step between steps 9 2 a and 9 3
- step S.sub.95 a is provided instead of step S.sub.95.
- step S92a the replacement unit 140 is used as the four-way use flag U 0 to U in the set selected by the set-up.
- step S 1 6 1 Determine if all of N 3 are 1's (step S 1 6 1), and if all 1's, go to step S 9 3 and if not all 1's (0's) In this case, out of the ways whose use flag U is 0, we exclude the way whose 2 you flag N is 1 (step S 1 6 2).
- step S 95 a the replacement unit 140 initializes the new flag N to 1 along with the initialization of other flags.
- FIG. 17 is a flowchart showing the flag update process in the flag new part 1 3 9. The figure is different from FIG. 6 in that step S 1 7 1 is added between steps S 6 2 and S 6 3.
- step S 1 71 the flag updating unit 1 3 9 determines that the flag of the cache entry of the hit queue in the selected set is “1”.
- the replacement unit 140 excludes the corresponding entry from the target of the replacement when the new flag is 1. This is due to the following reasons. In other words, if the use flag u has an initial value of 1 and if the use flags of other ways become 1 sequentially
- Modifications (1) to (5) of the first embodiment may be applied to the present embodiment.
- step S 95 a shown in Fig. 16 the use flag U immediately after replacement is initialized to 1, but instead, it may be initialized to 0. Unlike the first embodiment, since the new flag N is provided in the present embodiment, even if the initial value of the use flag is 1 or 0, access is also performed even if cache misses occur after replacement. It is possible to prevent re-pressing without being done.
- the cache memory in each of the above embodiments may be applied to any of an on-chip cache, an off-chip cache, an instruction cache, and a data cache built in a chip together with the processor.
- the present invention is directed to cache memory for speeding up memory and processing and its control method, for example, on-chip cache memory, off-chip cache memory, and memory memory. Suitable for instruction cache memory etc.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Memory System Of A Hierarchy Structure (AREA)
Abstract
Description
Claims
Priority Applications (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
EP04772377A EP1667028A4 (en) | 2003-09-19 | 2004-08-23 | ANTEMEMOIRE AND METHOD FOR CONTROLLING ANTEMEMOIRE |
US10/571,531 US20070028055A1 (en) | 2003-09-19 | 2004-08-23 | Cache memory and cache memory control method |
JP2005514011A JP4009304B2 (ja) | 2003-09-19 | 2004-08-23 | キャッシュメモリおよびキャッシュメモリ制御方法 |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2003-327032 | 2003-09-19 | ||
JP2003327032 | 2003-09-19 |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2005029336A1 true WO2005029336A1 (ja) | 2005-03-31 |
Family
ID=34372854
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/JP2004/012421 WO2005029336A1 (ja) | 2003-09-19 | 2004-08-23 | キャッシュメモリおよびキャッシュメモリ制御方法 |
Country Status (7)
Country | Link |
---|---|
US (1) | US20070028055A1 (ja) |
EP (1) | EP1667028A4 (ja) |
JP (1) | JP4009304B2 (ja) |
KR (1) | KR20060063804A (ja) |
CN (1) | CN100429632C (ja) |
TW (1) | TW200525356A (ja) |
WO (1) | WO2005029336A1 (ja) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2007293839A (ja) * | 2006-04-25 | 2007-11-08 | Internatl Business Mach Corp <Ibm> | ロックされたキャッシュ内のセットの置換を管理するための方法、コンピュータ・プログラム、キャッシング・システムおよびプロセッサ |
JP2010538390A (ja) * | 2007-09-04 | 2010-12-09 | アドバンスト・マイクロ・ディバイシズ・インコーポレイテッド | プロセッサの非常にアソシエティビティの高いキャッシュメモリ用のセカンドチャンス置換機構 |
JP2015193164A (ja) * | 2014-03-31 | 2015-11-05 | ブラザー工業株式会社 | 非吐出ノズル検出装置 |
Families Citing this family (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR20070093452A (ko) | 2005-04-08 | 2007-09-18 | 마쯔시다덴기산교 가부시키가이샤 | 캐시 메모리 시스템 및 그 제어 방법 |
KR100772196B1 (ko) * | 2005-12-06 | 2007-11-01 | 한국전자통신연구원 | Pci 메모리를 이용한 무복사 캐싱 방법 및 그 장치 |
SK287315B6 (sk) | 2006-06-02 | 2010-06-07 | Biotika, A. S. | Spôsob izolácie polymyxínu B z vyfermentovanej pôdy |
SK287293B6 (sk) | 2006-06-15 | 2010-05-07 | Biotika, A. S. | Spôsob fermentácie polymyxínu B pomocou produkčného mikroorganizmu Bacillus polymyxa |
US20080292560A1 (en) * | 2007-01-12 | 2008-11-27 | Dov Tamarkin | Silicone in glycol pharmaceutical and cosmetic compositions with accommodating agent |
US8214602B2 (en) * | 2008-06-23 | 2012-07-03 | Advanced Micro Devices, Inc. | Efficient load queue snooping |
TW201015319A (en) * | 2008-09-17 | 2010-04-16 | Panasonic Corp | Cache memory, memory system, data copying method and data rewriting method |
TW201017421A (en) * | 2008-09-24 | 2010-05-01 | Panasonic Corp | Cache memory, memory system and control method therefor |
CN107992433A (zh) * | 2017-12-19 | 2018-05-04 | 北京云知声信息技术有限公司 | 二级缓存检测方法及装置 |
US10783083B2 (en) * | 2018-02-12 | 2020-09-22 | Stmicroelectronics (Beijing) Research & Development Co. Ltd | Cache management device, system and method |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPS55157181A (en) * | 1979-05-25 | 1980-12-06 | Nec Corp | Buffer memory control system |
JPH0362144A (ja) * | 1989-04-13 | 1991-03-18 | Bull Sa | 情報処理システムのメモリアクセスを速くする方法及びこの方法を実施するためのシステム |
JPH04288647A (ja) * | 1991-02-27 | 1992-10-13 | Mitsubishi Electric Corp | キャッシュメモリにおける置き換え制御装置 |
JPH0619797A (ja) * | 1992-04-29 | 1994-01-28 | Sun Microsyst Inc | キャッシュ内の記憶されている行を保護する装置及び方法 |
Family Cites Families (14)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4195343A (en) * | 1977-12-22 | 1980-03-25 | Honeywell Information Systems Inc. | Round robin replacement for a cache store |
US5497477A (en) * | 1991-07-08 | 1996-03-05 | Trull; Jeffrey E. | System and method for replacing a data entry in a cache memory |
JP3309425B2 (ja) * | 1992-05-22 | 2002-07-29 | 松下電器産業株式会社 | キャッシュ制御装置 |
JPH06348595A (ja) * | 1993-06-07 | 1994-12-22 | Hitachi Ltd | キャッシュ装置 |
US5802568A (en) * | 1996-06-06 | 1998-09-01 | Sun Microsystems, Inc. | Simplified least-recently-used entry replacement in associative cache memories and translation lookaside buffers |
US5809528A (en) * | 1996-12-24 | 1998-09-15 | International Business Machines Corporation | Method and circuit for a least recently used replacement mechanism and invalidated address handling in a fully associative many-way cache memory |
US6032228A (en) * | 1997-11-26 | 2000-02-29 | International Business Machines Corporation | Flexible cache-coherency mechanism |
US6393525B1 (en) * | 1999-05-18 | 2002-05-21 | Intel Corporation | Least recently used replacement method with protection |
US6282617B1 (en) * | 1999-10-01 | 2001-08-28 | Sun Microsystems, Inc. | Multiple variable cache replacement policy |
US20030105929A1 (en) * | 2000-04-28 | 2003-06-05 | Ebner Sharon M. | Cache status data structure |
JP3661614B2 (ja) * | 2001-07-12 | 2005-06-15 | 日本電気株式会社 | キャッシュメモリ制御方法及びマルチプロセッサシステム |
JP2003131946A (ja) * | 2001-10-19 | 2003-05-09 | Nec Corp | キャッシュメモリ制御装置及び方法 |
US20030084253A1 (en) * | 2001-10-31 | 2003-05-01 | Johnson David J.C. | Identification of stale entries in a computer cache |
US6996678B1 (en) * | 2002-07-31 | 2006-02-07 | Cisco Technology, Inc. | Method and apparatus for randomized cache entry replacement |
-
2004
- 2004-08-23 US US10/571,531 patent/US20070028055A1/en not_active Abandoned
- 2004-08-23 KR KR1020057024622A patent/KR20060063804A/ko not_active Application Discontinuation
- 2004-08-23 CN CNB2004800270749A patent/CN100429632C/zh not_active Expired - Fee Related
- 2004-08-23 WO PCT/JP2004/012421 patent/WO2005029336A1/ja active Application Filing
- 2004-08-23 JP JP2005514011A patent/JP4009304B2/ja not_active Expired - Fee Related
- 2004-08-23 EP EP04772377A patent/EP1667028A4/en not_active Withdrawn
- 2004-08-30 TW TW093126043A patent/TW200525356A/zh unknown
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPS55157181A (en) * | 1979-05-25 | 1980-12-06 | Nec Corp | Buffer memory control system |
JPH0362144A (ja) * | 1989-04-13 | 1991-03-18 | Bull Sa | 情報処理システムのメモリアクセスを速くする方法及びこの方法を実施するためのシステム |
JPH04288647A (ja) * | 1991-02-27 | 1992-10-13 | Mitsubishi Electric Corp | キャッシュメモリにおける置き換え制御装置 |
JPH0619797A (ja) * | 1992-04-29 | 1994-01-28 | Sun Microsyst Inc | キャッシュ内の記憶されている行を保護する装置及び方法 |
Non-Patent Citations (1)
Title |
---|
See also references of EP1667028A4 * |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2007293839A (ja) * | 2006-04-25 | 2007-11-08 | Internatl Business Mach Corp <Ibm> | ロックされたキャッシュ内のセットの置換を管理するための方法、コンピュータ・プログラム、キャッシング・システムおよびプロセッサ |
JP2010538390A (ja) * | 2007-09-04 | 2010-12-09 | アドバンスト・マイクロ・ディバイシズ・インコーポレイテッド | プロセッサの非常にアソシエティビティの高いキャッシュメモリ用のセカンドチャンス置換機構 |
JP2015193164A (ja) * | 2014-03-31 | 2015-11-05 | ブラザー工業株式会社 | 非吐出ノズル検出装置 |
Also Published As
Publication number | Publication date |
---|---|
EP1667028A4 (en) | 2008-10-29 |
CN100429632C (zh) | 2008-10-29 |
JPWO2005029336A1 (ja) | 2006-11-30 |
TW200525356A (en) | 2005-08-01 |
US20070028055A1 (en) | 2007-02-01 |
CN1853171A (zh) | 2006-10-25 |
KR20060063804A (ko) | 2006-06-12 |
EP1667028A1 (en) | 2006-06-07 |
JP4009304B2 (ja) | 2007-11-14 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7484042B2 (en) | Data processing system and method for predictively selecting a scope of a prefetch operation | |
US6339813B1 (en) | Memory system for permitting simultaneous processor access to a cache line and sub-cache line sectors fill and writeback to a system memory | |
JP7049338B2 (ja) | タグマッチングコマンドに応答する記憶回路 | |
JP3620473B2 (ja) | 共有キャッシュメモリのリプレイスメント制御方法及びその装置 | |
US6282617B1 (en) | Multiple variable cache replacement policy | |
US20080016284A1 (en) | Data processing system and method for predictively selecting a scope of broadcast of an operation utilizing a history-based prediction | |
CN112612727B (zh) | 一种高速缓存行替换方法、装置及电子设备 | |
WO2005029336A1 (ja) | キャッシュメモリおよびキャッシュメモリ制御方法 | |
US7937536B2 (en) | Handling direct memory accesses | |
JP2005528695A (ja) | キャッシュ置換ポリシーの簡略化した実施態様を用いたマルチスレッド化キャッシュのための方法および装置 | |
JP2005528694A (ja) | スレッド識別子に基づくキャッシュ追い出しを用いたマルチスレッド化キャッシュのための方法および装置 | |
US10997079B2 (en) | Method and arrangement for saving cache power | |
US20070226423A1 (en) | Processor, data processing system, and method for initializing a memory block in a data processing system having multiple coherency domains | |
JP2006323845A (ja) | メモリ・ブロックを初期設定するためのプロセッサ、データ処理システム、および方法 | |
CN113961483A (zh) | 高速缓存存储器和使用高速缓存存储器的方法 | |
TW200908009A (en) | Hierarchical cache tag architecture | |
JPH07253927A (ja) | 物理的にアドレス指定されたデータ記憶構造からの迅速なデータリトリーブ方法及び装置 | |
JP3463292B2 (ja) | キャッシュ動作要求間の競合に応答して置換用の代替キャッシュ・エントリを選択する方法及びシステム | |
US20080307169A1 (en) | Method, Apparatus, System and Program Product Supporting Improved Access Latency for a Sectored Directory | |
TW200809500A (en) | Data processing system and method for selecting a scope of broadcast of an operation by reference to a translation table | |
US7302530B2 (en) | Method of updating cache state information where stores only read the cache state information upon entering the queue | |
JP2846697B2 (ja) | キャッシュメモリ制御装置 | |
US7865666B2 (en) | Cache memory systems and methods thereof | |
US20080028139A1 (en) | Content-addressable memory that supports a priority ordering between banks | |
JPH11328017A (ja) | 偶数/奇数キャッシュ・ディレクトリ方法及び装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
WWE | Wipo information: entry into national phase |
Ref document number: 200480027074.9 Country of ref document: CN |
|
AK | Designated states |
Kind code of ref document: A1 Designated state(s): AE AG AL AM AT AU AZ BA BB BG BW BY BZ CA CH CN CO CR CU CZ DK DM DZ EC EE EG ES FI GB GD GE GM HR HU ID IL IN IS JP KE KG KP KZ LC LK LR LS LT LU LV MA MD MK MN MW MX MZ NA NI NO NZ PG PH PL PT RO RU SC SD SE SG SK SY TJ TM TN TR TT TZ UA UG US UZ VN YU ZA ZM |
|
AL | Designated countries for regional patents |
Kind code of ref document: A1 Designated state(s): GM KE LS MW MZ NA SD SZ TZ UG ZM ZW AM AZ BY KG MD RU TJ TM AT BE BG CH CY DE DK EE ES FI FR GB GR HU IE IT MC NL PL PT RO SE SI SK TR BF CF CG CI CM GA GN GQ GW ML MR SN TD TG |
|
121 | Ep: the epo has been informed by wipo that ep was designated in this application | ||
WWE | Wipo information: entry into national phase |
Ref document number: 1020057024622 Country of ref document: KR |
|
WWE | Wipo information: entry into national phase |
Ref document number: 2005514011 Country of ref document: JP |
|
WWE | Wipo information: entry into national phase |
Ref document number: 2007028055 Country of ref document: US Ref document number: 10571531 Country of ref document: US |
|
WWE | Wipo information: entry into national phase |
Ref document number: 2004772377 Country of ref document: EP |
|
WWP | Wipo information: published in national office |
Ref document number: 2004772377 Country of ref document: EP |
|
WWP | Wipo information: published in national office |
Ref document number: 1020057024622 Country of ref document: KR |
|
WWP | Wipo information: published in national office |
Ref document number: 10571531 Country of ref document: US |