WO1999050752A1 - Shared cache structure for temporal and non-temporal instructions - Google Patents

Shared cache structure for temporal and non-temporal instructions Download PDF

Info

Publication number
WO1999050752A1
WO1999050752A1 PCT/US1999/006501 US9906501W WO9950752A1 WO 1999050752 A1 WO1999050752 A1 WO 1999050752A1 US 9906501 W US9906501 W US 9906501W WO 9950752 A1 WO9950752 A1 WO 9950752A1
Authority
WO
WIPO (PCT)
Prior art keywords
cache
data
temporal
bit
memory
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Ceased
Application number
PCT/US1999/006501
Other languages
English (en)
French (fr)
Other versions
WO1999050752A9 (en
Inventor
Salvador Palanca
Niranjan L. Cooray
Angad Narang
Vladimir Pentkovski
Steve Tsai
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Intel Corp
Original Assignee
Intel Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Intel Corp filed Critical Intel Corp
Priority to JP2000541596A priority Critical patent/JP4486750B2/ja
Priority to BR9909295-6A priority patent/BR9909295A/pt
Priority to EP99915030A priority patent/EP1066566B1/en
Priority to AU33645/99A priority patent/AU3364599A/en
Publication of WO1999050752A1 publication Critical patent/WO1999050752A1/en
Publication of WO1999050752A9 publication Critical patent/WO1999050752A9/en
Anticipated expiration legal-status Critical
Ceased legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/08Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/08Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
    • G06F12/0802Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches
    • G06F12/0875Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches with dedicated cache, e.g. instruction or stack
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/08Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
    • G06F12/0802Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches
    • G06F12/0864Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches using pseudo-associative means, e.g. set-associative or hashing
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/08Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
    • G06F12/12Replacement control
    • G06F12/121Replacement control using replacement algorithms
    • G06F12/126Replacement control using replacement algorithms with special data handling, e.g. priority of data or instructions, handling errors or pinning
    • GPHYSICS
    • G06COMPUTING OR CALCULATING; COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • G06F12/02Addressing or allocation; Relocation
    • G06F12/08Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
    • G06F12/0802Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches
    • G06F12/0862Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches with prefetch

Definitions

  • the present invention relates in general to the field of processors, and in particular, to a technique of providing a shared cache structure for temporal and non-temporal instructions.
  • cache memory with a processor facilitates the reduction of memory access time.
  • the fundamental idea of cache organization is that by keeping the most frequently accessed instructions and data in the fast cache memory, the average memory access time will approach the access time of the cache.
  • typical processors implement a cache hierarchy, that is, different levels of cache memory.
  • the different levels of cache correspond to different distances from the processor core. The closer the cache is to the processor, the faster the data access. However, the faster the data access, the more costly it is to store data. As a result, the closer the cache level, the faster and smaller the cache.
  • cache memory The performance of cache memory is frequently measured in terms of its hit ratio.
  • the processor refers to memory and finds the word in cache, it is said to produce a hit. If the word is not found in cache, then it is in main memory and it counts as a miss. If a miss occurs, then an allocation is made at the entry indexed by the access. The access can be for loading data to the processor or storing data from the processor to memory. The cached information is retained by the cache memory until it is no longer needed, made invalid or replaced by other data, in which instances the cache entry is de-allocated.
  • the faster and smaller LI cache is located closer to the processor than the L2 cache.
  • the processor requests cacheable data, for example, a load instruction
  • the request is first sent to the LI cache. If the requested data is in the LI cache, it is provided to the processor. Otherwise, there is an LI miss and the request is transferred to the L2 cache. Likewise, if there is an L2 cache hit, the data is passed to the LI cache and the processor core. If there is an L2 cache miss, the request is transferred to main memory. The main memory responds to the L2 cache miss by providing the requested data to the L2 cache, the LI cache, and to the processor core.
  • the type of data that is typically stored in cache includes active portions of programs and data. When the cache is full, it is necessary to replace existing lines of stored data in the cache memory to make room for newly requested lines of data.
  • One such replacement technique involves the use of the least recently used (LRU) algorithm, which replaces the least recently used line of data with the newly requested line.
  • LRU least recently used
  • the L2 cache since the L2 cache is larger than the LI cache, the L2 cache typically stores everything in the LI cache and some additional lines that have been replaced in the LI cache by the LRU algorithm.
  • U.S. Patent Application serial number 08/767,950 filed December 17, 1996, entitled “Cache Hierarchy Management” discloses a technique for allocating cache memory through the use of a locality hint associated with an instruction.
  • a processor accesses memory for transfer of data between the processor and the memory, that access can be allocated to the various levels of cache, or not allocated to cache memory at all, according to the locality hint associated with the instruction.
  • Certain instructions are used infrequently.
  • non-temporal prefetch instructions preload data which the processor does not require immediately, but which are anticipated to be required in the near future. Such data is typically used only once or will not be reused in the immediate future, and is termed “non-temporal data”. Instructions that are frequently used are termed "temporal data".
  • U.S. Application serial number 08/767,950 solves this problem by providing a buffer, separate from the cache memory, for storing the infrequently used data, such as non-temporal prefetched data.
  • a buffer separate from the cache memory, for storing the infrequently used data, such as non-temporal prefetched data.
  • the use of an extra, separate buffer is expensive both in terms of cost and space.
  • a method and system for providing cache memory management comprises a main memory, a processor coupled to the main memory, and at least one cache memory coupled to the processor for caching of data.
  • the at least one cache memory has at least two cache ways, each comprising a plurality of sets. Each of the plurality of sets has a bit which indicates whether one of the at least two cache ways contains non-temporal data.
  • the processor accesses data from one of the main memory or the at least one cache memory.
  • Figure 1 illustrates a circuit block diagram of one embodiment of a computer system which implements the present invention, in which a cache memory is used for data accesses between a main memory and a processor of the computer system.
  • Figure 2 is a circuit block diagram of a second embodiment of a computer system which implements the present invention, in which two cache memories are arranged into cache memory levels for accessing data between a main memory and a processor(s) of the computer system.
  • Figure 3 is a block diagram illustrating one embodiment of the organizational structure of the cache memory in which the technique of the present invention is implemented.
  • Figure 4 is a table illustrating the cache management technique, according to one embodiment of the present invention.
  • Figures 5A and 5B illustrate one example of the organization of a cache memory prior to and after temporal instruction hits way 2 of cache set 0, according to one embodiment of the present invention.
  • Figures 6A and 6B illustrate another example of the organization of a cache memory prior to and after temporal instruction hits way 2 of cache set 0, according to one embodiment of the present invention.
  • Figures 7A - 7D illustrate a example of the organization of a cache memory prior to and after a non-temporal instruction hits way 2 of cache set 0, according to one embodiment of the present invention.
  • Figures 8A - 8D illustrate another example of the organization of a cache memory prior to and after a non-temporal instruction hits way 2 of cache set 0, according to one embodiment of the present invention.
  • Figures 9A and 9B illustrate one example of the organization of a cache memory prior to and after a temporal instruction miss to cache set 0, according to one embodiment of the present invention.
  • Figures 10 A - 10D illustrate an example of the organization of a cache memory prior to and after a non-temporal instruction miss to cache set 0, according to one embodiment of the present invention.
  • a technique for providing management of cache memories, in which cache allocation is determined by data utilization.
  • numerous specific details are set forth, such as specific memory devices, circuit diagrams, processor instructions, etc., in order to provide a thorough understanding of the present invention.
  • the present invention may be practiced without these specific details.
  • well known techniques and structures have not been described in detail in order not to obscure the present invention. It is to be noted that a particular implementation is described as a preferred embodiment of the present invention, however, it is readily understood that other embodiments can be designed and implemented without departing from the spirit and scope of the present invention.
  • a typical computer system is shown, wherein a processor 10, which forms the central processing unit (CPU) of the computer system is coupled to a main memory 11 by a bus 14.
  • the main memory 11 is typically comprised of a random-access- memory and is usually referred to as RAM.
  • the main memory 11 is generally coupled to a mass storage device 12, such as a magnetic or optical memory device, for mass storage (or saving) of information.
  • a cache memory 13 (hereinafter also referred simply as cache) is coupled to the bus 14 as well.
  • the cache 13 is shown located between the CPU 11 and the main memory 11, in order to exemplify the functional utilization and transfer of data associated with the cache 13. It is appreciated that the actual physical placement of the cache 13 can vary depending on the system and the processor architecture. Furthermore, a cache controller 15 is shown coupled to the cache 13 and the bus 14 for controlling the operation of the cache 13. The operation of a cache controller, such as the controller 15, is known in the art and, accordingly, in the subsequent Figures, cache controllers are not illustrated. It is presumed that some controller(s) is/are present under control of the CPU 10 to control the operation of cache(s) shown.
  • information transfer between the memory 11 and the CPU 10 is achieved by memory accesses from the CPU 10.
  • cacheable data is currently or shortly to be accessed by the CPU 10, that data is first allocated in the cache 13. That is, when the CPU 10 accesses a given information from the memory 11, it seeks the information from the cache 13. If the accessed data is in the cache 13, a "hit” occurs. Otherwise, a "miss” results and cache allocation for the data is sought.
  • most accesses (whether load or store) require the allocation of the cache 13. Only uncacheable accesses are not allocated in the cache. Referring to Figure 2, a computer system implementing a multiple cache arrangement is shown.
  • the CPU 10 is still coupled to the main memory 11 by the bus 14 and the memory 11 is then coupled to the mass storage device 12.
  • two separate cache memories 21 and 22 are shown.
  • the caches 21-22 are shown arranged serially and each is representative of a cache level, referred to as Level 1 (LI) cache and Level 2 (L2) cache, respectively.
  • the LI cache 21 is shown as part of the CPU 10, while the L2 cache 22 is shown external to the CPU 10.
  • This structure exemplifies the current practice of placing the LI cache on the processor chip while lower level caches are placed external to it, where the lower level caches are further from the processor core.
  • the actual placement of the various cache memories is a design choice or dictated by the processor architecture.
  • the LI cache could be placed external to the CPU 10.
  • CPU 10 includes an execution unit 23, register file 24 and fetch/decoder unit 25.
  • the execution unit 23 is the processing core of the CPU 10 for executing the various arithmetic (or non-memory) processor instructions.
  • the register file 24 is a set of general purpose registers for storing (or saving) various information required by the execution unit 23. There may be more than one register file in more advanced systems.
  • the fetch/decoder unit 25 fetches instructions from a storage location (such as the main memory 11) holding the instructions of a program that will be executed and decodes these instructions for execution by the execution unit 23.
  • a bus interface unit (BIU) 26 provides an interface for coupling the various units of CPU 10 to the bus 14.
  • the LI cache is coupled to the internal bus 27 and functions as an internal cache for the CPU 10.
  • the LI cache could reside outside of the CPU 10 and coupled to the bus 14.
  • the caches can be used to cache data, instructions or both. In some systems, the LI cache is actually split into two sections, one section for caching data and one section for caching instructions.
  • the computer system may be comprised of more than one CPU (as shown by the dotted line in Figure 2). In such a system, it is typical for multiple CPUs to share the main memory 11 and/or mass storage unit 12. Accordingly, some or all of the caches associated with the computer system may be shared by the various processors of the computer system. For example, with the system of Figure 2, LI cache 21 of each processor would be utilized by its processor only, but the main memory 11 would be shared by all of the CPUs of the system. In addition, each CPU has an associated external L2 cache 22. The invention can be practiced in a single CPU computer system or in a multiple CPU computer system.
  • DMA direct memory accessing
  • Figure 3 is a block diagram illustrating one embodiment of the organizational structure of the cache memory in which the technique of the present invention is implemented.
  • the invention provides an LRU lock bit which indicates whether any one of the ways within that set contains non-temporal (NT) data. If so, the regular or pseudo LRU bits will be updated to point to the NT data.
  • NT non-temporal
  • the number of regular or pseudo-LRU bits per set varies depending on the number of ways per set and the LRU (regular or pseudo) technique implemented.
  • the cache 50 is organized as a four- way set associative cache.
  • each page is shown as being equal to one-fourth the cache size.
  • the cache 50 is divided into four ways (for example, way 0 (52), way 1 (54), way 2 (56) and way 3 (58)) of equal size and main memory 11 (see also Figures 1 and 2) is viewed as divided into pages (e.g., page 0 - page n).
  • each page may be larger or smaller than the cache size.
  • the organizational structure of cache 50 (as shown in Figure 3) may be implemented within the cache 13 of Figure 1, the LI cache and /or L2 cache 22 of Figure 2.
  • the cache 50 also includes an array of least recently used (LRU) bits 60o - 60n each of which points to the way within a set with the least recently used data (or NT data, if a biased LRU technique is implemented). Such listing is performed in accordance with an LRU technique under the control of the cache controller 15, to determine which cache entry to overwrite in the event that a cache set is full.
  • the LRU logic (not shown) keeps track of the cache locations within a set that have been least recently used.
  • an LRU technique that strictly keeps track of the least-recently used directory algorithm may be implemented.
  • a pseudo-LRU algorithm which makes a best attempt at keeping track of the least recently used directory element, is implemented.
  • the cache 50 further includes an array of LRU lock bits 70o - 70n which indicates whether any of the ways 52, 54, 56, 58 within a given set contains data that should not pollute the cache 50 (i.e., data with infrequent usage), as described in detail in the following sections.
  • FIG 4 is a table illustrating the cache management technique in accordance with the principles of the present invention.
  • the invention utilizes the array of LRU lock bits 70o - 70n to indicate whether any of the corresponding cached data is streaming or non- temporal, and as such, would be the first entry to be replaced upon a cache miss to the corresponding set.
  • the LRU lock bit 70 when set to 1, indicates that the corresponding set has an entry that is non-temporal. If the LRU lock bit 70 is cleared, upon a cache hit by a temporal instruction, the corresponding LRU bit(s) 60 is(are) updated in accordance with the LRU technique implemented (see item 1 of Figure 4) and the associated LRU lock bit is not updated. However, if the LRU lock bit 70 is already set to 1 (indicating that the corresponding set has a non-temporal instruction), the LRU lock bit 70 is not updated, and the LRU bit 60 is not updated (see item 2 ).
  • the LRU bit 60 and the LRU lock bit 70 are not updated, regardless of the status of the LRU lock bit 70 (see item 3).
  • cache hits by a streaming or non-temporal instructions force the LRU bits to the way that was hit (see item 4).
  • the LRU lock bit 70 is set to 1.
  • the data hit by the streaming or non-temporal instruction will be the first to be replaced upon a cache miss to the corresponding set.
  • the LRU lock bit Upon a cache miss by a temporal instruction, the LRU lock bit is cleared and the LRU bit 60 is updated (item 5) based on a pseudo LRU technique. However, upon a cache miss by a streaming or non- temporal instruction, the LRU lock bit 70 is set to 1 and the corresponding LRU bit 60 is not updated (item 6).
  • Figures 5 A and 5B illustrate one example of the organization of a cache memory prior to and after temporal instruction hits way 2 of cache set 0.
  • This example corresponds to item 1 of Figure 4.
  • LRU lock bit 70o had been previously cleared for cache set 0, and since the cache set 0 was hit by a temporal instruction, the LRU lock bit 70o is not updated.
  • the LRU bit 60o is updated in accordance with the LRU technique implemented. In the example, it is assumed that the pseudo LRU technique indicates that way 3 is the least recently used entry.
  • Figures 6A and 6B illustrate another example of the organization of a cache memory prior to and after temporal instruction hits way 2 of cache set 0. This example corresponds to item 2 of Figure 4.
  • LRU lock bit 70o had been previously set for cache set 0, indicating that the corresponding set contains non-temporal data. Accordingly, neither the LRU lock bit 70o nor the LRU bit 60o is updated.
  • Figures 7A - 7D illustrate an example of the organization of a cache memory prior to and after a non-temporal instruction hits way 2 of cache set 0.
  • This example corresponds to item 3 of Figure 4 and may be implemented by setting a mode bit located in the LI cache controller to zero (see Figure 4).
  • LRU lock bit 700 had been previously cleared for cache set 0.
  • a non-temporal cache hit does not update the LRU lock bit 70.
  • LRU lock bit 70Q nor the LRU bit 60Q is updated.
  • Figures 7C and 7D LRU lock bit 70o had been previously set for cache set 0, indicating that the corresponding set contains non-temporal data. Accordingly, neither the LRU lock bit 700 nor the LRU bit 60o is updated.
  • Figures 8A - 8D illustrate another example of the organization of a cache memory prior to and after a non-temporal instruction hits way 2 of cache set 0.
  • This example corresponds to item 4 of Figure 4 and may be implemented by setting the mode bit located in the LI cache controller to one (see Figure 4).
  • LRU lock bit 70o had been previously cleared for cache set 0.
  • a non-temporal cache hit updates the LRU lock bit 70. Accordingly, as shown in Figure 8A, since the cache set 0 was hit by a non-temporal instruction, the LRU lock bit 70o is updated (set to 1), as shown in Figure 8B.
  • the LRU bits 60o are updated to indicate the way that was hit. In the case where LRU lock bit 70 ⁇ had been previously set for cache set 0 ( Figures 8C and 8D), the LRU lock bit 70o remains set to 1. In addition, the LRU bits 60o are forced to point to the way within the set that was hit.
  • Figures 9A and 9B illustrate one example of the organization of a cache memory prior to and after a temporal instruction miss to cache set 0.
  • This example corresponds to item 5 of Figure 4.
  • LRU lock bit 70 ⁇ had been previously set for cache set 0, and since there is a miss by a temporal instruction targeting set 0, the LRU lock bit 70 ⁇ is cleared for that set, upon replacing the temporal miss in the cache.
  • the LRU bit 60o is updated in accordance with the LRU technique implemented.
  • the pseudo LRU technique indicates that way 3 is the least recently used entry.
  • Figures 10A - 10B illustrate an example of the organization of a cache memory prior to and after a non-temporal instruction miss to cache set 0. This example corresponds to item 6 of Figure 4.
  • LRU lock bit 70o had been previously cleared for cache set 0. Since there is a non-temporal miss to cache set 0, the LRU lock bit 70o is set and the LRU bits 60o remain the same, in order to point to the non-temporal data in the corresponding set 0.
  • a shared cache structure for managing temporal and non- temporal instructions, which minimizes data pollution in cache or cache hierarchy is provided.
  • Implementation of the present invention also eliminates the use of a separate buffer, making its implementation both cost effective and efficient.

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)
PCT/US1999/006501 1998-03-31 1999-03-24 Shared cache structure for temporal and non-temporal instructions Ceased WO1999050752A1 (en)

