The disclosed embodiments are generally directed to nested speculative regions, and in particular, to nested speculative regions for a synchronization facility.
Many modern computers have multiple processors or cores that share memory. One challenge with multiple processors is how to permit the multiple processors to share memory.
A synchronization facility allows modification of multiple memory locations (often called a “working set”) by a single region of instructions (often called a “speculative region”) executed by a single processor. The synchronization facility allows a speculative region to access the working set of memory locations, while watching the working set to detect accesses from other speculative regions being executed by other processors.
If another processor accesses a memory location of the working set, then the synchronization facility determines that there is a conflict and aborts one of the speculative regions. This enables the cores to share the memory without interfering with one another.
Therefore, there is a need in the art for an apparatus and method of performing nested speculative regions for a synchronization facility.
Some embodiments provide a method of performing nested speculative regions. The method includes responding to entering a speculative region by storing link information to an abort handler and responding to a commit command by removing link information from the abort handler. The method may include storing link information to the abort handler associated with the speculative region. When the speculative region is nested, the method may include storing link information to an abort handler associated with a previous speculative region. Removing link information may include removing link information from the abort handler associated with the corresponding speculative region. The method may include restoring link information to the abort handler associated with a previous speculative region. Responding to an abort command may include running the abort handler associated with the aborted speculative region. The method may include running the abort handler of each previous speculative region.
Some embodiments provide an apparatus for performing nested speculative regions. The apparatus includes two or more processors where each processor may include an instruction pointer (IP) register, a stack pointer (SP) register, a saved_rIP register, and a saved_rSP register. The apparatus may include a memory comprising memory locations. Each processor of the two or more processors may be configured to respond to entering a speculative region by storing link information to an abort handler associated with the speculative region, and if the speculative region is nested, then storing link information to an abort handler associated with a previous speculative region. Each processor of the two or more processors may respond to a commit command by removing link information to the abort handler associated with the corresponding speculative region, and if the commit is nested, then restoring link information to the abort handler associated with the previous speculative region. Each processor of the two or more processors may respond to an abort command by running the abort handler associated with the aborted speculative region, and if the aborted speculative region is nested, then for each previous speculative region, running the abort handler of the previous speculative region.
A more detailed understanding may be had from the following description, given by way of example in conjunction with the accompanying drawings wherein:
The processor 102 may include a central processing unit (CPU), a graphics processing unit (GPU), a CPU and GPU located on the same die, or one or more processor cores, wherein each processor core may be a CPU or a GPU. The CPU may include a synchronization facility for synchronizing memory access among multiple processors. The memory 104 may be located on the same die as the processor 102, or may be located separately from the processor 102. The memory 104 may include a volatile or non-volatile memory, for example, random access memory (RAM), dynamic RAM, or a cache. The memory 104 may include a synchronization facility.
The storage 106 may include a fixed or removable storage, for example, a hard disk drive, a solid state drive, an optical disk, or a flash drive. The input devices 108 may include a keyboard, a keypad, a touch screen, a touch pad, a detector, a microphone, an accelerometer, a gyroscope, a biometric scanner, or a network connection (e.g., a wireless local area network card for transmission and/or reception of wireless IEEE 802 signals). The output devices 110 may include a display, a speaker, a printer, a haptic feedback device, one or more lights, an antenna, or a network connection (e.g., a wireless local area network card for transmission and/or reception of wireless IEEE 802 signals).
The input driver 112 communicates with the processor 102 and the input devices 108, and permits the processor 102 to receive input from the input devices 108. The output driver 114 communicates with the processor 102 and the output devices 110, and permits the processor 102 to send output to the output devices 110. It is noted that the input driver 112 and the output driver 114 are optional components, and that the device 100 will operate in the same manner if the input driver 112 and the output driver 114 are not present.
The method 300 may begin with in response to beginning a speculative region 304. For example,
The method 300 may continue with in response to beginning a speculative region 304. For example, routine A 200.1 may continue with call Routine B 202.1. Routine B 210.1 is called and routine B begins with speculate 211.1.
The method 300 continues with is speculative region nested 306. In this case, speculate 211.1 is nested because it was called by routine A 200.1, which was inside a speculative region begun with speculate 201.1, so the method 300 continues with store link information to the abort handler associated with the previous speculative region 308. For example, a link may be stored from abort handler 214.1 to abort handler 204.1.
The method 300 continues with store link information to the abort handler associated with the speculative region 310. For example, a link to the abort handler 214.1 may be stored when entering speculate 211.1. The method 300 then returns to start 302.
The method 300 may continue with in response to a commit command 320. For example, routine B 210.1 may continue with commit 213.1. The method 300 may continue with is commit nested 322. In this case the commit 213.1 is nested, so the method 300 continues with restore link information to the abort handler associated with the previous speculative region 324. Here, the link information to abort handler 204.1 is restored. The method 300 may continue with removing link information to the abort handler associated with the speculative region 326. For example, link information to abort handler 214.1 may be removed.
The method 300 may continue with in response to beginning a speculative region 304. For example, routine B 210.1 may have completed and returned control to routine A 201.1. Routine A may next perform call routine C 202.2. Routine C 210.2 then performs speculate 211.2. The method 300 continues with is speculative region nested 306. In this case, speculate 211.2 is nested because it was called by routine A 200.1, which was inside a speculative region begun with speculate 201.1, so the method 300 continues with store link information to the abort handler associated with the previous speculative region 308. For example, a link may be stored from abort handler 214.2 to abort handler 204.1.
The method 300 may continue with store link information to the abort handler associated with speculative region 310. For example, link information may be stored abort handler 214.2. The method 300 then returns to start 302.
The method 300 may continue with in response to beginning a speculative region 304. For example, routine C 210.2 may continue with call Routine D 212.1. Routine D 212.1 is called and routine D begins with speculate 221.1. The method 300 continues with is speculative region nested 306. In this case, speculate 221.1 is nested because it was called by routine C 210.2, which was inside a speculative region begun with speculate 211.2, so the method 300 continues with store link information to the abort handler associated with the previous speculative region 308. For example, a link may be stored from abort handler 224.1 to abort handler 214.2.
The method 300 continues with store link information to the abort handler associated with the speculative region 310. For example, a link to the abort handler 224.1 may be stored when entering speculate 221.1. The method 300 then returns to start 302.
The method 300 may continue with in response to a commit command 320. For example, routine D 220.1 may continue with commit 223.1. The method 300 may continue with is commit nested 322. Here it is a nested commit, so the method 300 continues with restore link information to the abort handler associated with the previous speculative region 324. For example, link information to the abort handler 214.2 may be restored. The method 300 may continue with removing link information to the abort handler associated with the speculative region 326. For example, link information to 224.1 may be removed.
The method 300 may continue with in response to beginning a speculative region 304. For example, routine D 220.1 may return back to routine C 210.2. Routine C 210.2 may continue with call Routine E 212.2. Routine E 220.2 is called and routine E 220.2 begins with speculate 221.2. The method 300 continues with is speculative region nested 306. In this case, speculate 221.2 is nested because it was called by routine C 210.1, which was inside a speculative region begun with speculate 211.2, so the method 300 continues with store link information to the abort handler associated with the previous speculative region 308. For example, a link 250.2 may be stored from abort handler 224.2 to abort handler 214.2.
The method 300 continues with store link information to the abort handler associated with the speculative region 310. For example, a link to the abort handler 224.2 may be stored when entering speculate 221.2. The method 300 then returns to start 302.
The method 300 may continue with in response to an abort command 320. For example, an abort may occur because another processor may access memory that is part of the working set of memory locations of routine E 220.2.
The method 300 may continue with run abort handler associated with the aborted speculative region 314. For example, the aborted speculative region in
Illustrated in
The cores 602, 604 include cache memory 604, 605, registers 606, 607, rSP 608, 609, rIP 610, 611 , and synchronization facility 616, 617.
The cache memory 604, 605 may be a place to store memory locations 104 for quick access and may include facilities for maintaining the consistency of the cache memory 604, 605 with the memory 104. The registers 606, 607 may include registers 606, 607 for storing data, locations, and flags indicating the status of events.
The rSP 608, 609 may be a register stack pointer (rSP) with the address to a stack 632, 633 in memory 104 for use by a currently executing routine. The rIP 610, 613 may be a register instruction pointer (rIP) with the address to code that is to be executed next for a routine.
The synchronization facility 616, 617 may include a saved_rIP 618, 619, a saved_rSP 620, 621, an nesting level 622, 623, rAX 624, 625, and rFLAGS 626, 627. The saved_rIP 618, 619 may be the last rIP 610, 613 before a nested speculative region was called. The saved_rSP 620, 621 may be the last rSP 608, 609 before a nested speculative region was called. Nesting level 622, 623 may indicate the currently nesting level of the speculative regions. The rAX 624, 625 may be used to copy the value of nesting level 622, 623 and abort information when an abort occurs. The rFLAGS 626, 627 may be set to indicate statuses of why an abort occurred as well as indicate other statuses in the system. The synchronization facility 616, 617 may include speculate and commit commands, which may be implemented in microcode or circuits which may include registers and memory.
The memory 104 may include code with speculative region 630, 631, stacks 632, 633, code region 652, working set 636, 642, synchronization facility 650, and, optionally, current abort handler frame 648.
The code with speculative region 630, 631 may be code stored in the memory 104 that utilizes the synchronization facility 650 with speculate and commit commands that are executed by a core 602, 603. For example, the routines A, B, C, D, E, 200.1, 210.1, 210.2, 220.1, 220.2 may be speculative regions 630, 631. The code region 652 may be a portion of code that is executed by a core 602, 603. The stacks 632, 633 may be portions of memory 104 used to execute the code with speculative region 630, 631. The working sets 636, 642 may be memory locations 389, 639, 644, 645 that are used inside speculative regions of the code with speculative regions 630, 631.
The synchronization facility mechanism 650 may be an extension of the instruction set of the processor 102 that provides a synchronization facility. The synchronization facility 650 provides for atomic modification of multiple memory locations 638, 639, 644, 645 by a speculative region. Code with speculative region 630, 631 is executed by a core 602, 603. A speculative region may begin with a speculate command and end with a commit command. The speculative region may access memory locations in working set 636, 642 between the speculate and commit commands that are to be accessed atomically, which means that other regions of code should not access the memory locations 638, 639, 644, 645 between when a speculative region begins with a speculate command and when a speculative region ends with a commit command. So, while the speculative region is executing, the working set 636, 642 is only to be accessed by the speculative region. If a code region 652, which itself may be a speculative region, attempts to access one of the memory locations of the working set 636, 642, before the speculative region issues a commit command, then the synchronization facility 650 aborts either the code region 652 or the code with speculative region 630, 631. The code with speculative region 630, 631 may be aborted and then an attempt may be made to re-execute the code with speculative region 630, 631.
The nested speculate 504 may be implemented as a command that (a) saves the stored instruction pointer and the stored stack pointer, (b) stores the instruction pointer and stack pointer like the non-nested speculate, and adjusts the nesting level. For example, referring to
The nested commit 506 may be implemented as a command that restores the values for the saved instruction pointer and the saved stack pointer 506, and adjusts the nesting level. For example, referring to
The non-nested commit 508 may adjust the nesting level. For example, the core 602, 603 may set nesting level 622, 623 to indicate there is no nesting, which may be represented by zero.
Referring back to
The method 300 continues with is speculative region nested 306. For example, continuing with the example of
The method 300 continues with store link information to the abort handler associated with the speculative region 310. As part of the speculate command, the core 602 may store the instruction pointer rIP 610 in the location saved_rIP 618.
Additionally, as part of performing the speculate 402, the core 602 may store whether or not an abort has occurred in a location rFLAGS 626. The synchronization facility 616 on an abort will set rAX 624 to a non-zero value to include the nesting level 622 and abort information, set rFLAGS 626 to indicate an abort occurred, and restore the rIP 618 to “JNZ abort_handler” 403 so that on an abort, the core 602 will jump to line 409: “Abort_handler”, since “JNZ abort_handler” 403 will jump to abort_handler 409, if rFLAGS 626 is not zero.
If there is an abort during the execution of the speculative region (after speculate 402 and before commit 407), and not during a nested speculative region, then the synchronization facility 616 will copy saved_rIP 618 into rIP 610. The code line 403, “JNZ Abort_Handler”, will then be executed and since JNZ will be true, because rFLAGS 626 is not zero, execution will jump to code line 409, Abort_handler. Thus, store link information to the abort handler associated with the speculative region 306 is performed.
As part of performing the speculate 402, as discussed in conjunction with
The method 300 may then continue with in response to entering a speculate region 304. For example, continuing with the example in
The method 300 may continue with is speculative region nested 306. As part of performing the speculative command 452, nesting level 622 is used to determine whether the speculate 452 is nested. When speculate 402 was executed, nesting level 622 was incremented to 1, so the nesting level is 1 and does indicate the speculate 452 is nested. The core 602 increments nesting level 622 by 1 so that nesting level 622 is now 2.
The method 300 may continue with store link information to the abort handler associated with the previous speculative region 308. For example, as part of performing the speculate 452, the core 602 may push the saved_rIP 618 and the saved_rSP 620 on the stack 624, which may increment the stack pointer 624, rSP 608.
The method 300 may continue with store link information to the abort handler associated with the speculative region 310. For example, as part of performing the speculate 452, the core 602 may store the instruction point rIP 638 in the location saved_rIP 618. The core 602 may store the stack pointer rSP 608 in location Saved_rSP 620. The saved_rSP 620 may be used to restore the stack pointer rSP 608 if the current speculate region 402 is aborted. The method 300 continues with returning to start 302.
The method 300 may continue with in response to entering a commit command 306. For example, continuing with the example of
The method 300 may continue with is commit nested 322. For example, continuing with the example of
The method 300 may continue with restore link information to the abort handler associated with the previous speculative region 324. For example, continuing with the example of
The method 300 may continue with removing link information to the abort handler associated with the corresponding speculative region 322. For example, continuing with the example of
The method 300 may continue with returning to start 302. The method 300 may continue with in response to entering a commit command 306. For example, continuing with the example of
The method 300 continues with is the nesting level nested 306. For example, continuing with the example of
The method 300 continues with stop. For example, continuing with the example of
Alternatively to the code 400 example above, the method 300 may continue with in response to an abort command 312. For example, in the example of
The method 300 continues run abort handler associated with the aborted speculative region 314. For example, continuing with the example of
The method 300 may continue is aborted speculative region nested 316. For example, continuing with the example of
Alternatively to the code 400 example above, the method 300 may continue with in response to an abort command 312, where the abort occurs in the nested speculative region of lines 452 through 455. For example, in the example of
The method 300 continues run abort handler associated with the aborted speculative region 314. For example, continuing with the example of
The method 300 may continue is aborted speculative region nested 316. For example, continuing with the example of
For each previous speculative region, running the abort handler of the previous speculative region 318. Continuing the example of
The method 300 would then continue with returning to start 302. The core 602 would then jump to line 401 “Retry” and attempt to execute the speculative region 402 through 407 again.
The abort handler frame 702 includes abort handler pointer 704, continuation information 706, level 708, and next abort handler 710. Code with speculative region 630 includes code that creates the abort handler frame 702 in the stack before a speculate instruction.
The abort handler pointer 704 is a pointer to an abort handler for the current speculative region 630. Continuation information 706 is register state including the stack pointer to revert to for the abort handler. Level 708 is a level of nesting of the speculative region 630. Next abort handler 710 is a pointer to a previous abort handler frame 702.
The current abort handler frame 264 (see also
On an abort, the abort handler frames 702 are traversed by a routine that calls each of the abort handlers for each abort handler frame 702 by using the abort handler pointer 704 and linking to the previous abort handler frame 702 using next abort handler 710. The routine may check to level 708 of the abort handler frame 702, and if the level 708 is greater than a level of nesting indicated by a nesting counter, then the routine will not call the abort handler associated with the abort handler frame 702. Thus, the method 300 may be performed using abort handler frames 702.
Examples of disclosed embodiments of the synchronization facilities provide the advantage that nesting is supported such that multiple speculative regions can be contained within another speculative region, which allows speculative regions to call functions that themselves use the synchronization facility.
Examples of disclosed embodiments of the methods, apparatus, and computer readable medium for nested speculative regions have the advantage of calling nested abort handlers whereas current synchronization facilities only notify the outermost speculative region of an abort, thus ignoring abort handlers registered by nested speculative regions, which may clean up memory locations and registers, and may keep statistics on the number of aborts. The omission of calling abort handlers of nested speculative regions means that nested code must not rely on the abort handler ever being called in case of an abort. This will restrict what the code in nested speculative regions can do. For example, the nested code cannot use the abort handlers to do clean-up of non-speculative modifications it has done inside the speculative region.
Examples of disclosed embodiments of the methods, apparatus, and computer readable medium for nested speculative regions have the advantage of calling nested abort handlers whereas current, so that statistics of success-abort rates to determine future behavior can be calculated.
The methods or flow charts provided herein may be implemented in a computer program, software, or firmware incorporated in a computer-readable storage medium for execution by a general purpose computer or a processor. Examples of computer-readable storage mediums include a read only memory (ROM), a random access memory (RAM), a register, cache memory, semiconductor memory devices, magnetic media such as internal hard disks and removable disks, magneto-optical media, and optical media such as CD-ROM disks, and digital versatile disks (DVDs). The computer-readable storage may be non-transitory.
Number | Name | Date | Kind |
---|---|---|---|
7779307 | Favor | Aug 2010 | B1 |
8127057 | Chung | Feb 2012 | B2 |
8195917 | Hohmuth et al. | Jun 2012 | B2 |
20100023703 | Christie | Jan 2010 | A1 |
20100023704 | Christie et al. | Jan 2010 | A1 |
20100023706 | Christie | Jan 2010 | A1 |
20100023707 | Hohmuth | Jan 2010 | A1 |
20100205408 | Chung et al. | Aug 2010 | A1 |
20110208921 | Pohlack et al. | Aug 2011 | A1 |
20110209151 | Chung et al. | Aug 2011 | A1 |
20110231630 | Dannowski et al. | Sep 2011 | A1 |
20110246724 | Marathe | Oct 2011 | A1 |
20110307689 | Chung | Dec 2011 | A1 |
20120124293 | Chung | May 2012 | A1 |
20120124563 | Chung et al. | May 2012 | A1 |
20120159084 | Pohlack et al. | Jun 2012 | A1 |
20120227045 | Knauth | Sep 2012 | A1 |
20120233411 | Christie et al. | Sep 2012 | A1 |
Number | Date | Country | |
---|---|---|---|
20140181480 A1 | Jun 2014 | US |