This disclosure relates generally to the field of microprocessors. In particular, the disclosure relates to efficiently implementing MONITOR and MWAIT instructions in a distributed cache architecture.
Modern high-performance microprocessors can have a number of execution cores and multiple levels of cache storage. Thus there is an ever increasing demand for higher interconnect bandwidth between these components. One technique to provide such higher interconnect bandwidths involves distributed cache partitioning with parallel access to multiple portions of the distributed cache through a shared interconnect.
Another aspect of some modern high-performance microprocessors includes multithreaded software and hardware, and thread synchronization through shared memory. An example of two instructions to provide thread synchronization through shared memory would be the MONITOR and the MWAIT instructions of Intel Corporation's SSE3 instruction set. MONITOR defines an address range used to monitor write-back stores. MWAIT is used to indicate that an execution thread is waiting for data to be written to the address range defined by the MONITOR instruction. The thread can then transition into a low power state and wait to be notified by a monitor-wake event when data is written to the monitored address range.
When the two above mentioned techniques are used in combination with each other, additional challenges present themselves. For example, centralized tracking of all monitor requests for all of the active execution threads while permitting parallel access to multiple portions of the distributed cache may introduce bottlenecks and adversely impact the performance of distributed cache access through the shared interconnect. To date, efficient techniques for implementing thread synchronization through MONITOR and MWAIT instructions in a distributed cache architecture have not been fully explored.
The present invention is illustrated by way of example and not limitation in the figures of the accompanying drawings.
Methods and apparatus for MONITOR and MWAIT in a distributed cache architecture are herein disclosed. One embodiment includes an execution thread sending a MONITOR request for an address via a communication interconnect to a portion of a distributed cache that stores data corresponding to that address. At the distributed cache portion the MONITOR request and an associated speculative state is recorded locally for that execution thread. The execution thread then issues an MWAIT instruction for the address. At the distributed cache portion the MWAIT and an associated wait-to-trigger state are then recorded for the execution thread. When a write request matching the address is received at the distributed cache portion, a monitor-wake event is then sent to the execution thread. The associated monitor state at the distributed cache portion for that execution thread may then be reset or cleared to idle.
These and other embodiments of the present invention may be realized in accordance with the following teachings and it should be evident that various modifications and changes may be made in the following teachings without departing from the broader spirit and scope of the invention. The specification and drawings are, accordingly, to be regarded in an illustrative rather than restrictive sense and the invention measured only in terms of the claims and their equivalents.
It will be appreciated that address ranges may be divided in a distributed cache system according to a variety of algorithms. A single central MONITOR tracking agent could be inefficient and become a performance bottleneck. On the other hand, a distributed tracking mechanism may present a potential for false monitor-wake events, stale addresses being monitored, and other potential performance issues. For example, when an execution thread sends a sequence of MONITOR requests, the most recent MONITOR request could be directed to a different distributed cache portion than some previous requests, which presents a potential for stale addresses being monitored and false monitor-wake events. Requiring, in such a distributed tracking system, that old MONITOR requests be cleared by the execution thread before issuing new requests could potentially slow processing and introduce new race conditions.
A three-state machine as will be described in detail below with regard to
Computing system 101 further comprises a shared interconnect 110 and execution cores 120-150. Execution cores 120-150 and distributed cache portions 160-190 may include communication egress queues 121-151 and 161-191 and communication ingress queues 122-152 and 162-192, respectively, to send and receive requests, data, instructions, acknowledgements and other communications via shared interconnect 110.
One of execution cores 120-150 may send a MONITOR request for an address from a particular execution thread via shared interconnect 110. The MONITOR request will be routed to one of the distributed cache portions 160-190, that one of the distributed cache portions 160-190 being the particular cache portion supposed to store data corresponding to the monitored address. The cache portion receiving the MONITOR request can record the requested address to monitor and record an associated speculative state in local state storage for the requesting execution thread.
Execution cores 120-150 may also include local storage, 123-153, respectively, to store the last monitored addresses for each execution thread. When the execution thread issues an MWAIT instruction, the last monitored addresses for that execution thread may be provided by the execution core to shared interconnect 110 so that the MWAIT request can be routed to the same cache portion supposed to store data corresponding to the monitored address. The cache portion receiving the MWAIT request can then record the MWAIT for the execution thread and an associated wait-to-trigger state in local state storage for the requesting execution thread. That cache portion may also acknowledge the MWAIT by sending an acknowledgement back to the execution thread.
When the cache portion receives a write request matching the monitored address it can send a monitor-wake event to the execution thread at its execution core, at which point it may optionally record an associated idle state in local state storage for the requesting execution thread.
It will be appreciate that many different connection topologies may be suitable for shared interconnect 110, execution cores 120-150 and distributed cache portions 160-190. In one embodiment, a ring topology may be used. In alternative embodiments a mesh, or a crossbar or a hypercube or some hybrid combination of these or other topologies may be used.
In some embodiments of the distributed cache architecture to perform thread synchronization through MONITOR and MWAIT instructions, the last level of caches are partitioned into distributed cache slices to function as described above with regard to distributed cache portions 160-190 and can be accessed in parallel through shared interconnect 110. In some alternative embodiments, the write request may be received at the cache portion in the form of a relayed request from another cache portion or level. For example, the cache portion may receive the write request as a read for ownership request or as a state transition associated with the monitored address, changing from a shared state to an exclusive state. It will be appreciated that these are just alternative forms in which the write request may be received at the cache portion.
In processing block 211 a MONITOR request for an address is sent from an execution thread out of multiple execution threads to one of the distributed cache portions, that one of the distributed cache portions being the particular cache portion supposed to store data corresponding to the monitored address. In processing block 212 the address may be recorded for that thread as its last monitored address. At the cache portion, in processing block 213 the MONITOR request is recorded for the execution thread. In processing block 214 a speculative state is associated with the cache portion's monitor finite-state machine for that thread. The cache portion may receive a monitor clear request from the execution thread while the monitor finite-state machine is in a speculative state, in which case the recorded MONITOR request for the execution thread may then be erased. Further details of such conditions are discussed below with regard to
In processing block 215 an MWAIT instruction is issued from the execution thread for the address. At the cache portion, in processing block 216 the MWAIT is recorded for the execution thread. In processing block 217 a wait-to-trigger state is associated with the cache portion's monitor finite-state machine for that thread and an acknowledgement of the MWAIT may also be sent back to the thread.
In processing block 218 a write request is received at the cache portion and it is determined that the write request received matches the monitored address. Finally in processing block 219 a monitor-wake event is sent to the execution thread an idle state is associated with the cache portion's monitor finite-state machine for that thread.
It will be appreciated that multiple embodiments of process 201 may be performed concurrently in a distributed fashion by a distributed cache architecture in any one or more cache portions for any or all of the concurrent execution threads in the system. In any distributed cache system, since addresses and the corresponding data must necessarily be associated with each other, there must exist a system for routing read and write requests to the correct distributed cache portions according to the requested address. That same system may also be used to route MONITOR requests and MWAIT requests.
If the cache portion receives a write request matching the address or a monitor clear request from the execution thread while monitor finite-state machine 301 is in speculative state 330, finite-state machine 301 makes transition 331 back to the state 310. If the cache portion receives another MONITOR request from that same execution thread, monitor finite-state machine 301 makes transition 333 returning to speculative state 330 and may also adjust the monitored address as necessary. On the other hand, if the cache portion receives an MWAIT request from that execution thread, monitor finite-state machine 301 makes transition 332 to wait-to-trigger state 320. It will be appreciated that the cache portion may also acknowledge the MWAIT by sending an acknowledgement back to the execution thread.
It will be appreciated that speculative state 330 ensures that monitor-wake events are sent only for the last monitored address, while tracking addresses from the time a MONITOR request is received, even before receiving an MWAIT request.
If the cache portion receives a write request matching the monitored address while monitor finite-state machine 301 is in wait-to-trigger state 320, a monitor-wake event is sent to the execution thread. On the other hand, the cache portion may receive a monitor clear request from the execution thread while monitor finite-state machine 301 is in wait-to-trigger state 320. In such a case the MONITOR request may be erased for that execution thread and no monitor-wake event needs to be sent to the execution thread, but in either of these two cases, monitor finite-state machine 301 may make transition 321 back to the idle state 310.
It will be appreciated that in some embodiments the addresses being monitored and recorded at the cache portion can also be used to prevent the data corresponding to said addresses from being evicted from the cache portion in order to further improve the performance of thread synchronization. In alternative embodiments, the addresses being monitored and the associated speculative states or wait-to-trigger states recorded at the cache portion can be retained and tracked even after data corresponding to said addresses is evicted from the cache portion.
The above description is intended to illustrate preferred embodiments of the present invention. From the discussion above it should also be apparent that especially in such an area of technology, where growth is fast and further advancements are not easily foreseen, the invention can may be modified in arrangement and detail by those skilled in the art without departing from the principles of the present invention within the scope of the accompanying claims and their equivalents.