Priority Applications (4)

Application Number Priority Date Filing Date Title
JP2000541596A JP4486750B2 (ja) 1998-03-31 1999-03-24 テンポラリ命令及び非テンポラリ命令用の共用キャッシュ構造
BR9909295-6A BR9909295A (pt) 1998-03-31 1999-03-24 Estrutura de cache compartilhado para instruções temporais e não-temporais
EP99915030A EP1066566B1 (en) 1998-03-31 1999-03-24 Shared cache structure for temporal and non-temporal instructions and corresponding method
AU33645/99A AU3364599A (en) 1998-03-31 1999-03-24 Shared cache structure for temporal and non-temporal instructions

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US09/053,386 1998-03-31
US09/053,386 US6202129B1 (en) 1998-03-31 1998-03-31 Shared cache structure for temporal and non-temporal information using indicative bits

Publications (2)

Publication Number Publication Date
WO1999050752A1 true WO1999050752A1 (en) 1999-10-07
WO1999050752A9 WO1999050752A9 (en) 2000-05-25

Family

ID=21983863

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US1999/006501 Ceased WO1999050752A1 (en) 1998-03-31 1999-03-24 Shared cache structure for temporal and non-temporal instructions

Country Status (10)

Country Link
US (2) US6202129B1 (enExample)
EP (1) EP1066566B1 (enExample)
JP (1) JP4486750B2 (enExample)
KR (1) KR100389549B1 (enExample)
CN (1) CN1230750C (enExample)
AU (1) AU3364599A (enExample)
BR (1) BR9909295A (enExample)
RU (1) RU2212704C2 (enExample)
TW (1) TW573252B (enExample)
WO (1) WO1999050752A1 (enExample)

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2002027498A3 (en) * 2000-09-29 2003-01-23 Sun Microsystems Inc System and method for identifying and managing streaming-data
US6584547B2 (en) * 1998-03-31 2003-06-24 Intel Corporation Shared cache structure for temporal and non-temporal instructions
WO2007096572A1 (en) * 2006-02-22 2007-08-30 Arm Limited Cache management within a data processing apparatus
US7512498B2 (en) * 2002-12-31 2009-03-31 Intel Corporation Streaming processing of biological sequence matching
US8078803B2 (en) 2008-01-30 2011-12-13 Qualcomm Incorporated Apparatus and methods to reduce castouts in a multi-level cache hierarchy

