Cache prefetching is a technique used by computer systems and processors to improve execution performance by fetching instructions or data from their original storage in slower memory to a faster local memory before it is actually needed. Hardware based prefetching can include a dedicated hardware mechanism, such as a prefetcher, in the processor that monitors the stream of instructions or data being requested by the executing program, recognizes the next few elements that the program might need based on this stream, and prefetches the data into the processor's cache.
Conventional methods of prefetching utilize a pull-based prefetcher for issuing prefetch requests, where the issued prefetch request is propagated down the memory hierarchy through each cache level to the memory level where the data resides, before prefetching the data all the way back up to the level where the request was issued. Such methods for prefetching can exhibit poor prefetcher timeliness and coverage.
The present specification sets forth various implementations of systems, apparatus, and methods for pushed prefetching in a memory hierarchy. The present specification describes a system and apparatus embodiments for pushed prefetching in a memory hierarchy that includes multiple core complexes, where each core complex includes multiple cores and multiple caches. The caches are configured in a memory hierarchy with multiple levels. An interconnect device coupling the core complexes to each other and coupling the core complexes to shared memory is also included. The shared memory is at a lower level of the memory hierarchy than the caches and each core complex includes a push-based prefetcher. In some implementations, the push-based prefetcher is separate from the plurality of core complexes. The push-based prefetcher comprises logic to monitor memory traffic between caches of a first or selected level of the memory hierarchy and the shared memory. Based on the monitoring, the push-based prefetcher initiates a prefetch of data to a cache of the first level of the memory hierarchy.
In some implementations, the caches of the first level are L3 caches of the core complexes. In some implementations, the push-based prefetcher further comprises logic to send a resource acquisition request to the cache of the first level of the memory hierarchy and receive an acknowledgement of resource acquisition including a tag based on the resource acquisition request. Additionally, the push-based prefetcher acquires data from a data source in the memory hierarchy and, only after receiving the acknowledgement, sends the acquired data and the tag to a data target in the cache of the first level of the memory hierarchy. In some implementations, sending the resource acquisition request occurs in parallel with acquiring the data from the data source.
In some implementations, the push-based prefetcher further comprises logic to send a resource acquisition request to the cache of the first level of the memory hierarchy and receive a negative-acknowledgement of resource acquisition, where the negative-acknowledgement includes a tag. In such implementations, the push-based prefetcher drops the prefetch only after receiving the negative-acknowledgement.
In some implementations, the push-based prefetcher further comprises logic to send a resource acquisition request to the cache of the first level of the memory hierarchy and acquire data from a data source in the memory hierarchy. Responsive to acquiring the data from the data source and if an acknowledgment of the resource acquisition request has been received including a tag, the push-based prefetcher sends the acquired data and the tag to a data target in the cache of the first level of the memory hierarchy. If an acknowledgement of the resource acquisition request has not been received, the push-based prefetcher drops the prefetch independent of receiving a negative-acknowledgement.
In some implementations, the push-based prefetcher further comprises logic to determine, from a memory directory for the data, that a source of the data is at a lower level than the cache of the first level and acquire the data from the source of the data. In some implementations, the push-based prefetcher further comprises logic to determine, from a memory directory for the data, that a source of the data is at any level within another core complex separate from the cache of the first level and acquire the data from the source of the data. In some implementations, the push-based prefetcher further comprises logic to determine, from a memory directory for the data, that the data is already at the cache of the first level and determine not to prefetch the data.
In some implementations, the system or apparatus for pushed prefetching in a memory hierarchy further includes a cache controller of the cache of the first level. The cache controller includes logic configured to throttle responses to resource acquisition requests sent from the push-based prefetcher based on prefetcher statistics. In some aspects, the cache controller sends a negative-acknowledgement to the push-based prefetcher based on the prefetcher statistics independent of availability of resources for the push-based prefetcher.
In some implementations, the system or apparatus for pushed prefetching in a memory hierarchy further includes a cache controller of the cache of the first level. The cache controller comprises logic configured to send, to the push-based prefetcher, throttling signals based on prefetcher statistics. The push-based prefetcher throttles the sending of resource acquisition requests based on the throttling signals.
The present specification also describes a method of pushed prefetching in a memory hierarchy that includes monitoring memory traffic between caches of a first level of a memory hierarchy and a second, lower level of a memory hierarchy. Such method also includes initiating a prefetch of data to a cache of the first level of the memory hierarchy based on the monitoring.
In some implementations, the caches of the first level are L2 caches in a core complex, and the second, lower level is a shared L3 cache in the core complex. In some implementations, the caches of the first level are L3 caches of multiple core complexes, and the second, lower level is memory shared by the core complexes.
In some implementations, the method further includes sending a resource acquisition request to the cache of the first level of the memory hierarchy and receiving, based on the resource acquisition request, an acknowledgement of resource acquisition including a tag. The method also includes acquiring data from a data source in the memory hierarchy and, only after receiving the acknowledgement, sending the acquired data and the tag to a data target in the cache of the first level of the memory hierarchy. In some implementations, sending the resource acquisition request occurs in parallel with acquiring the data from the data source.
In some implementations, the method also includes sending a resource acquisition request to the cache of the first level of the memory hierarchy and receiving, based on the resource acquisition request, a negative-acknowledgement of resource acquisition including a tag. The method also includes dropping the prefetch responsive to the negative-acknowledgement.
In some implementations, the method further includes sending a resource acquisition request to the cache of the first level of the memory hierarchy and acquiring data from a data source in the memory hierarchy. Responsive to acquiring the data from the data source and if an acknowledgment of the resource acquisition request has been received including a tag, the method includes sending the acquired data and the tag to a data target in the cache of the first level of the memory hierarchy. If an acknowledgement of the resource acquisition request has not been received, the method includes dropping the prefetch independent of receiving a negative-acknowledgement.
The present specification also describes an apparatus comprising multiple cores and multiple caches configured in a memory hierarchy with multiple levels, where the one or more of the caches is shared by the cores. The apparatus also includes a push-based prefetcher comprising logic to monitor memory traffic between caches of a first level of the memory hierarchy and a shared cache of a second, lower level of the memory hierarchy. The push-based prefetcher also initiates, based on the monitoring, a prefetch of data to a cache of the first level of the memory hierarchy.
Pushed prefetching in accordance with the present disclosure is generally implemented with computers, that is, with computing systems. Implementations in accordance with the present disclosure may, in some conditions, result in computers that operate with greater speed and/or lower latency of processing—features which are highly desirable in many computing arrangements. Examples of computers that may implement embodiments of present disclosure include servers, laptops, portable devices (e.g., mobile phone, handheld game consoles, etc.), game consoles, embedded computing devices and the like. For further explanation, therefore,
The example processor core complexes 101a and 101b each include multiple processor cores (102a, 102b), multiple L2 caches (104a, 104b), and a shared L3 cache (106a, 106b, shared amongst the cores 102a, 102b of the respective core complex—e.g., L3 cache 106a is shared amongst cores 102a of core complex 101a). The example core complexes also include other computer components, hardware, software, firmware, and the like not shown here. For example, each of the cores within each core complex includes an L1 cache (not shown in
The example interconnect 108 of
In the example system 100 of
In some implementations, the push-based prefetcher 110 is also configured to initiate a prefetch of data to a cache of the first level of the memory hierarchy based on the monitoring of the memory traffic. In some implementations, initiating a prefetch to a cache of the first level of the memory hierarchy is carried out by the push-based prefetcher 110 requesting, in a prefetch request, to send data to the cache of the first level of the memory hierarchy. In some implementations, in the example system 100 of
In some implementations, initiating a prefetch of data to a cache of the first level of the memory hierarchy includes sending a resource acquisition request to the cache. The resource acquisition request is sent by the push-based prefetcher to the cache of the first level and includes a request to send data to the cache. The push-based prefetcher, in initiating a prefetch of data to a cache of the first level of the memory hierarchy, can receive, based on the resource acquisition request, an acknowledgement of resource acquisition including a tag. The acknowledgement of resource acquisition is received by the push-based prefetcher from the cache in response to sending the resource acquisition request to the cache. In some implementations, the acknowledgement of resource acquisition is received from a cache controller (not shown in
In some implementations, initiating, by the push-based prefetcher 110, a prefetch of data to a cache of the first level of the memory hierarchy also includes acquiring data from a data source in the memory hierarchy. Acquiring data from a data source in the memory hierarchy is carried out by the push-based prefetcher by determining which data source in the memory hierarchy from which to retrieve the data to prefetch for the cache of the first level, and subsequently retrieving such data from the determined data source and, ultimately, transmitting to the cache of the first level. Continuing with the above example, in the system 100 of
In some implementations, acquiring data from a data source in the memory hierarchy includes referencing a memory directory 114. In the system 100 of
In acquiring data from a data source in the memory hierarchy, the push-based prefetcher 110 can reference the memory directory 114 to determine the data source in the memory hierarchy that includes the data to be acquired. In some implementations, the data source is determined, by logic within the push-based prefetcher, to be within the shared memory 112, within another core complex, or within the cache of the first level of the memory hierarchy. If the data source is determined to be the cache of the first level, where the cache already has the data, the push-based prefetcher determines not to prefetch or determines to drop the prefetch. If the data source is determined to be the shared memory 112, or any other level of the memory hierarchy lower than the cache of the first level, the push-based prefetcher acquires the data from that data source. If the data source is determined to be, according to the memory directory 114, within a core complex other than the core complex of the cache of the first level, the push-based prefetcher acquires the data from that data source, independent of which level of the memory hierarchy the data source resides.
In some implementations, the push-based prefetcher 110, in prefetching data to a cache of the first level of the memory hierarchy, is configured to send the acquired data and the tag to a data target in the cache of the first level of the memory hierarchy. Sending the acquired data and the tag to a data target in the cache of the first level of the memory hierarchy is carried out by the push-based prefetcher 110 transmitting a resource acquisition request (a request by prefetcher 110 to send data to the cache of the first level of the memory hierarchy.) Only after prefetcher 110 receives an acknowledgement from the cache (or logic related to the cache—e.g., a cache controller) to the resource acquisition request, since the cache must first allocate resources (a specific MSHR) for receiving the prefetch data from the push-based prefetcher, does prefetcher 110 transmit the acquired data and tag to the data target in the cache. Accordingly, and continuing with the above example, in the system 100 of
In some implementations, in initiating a prefetch of data to a cache of the first level of the memory hierarchy, the push-based prefetcher 110 can receive, based on a resource acquisition request, a negative-acknowledgement of resource acquisition. The negative-acknowledgement of resource acquisition is received by the push-based prefetcher from the cache in response to sending the resource acquisition request to the cache. In some implementations, the negative-acknowledgement of resource acquisition is received from a cache controller (not shown in
In some implementations, the push-based prefetcher is configured to drop the prefetch only in response to receiving a negative-acknowledgement of resource acquisition. In such an implementation, the push-based prefetcher waits until a response to the resource acquisition request is received before either sending the acquired data or dropping the prefetch. That is, the push-based prefetcher drops the prefetch upon expiration of a predefined period of time. In such implementations, a response might not be received for a significant amount of time, if at all, and could thereby waste computing resources that could instead be used for other prefetch requests.
In other implementations, the push-based prefetcher waits for a response only for the amount of time required to acquire the data for prefetching. In such implementations, the push-based prefetcher is configured to, responsive to acquiring the data from the data source, determine whether an acknowledgment of the resource acquisition in response to the request has been received including a tag. If an acknowledgment of resource acquisition has been received including a tag, the push-based prefetcher sends the acquired data and the tag to a data target in the cache of the first level of the memory hierarchy. If an acknowledgement of the resource acquisition request has not been received by the time the data has been acquired by the prefetcher, then the push-based prefetcher drops the prefetch, independent of whether a negative-acknowledgement has been received. In waiting for a response to the resource acquisition request only for the amount of time required to acquire the data for prefetching the push-based prefetcher can prevent long wait times that waste resources.
In such implementations where the push-based prefetcher drops the prefetch before receiving a response from the cache, the push-based prefetcher can receive a response to the resource acquisition request after already dropping the prefetch. In such an example, the push-based prefetcher ignores the response from the cache. In such an example, where the cache controller sends an acknowledgement of resource acquisition after the prefetch has already been dropped by the push-based prefetcher, the cache has allocated resources (such as an MSHR) for a prefetch request for data that will not be received (as the prefetcher has dropped the prefetch). In such an example, the cache, or cache controller of the cache, is configured to wait for the prefetch data for a predetermined amount of time before releasing the allocated resources. Releasing the allocated resources may include de-allocating, by the cache controller, the MSHR when the predetermined amount of time elapses. In some implementations, the cache, or cache controller of the cache, is configured to keep a timestamp associated with an MSHR ID included within the response sent to the push-based prefetcher.
For further explanation,
In the example system 200 of
In some implementations, the push-based prefetcher 210 is also configured to, based on the monitoring of the memory traffic, initiate a prefetch of data to a cache of the first level of the memory hierarchy. In some implementations, initiating a prefetch of data to a cache of the first level of the memory hierarchy is carried out by the push-based prefetcher 210 requesting, in a prefetch request, to send data to the cache of the first level of the memory hierarchy. In the example system 200 of
In some implementations, initiating a prefetch of data to a cache of the first level of the memory hierarchy includes sending a resource acquisition request to the cache. In some implementations, the resource acquisition request is sent by the push-based prefetcher to the cache of the first level and includes a request to send data to the cache. In some implementations, in initiating a prefetch of data to a cache of the first level of the memory hierarchy, the push-based prefetcher receives, based on the resource acquisition request, an acknowledgement of resource acquisition including a tag. In some implementations, the acknowledgement of resource acquisition is received by the push-based prefetcher from the cache in response to sending the resource acquisition request to the cache. In some implementations, the acknowledgement of resource acquisition is received from a cache controller (not shown in
In some implementations, initiating, by the push-based prefetcher 210, a prefetch of data to a cache of the first level of the memory hierarchy also includes acquiring data from a data source in the memory hierarchy. Acquiring data from a data source in the memory hierarchy is carried out by the push-based prefetcher determining which data source in the memory hierarchy to retrieve the data to prefetch to the cache of the first level, and subsequently retrieving such data from the determined data source. Continuing with the above example, in the system 200 of
In some implementations, acquiring data from a data source in the memory hierarchy includes referencing a memory directory 214. In the system 200 of
In some implementations, the push-based prefetcher 210, in prefetching data to a cache of the first level of the memory hierarchy, is configured to send the acquired data and the tag to a data target in the cache of the first level of the memory hierarchy. Sending the acquired data and the tag to a data target in the cache of the first level of the memory hierarchy is carried out by the push-based prefetcher 210 only after receiving the acknowledgement from the cache, since the cache must first allocate resources (a specific MSHR) for receiving the prefetch data from the push-based prefetcher. Continuing with the above example, in the system 200 of
In some implementations, in initiating a prefetch of data to a cache of the first level of the memory hierarchy, the push-based prefetcher 210 receives, based on the resource acquisition request, a negative-acknowledgement of resource acquisition. The negative-acknowledgement of resource acquisition is received by the push-based prefetcher from the cache in response to sending the resource acquisition request to the cache. In some implementations, the negative-acknowledgement of resource acquisition is received from a cache controller (not shown in
In some implementations, the push-based prefetcher is configured to drop the prefetch only in response to receiving a negative-acknowledgement of resource acquisition. In such an implementation, the push-based prefetcher waits until a response to the resource acquisition request is received before either sending the acquired data or dropping the prefetch. In such implementations, a response might not be received for a significant amount of time, if at all, and could thereby waste computing resources that could instead be used for other prefetch requests.
In other implementations, the push-based prefetcher waits for a response only for the amount of time required to acquire the data for prefetching. In such implementations, the push-based prefetcher is configured to, responsive to acquiring the data from the data source, determine whether an acknowledgment of the resource acquisition in response to the request has been received including a tag. If an acknowledgment of resource acquisition has been received including a tag, the push-based prefetcher sends the acquired data and the tag to a data target in the cache of the first level of the memory hierarchy. If an acknowledgement of the resource acquisition request has not been received by the time the data has been acquired, the push-based prefetcher drops the prefetch, independent of whether a negative-acknowledgement has been received. In waiting for a response to the resource acquisition request only for the amount of time required to acquire the data for prefetching, the push-based prefetcher can prevent long wait times that waste resources.
In such implementations where the push-based prefetcher drops the prefetch before receiving a response from the cache, the push-based prefetcher can receive a response to the resource acquisition request after already dropping the prefetch. In such an example, the push-based prefetcher ignores the response from the cache. In such an example, where the cache controller sends an acknowledgement of resource acquisition after the prefetch has already been dropped by the push-based prefetcher, the cache has allocated resources (such as an MSHR) for a prefetch request for data that will not be received. In such an example, the cache, or cache controller of the cache, is configured to wait for the prefetch data for a predetermined amount of time before releasing the allocated resources. In some implementations, the cache, or cache controller of the cache, is configured to keep a timestamp associated with an MSHR ID included within the response sent to the push-based prefetcher.
For further explanation,
The method of
The method of
For further explanation,
The method of
The method of
In throttling or adjusting 404 responses to resource acquisition requests based on the prefetcher statistics, the cache controller can deny resource acquisition requests from the push-based prefetcher based on one or more of prefetcher coverage, prefetcher accuracy, and prefetcher timeliness (or other metrics). Such throttling or adjusting 404 of resource acquisition request responses by the cache can reduce unnecessary use of system resources and increase system performance and efficiency.
For further explanation,
The method of
The method of
In adjusting or throttling 506 the sending of resource acquisition requests based on the throttling signals, the cache controller can adjust the aggressiveness of the push-based prefetcher by controlling the amount of resource acquisition requests to be sent from the push-based prefetcher based on one or more of determined prefetcher coverage, prefetcher accuracy, and prefetcher timeliness. Such throttling 506 can reduce unnecessary use of system resources and increase system performance and efficiency.
In view of the explanations set forth above, persons of ordinary skill in the art will recognize that pushed prefetching according to the various implementations of the present disclosure allows for improved prefetcher timeliness. In conventional methods of prefetching, using a pull-based prefetcher, an issued prefetch request targeting a particular level of the memory hierarchy must be propagated down the levels of each cache, starting from the particular level at which the prefetch was issued down to the memory level of the data source before then prefetching the data all the way back up to the particular level. In some implementations, pushed prefetching in accordance with the present disclosure includes a push-based prefetcher that is instead configured to issue the prefetch directly from the memory level of the data source.
In view of the explanations set forth above, persons of ordinary skill in the art will recognize that pushed prefetching according to the various implementations of the present disclosure also allows for improved prefetcher coverage. According to some implementations of the present disclosure, the push-based prefetcher is configured to push prefetch data to a memory level that is higher than the memory level from which the prefetch request was issued, which is in contrast to conventional methods of prefetching, using a pull-based prefetcher, which can only pull data up to the memory level which issued the prefetch request. Readers will recognize that pushed prefetching according to the various implementations of the present disclosure also allows for improved prefetcher training by configuring the prefetcher to monitor additional memory traffic compared with a conventional pull-based prefetcher.
It will be understood from the foregoing description that modifications and changes can be made in various implementations of the present disclosure. The descriptions in this specification are for purposes of illustration only and are not to be construed in a limiting sense. The scope of the present disclosure is limited only by the language of the following claims.