Families Citing this family (65)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5978379A (en) 1997-01-23 1999-11-02 Gadzoox Networks, Inc. Fiber channel learning bridge, learning half bridge, and protocol
US6216215B1 (en) 1998-04-02 2001-04-10 Intel Corporation Method and apparatus for senior loads
US6542966B1 (en) * 1998-07-16 2003-04-01 Intel Corporation Method and apparatus for managing temporal and non-temporal data in a single cache structure
US7430171B2 (en) 1998-11-19 2008-09-30 Broadcom Corporation Fibre channel arbitrated loop bufferless switch circuitry to increase bandwidth without significant increase in cost
US6560677B1 (en) * 1999-05-04 2003-05-06 International Business Machines Corporation Methods, cache memories, systems and computer program products for storing transient, normal, and locked entries in an associative cache memory
US6728835B1 (en) * 2000-08-30 2004-04-27 Unisys Corporation Leaky cache mechanism
US6681295B1 (en) * 2000-08-31 2004-01-20 Hewlett-Packard Development Company, L.P. Fast lane prefetching
US6668307B1 (en) * 2000-09-29 2003-12-23 Sun Microsystems, Inc. System and method for a software controlled cache
US6578111B1 (en) * 2000-09-29 2003-06-10 Sun Microsystems, Inc. Cache memory system and method for managing streaming-data
US6598124B1 (en) * 2000-09-29 2003-07-22 Sun Microsystems, Inc. System and method for identifying streaming-data
US6766413B2 (en) * 2001-03-01 2004-07-20 Stratus Technologies Bermuda Ltd. Systems and methods for caching with file-level granularity
US6574708B2 (en) * 2001-05-18 2003-06-03 Broadcom Corporation Source controlled cache allocation
US6766389B2 (en) 2001-05-18 2004-07-20 Broadcom Corporation System on a chip for networking
US7287649B2 (en) * 2001-05-18 2007-10-30 Broadcom Corporation System on a chip for packet processing
US7239636B2 (en) 2001-07-23 2007-07-03 Broadcom Corporation Multiple virtual channels for use in network devices
US6823426B2 (en) * 2001-12-20 2004-11-23 Intel Corporation System and method of data replacement in cache ways
US7328328B2 (en) * 2002-02-19 2008-02-05 Ip-First, Llc Non-temporal memory reference control mechanism
US7295555B2 (en) 2002-03-08 2007-11-13 Broadcom Corporation System and method for identifying upper layer protocol message boundaries
US7114043B2 (en) * 2002-05-15 2006-09-26 Broadcom Corporation Ambiguous virtual channels
US7269709B2 (en) * 2002-05-15 2007-09-11 Broadcom Corporation Memory controller configurable to allow bandwidth/latency tradeoff
US7266587B2 (en) * 2002-05-15 2007-09-04 Broadcom Corporation System having interfaces, switch, and memory bridge for CC-NUMA operation
US7035979B2 (en) * 2002-05-22 2006-04-25 International Business Machines Corporation Method and apparatus for optimizing cache hit ratio in non L1 caches
US7073030B2 (en) 2002-05-22 2006-07-04 International Business Machines Corporation Method and apparatus providing non level one information caching using prefetch to increase a hit ratio
US6904501B1 (en) * 2002-06-17 2005-06-07 Silicon Graphics, Inc. Cache memory for identifying locked and least recently used storage locations
US7934021B2 (en) 2002-08-29 2011-04-26 Broadcom Corporation System and method for network interfacing
US7346701B2 (en) 2002-08-30 2008-03-18 Broadcom Corporation System and method for TCP offload
US8180928B2 (en) 2002-08-30 2012-05-15 Broadcom Corporation Method and system for supporting read operations with CRC for iSCSI and iSCSI chimney
WO2004021626A2 (en) 2002-08-30 2004-03-11 Broadcom Corporation System and method for handling out-of-order frames
US7313623B2 (en) 2002-08-30 2007-12-25 Broadcom Corporation System and method for TCP/IP offload independent of bandwidth delay product
WO2005050455A1 (ja) * 2003-11-18 2005-06-02 Matsushita Electric Industrial Co., Ltd. キャッシュメモリ及びその制御方法
US7321954B2 (en) * 2004-08-11 2008-01-22 International Business Machines Corporation Method for software controllable dynamically lockable cache line replacement system
US20060101208A1 (en) * 2004-11-09 2006-05-11 Intel Corporation Method and apparatus for handling non-temporal memory accesses in a cache
US7356650B1 (en) * 2005-06-17 2008-04-08 Unisys Corporation Cache apparatus and method for accesses lacking locality
US7437510B2 (en) * 2005-09-30 2008-10-14 Intel Corporation Instruction-assisted cache management for efficient use of cache and memory
US7624257B2 (en) * 2005-11-30 2009-11-24 International Business Machines Corporation Digital data processing apparatus having hardware multithreading support including a register set reserved for special class threads
US20070150658A1 (en) * 2005-12-28 2007-06-28 Jaideep Moses Pinning locks in shared cache
US8527713B2 (en) * 2006-01-31 2013-09-03 Qualcomm Incorporated Cache locking without interference from normal allocations
WO2007097028A1 (ja) * 2006-02-27 2007-08-30 Fujitsu Limited Lru制御装置、lru制御方法およびlru制御プログラム
US20080147989A1 (en) * 2006-12-14 2008-06-19 Arm Limited Lockdown control of a multi-way set associative cache memory
US7949834B2 (en) * 2007-01-24 2011-05-24 Qualcomm Incorporated Method and apparatus for setting cache policies in a processor
US7793049B2 (en) * 2007-10-30 2010-09-07 International Business Machines Corporation Mechanism for data cache replacement based on region policies
US8108614B2 (en) * 2007-12-31 2012-01-31 Eric Sprangle Mechanism for effectively caching streaming and non-streaming data patterns
BRPI0822963B1 (pt) * 2008-07-23 2019-10-01 Micro Motion, Inc. Método para executar uma rotina de processamento utilizando uma memória externa e uma memória interna, e, sistema de processamento
US8364898B2 (en) * 2009-01-23 2013-01-29 International Business Machines Corporation Optimizing a cache back invalidation policy
US8312219B2 (en) * 2009-03-02 2012-11-13 International Business Machines Corporation Hybrid caching techniques and garbage collection using hybrid caching techniques
US9063825B1 (en) 2009-09-21 2015-06-23 Tilera Corporation Memory controller load balancing with configurable striping domains
US8560777B2 (en) * 2009-12-16 2013-10-15 Telefonaktiebolaget L M Ericsson (Publ) Method, server, computer program and computer program product for caching
US9323527B2 (en) * 2010-10-15 2016-04-26 International Business Machines Corporation Performance of emerging applications in a virtualized environment using transient instruction streams
EP2761480A4 (en) 2011-09-30 2015-06-24 Intel Corp APPARATUS AND METHOD FOR IMPLEMENTING MULTINIVE MEMORY HIERARCHY ON COMMON MEMORY CHANNELS
CN107391397B (zh) 2011-09-30 2021-07-27 英特尔公司 支持近存储器和远存储器访问的存储器通道
EP2761466B1 (en) 2011-09-30 2020-08-05 Intel Corporation Apparatus and method for implementing a multi-level memory hierarchy
EP2761464B1 (en) 2011-09-30 2018-10-24 Intel Corporation Apparatus and method for implementing a multi-level memory hierarchy having different operating modes
US9122286B2 (en) * 2011-12-01 2015-09-01 Panasonic Intellectual Property Management Co., Ltd. Integrated circuit apparatus, three-dimensional integrated circuit, three-dimensional processor device, and process scheduler, with configuration taking account of heat
US9519549B2 (en) * 2012-01-11 2016-12-13 International Business Machines Corporation Data storage backup with lessened cache pollution
US8856455B2 (en) 2012-03-28 2014-10-07 International Business Machines Corporation Data cache block deallocate requests
US8874852B2 (en) 2012-03-28 2014-10-28 International Business Machines Corporation Data cache block deallocate requests in a multi-level cache hierarchy
CN103577480B (zh) * 2012-08-07 2017-05-31 中国银联股份有限公司 一种参数划分系统及其方法、一种业务处理系统及其方法
US9558121B2 (en) * 2012-12-28 2017-01-31 Intel Corporation Two-level cache locking mechanism
US9256539B2 (en) 2013-03-07 2016-02-09 Lenovo Enterprise Solutions (Singapore) Pte. Ltd. Sharing cache in a computing system
US9311239B2 (en) 2013-03-14 2016-04-12 Intel Corporation Power efficient level one data cache access with pre-validated tags
US20150095586A1 (en) * 2013-09-30 2015-04-02 Advanced Micro Devices , Inc. Storing non-temporal cache data
US11580125B2 (en) * 2015-05-08 2023-02-14 Adp, Inc. Information system with temporal data
US10379827B2 (en) 2016-12-29 2019-08-13 Intel Corporation Automatic identification and generation of non-temporal store and load operations in a dynamic optimization environment
US11681627B1 (en) * 2021-10-18 2023-06-20 Meta Platforms Technologies, Llc Distributed temporal cache for Systems on a Chip
US12072803B1 (en) * 2022-06-30 2024-08-27 Advanced Micro Devices, Inc. Systems and methods for tracking data cache miss requests with data cache tags

Citations (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4905141A (en) * 1988-10-25 1990-02-27 International Business Machines Corporation Partitioned cache memory with partition look-aside table (PLAT) for early partition assignment identification
US5353425A (en) * 1992-04-29 1994-10-04 Sun Microsystems, Inc. Methods and apparatus for implementing a pseudo-LRU cache memory replacement scheme with a locking feature
US5434992A (en) * 1992-09-04 1995-07-18 International Business Machines Corporation Method and means for dynamically partitioning cache into a global and data type subcache hierarchy from a real time reference trace
US5471605A (en) * 1992-08-27 1995-11-28 Intel Corporation Apparatus for updating a multi-way set associative cache memory status array
US5493667A (en) * 1993-02-09 1996-02-20 Intel Corporation Apparatus and method for an instruction cache locking scheme
EP0496439B1 (en) * 1991-01-15 1998-01-21 Koninklijke Philips Electronics N.V. Computer system with multi-buffer data cache and method therefor
US5826052A (en) * 1994-04-29 1998-10-20 Advanced Micro Devices, Inc. Method and apparatus for concurrent access to multiple physical caches
US5829025A (en) * 1996-12-17 1998-10-27 Intel Corporation Computer system and method of allocating cache memories in a multilevel cache hierarchy utilizing a locality hint within an instruction
US5845317A (en) * 1995-11-17 1998-12-01 Micron Technology, Inc. Multi-way cache expansion circuit architecture
US5875465A (en) * 1996-04-03 1999-02-23 Arm Limited Cache control circuit having a pseudo random address generator

Family Cites Families (25)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US549366A (en) * 1895-11-05 Plow-protector
JPS5119453A (en) * 1974-08-08 1976-02-16 Fujitsu Ltd Patsufua memoriseigyohoshiki
JPS5534336A (en) * 1978-08-31 1980-03-10 Fujitsu Ltd Buffer memory control method
JPS58159285A (ja) * 1982-03-17 1983-09-21 Nec Corp バツフアメモリ制御方式
SU1304030A1 (ru) * 1985-06-19 1987-04-15 Войсковая Часть 25840 Устройство дл управлени доступом к пам ти от двух ЦВМ
JPH01133162A (ja) * 1987-11-18 1989-05-25 Fujitsu Ltd キャッシュメモリ制御方式
JPH0358151A (ja) * 1989-07-26 1991-03-13 Nec Corp キャッシュメモリ装置
JPH0358252A (ja) * 1989-07-27 1991-03-13 Nec Corp キャッシュメモリ制御装置
JPH041838A (ja) * 1990-04-18 1992-01-07 Nec Corp キャッシュメモリ制御回路
JPH04215151A (ja) * 1990-12-13 1992-08-05 Nec Commun Syst Ltd キャッシュ制御方式
GB2255211B (en) * 1991-04-25 1995-05-17 Intel Corp LRU pointer updating in a controller for two-way set associative cache
GB2256512B (en) * 1991-06-04 1995-03-15 Intel Corp Second level cache controller unit and system
JPH05165726A (ja) * 1991-12-12 1993-07-02 Nec Corp データ処理装置
JPH05233454A (ja) * 1992-02-24 1993-09-10 Hitachi Ltd キャッシュメモリ装置
JPH06348595A (ja) * 1993-06-07 1994-12-22 Hitachi Ltd キャッシュ装置
JPH07281957A (ja) * 1994-04-15 1995-10-27 Hitachi Ltd キャッシュ記憶装置およびアクセス命令生成方法
JPH07334428A (ja) * 1994-06-14 1995-12-22 Toshiba Corp キャッシュメモリ
US5584014A (en) * 1994-12-20 1996-12-10 Sun Microsystems, Inc. Apparatus and method to preserve data in a set associative memory device
US5701426A (en) * 1995-03-31 1997-12-23 Bull Information Systems Inc. Data processing system and method using cache miss address prediction and forced LRU status in a cache memory to improve cache hit ratio
JPH10207767A (ja) * 1997-01-16 1998-08-07 Toshiba Corp ロック機能付キャッシュメモリ及びこのキャッシュメモリを備えたマイクロプロセッサ
US6434671B2 (en) * 1997-09-30 2002-08-13 Intel Corporation Software-controlled cache memory compartmentalization
US6223258B1 (en) * 1998-03-31 2001-04-24 Intel Corporation Method and apparatus for implementing non-temporal loads
US6105111A (en) * 1998-03-31 2000-08-15 Intel Corporation Method and apparatus for providing a cache management technique
US6205520B1 (en) * 1998-03-31 2001-03-20 Intel Corporation Method and apparatus for implementing non-temporal stores
US6202129B1 (en) * 1998-03-31 2001-03-13 Intel Corporation Shared cache structure for temporal and non-temporal information using indicative bits

Patent Citations (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4905141A (en) * 1988-10-25 1990-02-27 International Business Machines Corporation Partitioned cache memory with partition look-aside table (PLAT) for early partition assignment identification
EP0496439B1 (en) * 1991-01-15 1998-01-21 Koninklijke Philips Electronics N.V. Computer system with multi-buffer data cache and method therefor
US5353425A (en) * 1992-04-29 1994-10-04 Sun Microsystems, Inc. Methods and apparatus for implementing a pseudo-LRU cache memory replacement scheme with a locking feature
US5471605A (en) * 1992-08-27 1995-11-28 Intel Corporation Apparatus for updating a multi-way set associative cache memory status array
US5434992A (en) * 1992-09-04 1995-07-18 International Business Machines Corporation Method and means for dynamically partitioning cache into a global and data type subcache hierarchy from a real time reference trace
US5493667A (en) * 1993-02-09 1996-02-20 Intel Corporation Apparatus and method for an instruction cache locking scheme
US5826052A (en) * 1994-04-29 1998-10-20 Advanced Micro Devices, Inc. Method and apparatus for concurrent access to multiple physical caches
US5845317A (en) * 1995-11-17 1998-12-01 Micron Technology, Inc. Multi-way cache expansion circuit architecture
US5875465A (en) * 1996-04-03 1999-02-23 Arm Limited Cache control circuit having a pseudo random address generator
US5829025A (en) * 1996-12-17 1998-10-27 Intel Corporation Computer system and method of allocating cache memories in a multilevel cache hierarchy utilizing a locality hint within an instruction

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
See also references of EP1066566A4 *

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6584547B2 (en) * 1998-03-31 2003-06-24 Intel Corporation Shared cache structure for temporal and non-temporal instructions
WO2002027498A3 (en) * 2000-09-29 2003-01-23 Sun Microsystems Inc System and method for identifying and managing streaming-data
US7512498B2 (en) * 2002-12-31 2009-03-31 Intel Corporation Streaming processing of biological sequence matching
WO2007096572A1 (en) * 2006-02-22 2007-08-30 Arm Limited Cache management within a data processing apparatus
US8041897B2 (en) 2006-02-22 2011-10-18 Arm Limited Cache management within a data processing apparatus
US8078803B2 (en) 2008-01-30 2011-12-13 Qualcomm Incorporated Apparatus and methods to reduce castouts in a multi-level cache hierarchy
US8386716B2 (en) 2008-01-30 2013-02-26 Qualcomm Incorporated Apparatus and methods to reduce castouts in a multi-level cache hierarchy

Also Published As

Publication number Publication date
AU3364599A (en) 1999-10-18
WO1999050752A9 (en) 2000-05-25
EP1066566A4 (en) 2002-10-23
US6584547B2 (en) 2003-06-24
EP1066566A1 (en) 2001-01-10
US20020007441A1 (en) 2002-01-17
RU2212704C2 (ru) 2003-09-20
CN1230750C (zh) 2005-12-07
TW573252B (en) 2004-01-21
EP1066566B1 (en) 2006-11-02
JP4486750B2 (ja) 2010-06-23
BR9909295A (pt) 2000-12-05
KR100389549B1 (ko) 2003-06-27
KR20010042262A (ko) 2001-05-25
US6202129B1 (en) 2001-03-13
CN1295687A (zh) 2001-05-16
JP2002510085A (ja) 2002-04-02

Similar Documents

Publication Publication Date Title
US6584547B2 (en) Shared cache structure for temporal and non-temporal instructions
US6105111A (en) Method and apparatus for providing a cache management technique
US6138213A (en) Cache including a prefetch way for storing prefetch cache lines and configured to move a prefetched cache line to a non-prefetch way upon access to the prefetched cache line
US6766419B1 (en) Optimization of cache evictions through software hints
US6292871B1 (en) Loading accessed data from a prefetch buffer to a least recently used position in a cache
US8909871B2 (en) Data processing system and method for reducing cache pollution by write stream memory access patterns
US4774654A (en) Apparatus and method for prefetching subblocks from a low speed memory to a high speed memory of a memory hierarchy depending upon state of replacing bit in the low speed memory
US5664147A (en) System and method that progressively prefetches additional lines to a distributed stream buffer as the sequentiality of the memory accessing is demonstrated
US6085291A (en) System and method for selectively controlling fetching and prefetching of data to a processor
US6122715A (en) Method and system for optimizing write combining performance in a shared buffer structure
US6957304B2 (en) Runahead allocation protection (RAP)
KR100339904B1 (ko) 캐시 프로세스용 시스템 및 방법
US7895399B2 (en) Computer system and control method for controlling processor execution of a prefetech command
EP1573555B1 (en) Page descriptors for prefetching and memory management
US7073030B2 (en) Method and apparatus providing non level one information caching using prefetch to increase a hit ratio
EP0763795A1 (en) Stream prefetching buffer with stream filter
US20100217937A1 (en) Data processing apparatus and method
CN1425154A (zh) 高速缓冲存储器线清洗微结构执行方法和系统
WO1998027492A1 (en) Cache hierarchy management with locality hints for different cache levels
CN1093961C (zh) 增强存储器性能的方法及数据处理系统
US6535961B2 (en) Spatial footprint prediction
US5926841A (en) Segment descriptor cache for a processor
US7293141B1 (en) Cache word of interest latency organization
US20030014594A1 (en) Hot way caches: an energy saving technique for high performance caches
JP2024011696A (ja) 演算処理装置及び演算処理方法

Legal Events

Date Code Title Description
WWE Wipo information: entry into national phase

Ref document number: 99804733.3

Country of ref document: CN

AK Designated states

Kind code of ref document: A1

Designated state(s): AE AL AM AT AU AZ BA BB BG BR BY CA CH CN CU CZ DE DK EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MD MG MK MN MW MX NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT UA UG US UZ VN YU ZA ZW

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): GH GM KE LS MW SD SL SZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
AK Designated states

Kind code of ref document: C2

Designated state(s): AE AL AM AT AU AZ BA BB BG BR BY CA CH CN CU CZ DE DK EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MD MG MK MN MW MX NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT UA UG US UZ VN YU ZA ZW

AL Designated countries for regional patents

Kind code of ref document: C2

Designated state(s): GH GM KE LS MW SD SL SZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG

COP Corrected version of pamphlet

Free format text: PAGES 1/12-12/12, DRAWINGS, REPLACED BY NEW PAGES 1/13-13/13; DUE TO LATE TRANSMITTAL BY THE RECEIVING OFFICE

WWE Wipo information: entry into national phase

Ref document number: IN/PCT/2000/00382/MU

Country of ref document: IN

WWE Wipo information: entry into national phase

Ref document number: 1020007010799

Country of ref document: KR

ENP Entry into the national phase

Ref document number: 2000 541596

Country of ref document: JP

Kind code of ref document: A

WWE Wipo information: entry into national phase

Ref document number: 1999915030

Country of ref document: EP

WWP Wipo information: published in national office

Ref document number: 1999915030

Country of ref document: EP

REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

WWP Wipo information: published in national office

Ref document number: 1020007010799

Country of ref document: KR

WWG Wipo information: grant in national office

Ref document number: 1020007010799

Country of ref document: KR

WWG Wipo information: grant in national office

Ref document number: 1999915030

Country of ref document: EP