Microprocessors are increasingly being called on to support multiple cores on a single chip. To keep design efforts and costs down and to adapt to future applications, designers often try to design multiple core microprocessors that can meet the needs of an entire product range, from mobile laptops to high-end servers. This design goal presents a difficult dilemma to processor designers: maintaining the single-thread performance important for microprocessors in laptop and desktop computers while at the same time providing the system throughput important for microprocessors in servers. Traditionally, designers have tried to meet the goal of high single-thread performance using chips with single, large, complex cores. On the other hand, designers have tried to meet the goal of high system throughput by providing multiple, comparatively smaller, simpler cores on a single chip. Because, however, designers are faced with limitations on chip size and power consumption, providing both high single-thread performance and high system throughput on the same chip at the same time presents significant challenges. More specifically, a single chip will not accommodate many large cores, and small cores traditionally do not provide high single-thread performance.
One factor which strongly affects throughput is the need to execute instructions dependent on long-latency operations, such as the servicing of cache misses. Instructions in a processor may await execution in a logic structure known as a “scheduler.” In the scheduler, instructions with destination registers allocated wait for their source operands to become available, whereupon the instructions can leave the scheduler, execute and retire.
Like any structure in a processor, the scheduler is subject to area constraints and accordingly has a finite number of entries. Instructions dependent on the servicing of a cache miss may have to wait hundreds of cycles until the miss is serviced. While they wait, their scheduler entries are kept allocated and thus unavailable to other instructions. This situation creates pressure on the scheduler and can result in performance loss.
Similarly, pressure is created on the register file because the instructions waiting in the scheduler keep their destination registers allocated and therefore unavailable to other instructions. This situation can also be detrimental to performance, particularly in view of the fact that the register file may need to sustain thousands of instructions and is typically a power-hungry, cycle-critical, continuously clocked structure.
Embodiments of the present invention relate to a system and method for comparatively increasing processor throughput and memory latency tolerance, and relieving pressure on the scheduler and on the register file, by diverting instructions dependent on long-latency operations from a processor pipeline flow and re-introducing them into the flow when the long-latency operations are completed. In this way, the instructions do not tie up resources and overall instruction throughput in the pipeline is comparatively increased.
More specifically, embodiments of the present invention relate to identifying instructions dependent on long-latency operations, referred to herein as “slice” instructions, and moving them from the pipeline to a “slice data buffer” along with at least a portion of information needed for the slice instructions to execute. The scheduler entries and destination registers of the slice instructions may then be reclaimed for use by other instructions. Instructions independent of the long latency operations can use these resources and continue program execution. When the long-latency operations upon which the slice instructions in the slice data buffer depend are completed, the slice instructions may be re-introduced into the pipeline, executed and retired. Embodiments of the present invention thereby effect a non-blocking, continual flow processor pipeline.
The slice processing unit 100 may be associated with a processor pipeline. The pipeline may comprise an instruction decoder 104 to decode instructions, coupled to allocate and register rename logic 105. As is well known, processors may include logic such as allocate and register rename logic 105 to allocate physical registers to instructions and map logical registers of the instructions to the physical registers. “Map” as used here means to define or designate a correspondence between (in conceptual terms, a logical register identifier is “renamed” into a physical register identifier). More specifically, for the brief span of its life in a pipeline, an instruction's source and destination operands, when they are specified in terms of identifiers of the registers of the processor's set of logical (also “architectural”) registers, are assigned physical registers so that the instruction can actually be carried out in the processor. The physical register set is typically much more numerous than the logical register set and thus multiple different physical registers can be mapped to the same logical register.
The allocate and register rename logic 105 may be coupled to uop (“micro”-operation, i.e., instruction) queues 106 to queue instructions for execution, and the uop queues 106 may be coupled to schedulers 107 to schedule the instructions for execution. The mapping of logical registers to physical registers (referred to hereafter as “the physical register mapping”) performed by the allocate and register rename logic 105 may be recorded in a reorder buffer (ROB) (not shown) or in the schedulers 107 for instructions awaiting execution. According to embodiments of the present invention, the physical register mapping may be copied to the slice data buffer 101 for instructions identified as slice instructions, as described in more detail further on.
The schedulers 107 may be coupled to the register file, which includes the processor's physical registers, shown in
As noted earlier, the servicing of a cache miss for a load that misses in the L2 cache may be considered a long-latency operation. Other examples of long latency operations include floating point operations and dependent chains of floating point operations. As instructions are processed by the pipeline, instructions dependent on long-latency operations may be classified as slice instructions and be given special handling according to embodiments of the present invention to prevent the slice instructions blocking or slowing pipeline throughput. A slice instruction may be an independent instruction, such as a load that generates a cache miss, or an instruction that depends on another slice instruction, such as an instruction that reads the register loaded by the load instruction.
When a slice instruction occurs in the pipeline, it may be stored in the slice data buffer 101, in its place in a scheduling order of instructions as determined by schedulers 107. A scheduler typically schedules instructions in data dependence order. The slice instruction may be stored in the slice data buffer with at least a portion of information necessary to execute the instruction. For example, the information may include the value of a source operand if available, and the instruction's physical register mapping. The physical register mapping preserves the data dependence information associated with the instruction. By storing any available source values and the physical register mapping with the slice instruction in the slice data buffer, the corresponding registers can be released and reclaimed for other instructions, even before the slice instruction completes. Further, when the slice instruction is subsequently re-introduced into the pipeline to complete its execution, it may be unnecessary to re-evaluate at least one of its source operands, while the physical register mapping ensures that the instruction is executed at the correct place in a slice instruction sequence.
According to embodiments of the present invention, identification of slice instructions may be performed dynamically by tracking register and memory dependencies of long-latency operations. More specifically, slice instructions may be identified by propagating a slice instruction indicator via physical registers and store queue entries. A store queue is a structure (not shown in
The bit may initially be set for an independent slice instruction and then propagated to instructions directly or indirectly dependent on that independent instruction. More specifically, the NAV bit of the destination register of an independent slice instruction in the scheduler, such as a load that misses the cache, may be set. Subsequent instructions having that destination register as a source may “inherit” the NAV bit, in that the NAV bits in their respective destination registers may also be set. If the source operand of a store instruction has its NAV bit set, the NAV bit of the store queue entry corresponding to the store may be set. Subsequent load instructions either reading from or predicted to forward from that store queue entry may have the NAV bit set in their respective destinations. The instruction entries in the scheduler may also be provided with NAV bits for their source and destination operands corresponding to the NAV bits in the physical register file and store queue entries. The NAV bits in the scheduler entries may be set as corresponding NAV bits in the physical registers and store queue entries are set, to identify the scheduler entries as containing slice instructions. A dependency chain of slice instructions may be formed in the scheduler by the foregoing process.
In the normal course of operations in a pipeline, an instruction may leave the scheduler and be executed when its source registers are ready, that is, contain the values needed for the instruction to execute and yield a valid result. A source register may become ready when, for example, a source instruction has executed and written a value to the register. Such a register is referred to herein as a “completed source register.” According to embodiments of the present invention, a source register may be considered ready either when it is a completed source register, or when its NAV bit is set. Thus, a slice instruction can leave the scheduler when any of its source registers is a completed source register, and any source register that is not a completed source register has its NAV bit set. Slice instructions and non-slice instructions can therefore “drain” out of the pipeline in a continual flow, without the delays caused by dependence on long-latency operations, and allowing subsequent instructions to acquire scheduler entries.
Operations performed when a slice instruction leaves the scheduler may include recording, along with the instruction itself, the value of any completed source register of the instruction in the slice data buffer, and marking any completed source register as read. This allows the completed source register to be reclaimed for use by other instructions. The instruction's physical register mapping may also be recorded in the slice data buffer. A plurality of slice instructions (a “slice”) may be recorded in the slice data buffer along with corresponding completed source register values and physical register mappings. In consideration of the foregoing, a slice may be viewed as a self-contained program that can be re-introduced into the pipeline, when the long-latency operations upon which it depends complete, and executed efficiently since the only external input needed for the slice to execute is the data from the load (assuming the long-latency operation is the servicing of a cache miss). Other inputs have been copied to the slice data buffer as the values of completed source registers, or are generated internally to the slice.
Further, as noted earlier, the destination registers of the slice instructions may be released for reclamation and use by other instructions, relieving pressure on the register file.
In embodiments, the slice data buffer may comprise a plurality of entries. Each entry may comprise a plurality of fields corresponding to each slice instruction, including a field for the slice instruction itself, a field for a completed source register value, and fields for the physical register mappings of source and destination registers of the slice instruction. Slice data buffer entries may be allocated as slice instructions leave the scheduler, and the slice instructions may be stored in the slice data buffer in the order they had in the scheduler, as noted earlier. The slice instructions may be returned to the pipeline, in due course, in the same order. For example, in embodiments the instructions could be reinserted into the pipeline via the uop queues 107, but other arrangements are possible. In embodiments, the slice data buffer may be a high density SRAM (static random access memory) implementing a long-latency, high bandwidth array, similar to an L2 cache.
Reference is now made again to
The slice rename filter 102 may be used for operations associated with checkpointing, a known process in speculative processors. Checkpointing may be performed to preserve the state of the architectural registers of a given thread at a given point, so that the state can be readily recovered if needed. For example, checkpointing may be performed at a low-confidence branch.
If a slice instruction writes to a checkpointed physical register, that instruction should not be assigned a new physical register by the remapper 103. Instead, that checkpointed physical register must be mapped to the same physical register originally assigned to it by the allocate and register rename logic 105, otherwise the checkpoint would become corrupted/invalid. The slice rename filter 102 provides the information to the slice remapper 103 as to which physical registers are checkpointed, so that the slice remapper 102 can assign their original mappings to the checkpointed physical registers. When the results of slice instructions that write to checkpointed registers are available, they may be merged or integrated with the results of independent instructions writing to checkpointed registers that completed earlier.
According to embodiments of the present invention, the slice remapper 103 may have available to it, for assigning to the physical register mappings of slice instructions, a greater number of physical registers than does the allocate and register rename logic 105. This may be in order to prevent deadlocks due to checkpointing. More specifically, physical registers may be unavailable to be remapped to slice instructions because the physical registers are tied up by checkpoints. On the other hand, it may be the case that only when the slice instructions complete can the physical registers tied up by the checkpoints be released. This situation can lead to deadlock.
Accordingly, as noted above, the slice remapper could have a range of physical registers available for mapping that is over and above the range available to the allocate and register rename logic 105. For example, there could be 192 actual physical registers in a processor; 128 of these might be made available to the allocate and register rename logic 105 for mapping to instructions, while the entire range of 192 would be available to the slice remapper. Thus, in this example, an extra 64 physical registers would be available to the slice remapper to ensure that a deadlock situation due to registers being unavailable in the base set of 128 does not occur.
An example will now be given, referring to elements of
In the schedulers 107, instructions (1) and (2) await execution. When their source operands become available, instructions (1) and (2) can leave the scheduler and execute, making their respective entries in the schedulers 107 available to other instructions. The source operand of load instruction (1) is a memory location, and thus instruction (1) requires the correct data from the memory location to be present in the L1 cache (not shown) or L2 cache 110. Instruction (2) depends on instruction (1) in that it needs instruction (1) to execute successfully in order for the correct data to be present in register R1. Assume that register R3 is a completed source register.
Now further assume the load instruction, instruction (1), misses in the L2 cache 110. Typically, it could take hundreds of cycles for the cache miss to be serviced. During that time, in a conventional processor the scheduler entries occupied by instructions (1) and (2) would be unavailable for other instructions, inhibiting throughput and lowering performance. Moreover, physical registers R1, R2 and R3 would remain allocated while the cache miss was serviced, creating pressure on the register file.
By contrast, according to embodiments of the present invention, instructions (1) and (2) may be diverted to the slice processing unit 100 and their corresponding scheduler and register file resources freed for use by other instructions in the pipeline. More specifically, the NAV bit may be set in R1 when instruction (1) misses the cache, and then, based on the fact that instruction (2) reads R1, also set in R2. Subsequent instructions, not illustrated, having R1 or R2 as sources, would also have the NAV bit set in their respective destination registers. The NAV bits in the scheduler entries corresponding to the instructions would also be set, identifying them as slice instructions.
Instruction (1) is, more particularly, an independent slice instruction because it does not have as a source a register or store queue entry. On the other hand, instruction (2) is a dependent slice instruction because it has as a source a register whose NAV bit is set.
Because the NAV bit is set in R1, instruction (1) can exit the schedulers 107. Pursuant to exiting the schedulers 107, instruction (1) is written into the slice data buffer 101, along with its physical register mapping R1 (to some logical register). Similarly, because the NAV bit is set in R1 and because R3 is a completed source register, instruction (2) can exit the schedulers 107, whereupon instruction (2), the value of R3, and the physical register mappings R1 (to some logical register), R2 (to some logical register) and R3 (to some logical register) are written into the slice data buffer 101. Instruction (2) follows instruction (1) in the slice data buffer, just as it did in the schedulers. The scheduler entries formerly occupied by instructions (1) and (2), and registers R1, R2 and R3 can all now be reclaimed and made available for use by other instructions.
When the cache miss generated by instruction (1) is serviced, instructions (1) and (2) may be inserted, in their original scheduling order, back into the pipeline, with a new physical register mapping performed by the slice remapper 103. The completed source register value may be carried with the instruction as an immediate operand. The instructions may subsequently be executed.
In view of the foregoing description,
As shown in block 201, based on the identification, the instruction may be caused to leave the pipeline without being executed and be placed in a slice data buffer, along with at least a portion of information needed to execute the instruction. The at least a portion of information may include a value of a source register and a physical register mapping. The scheduler entry and physical register(s) allocated by the instruction may be released and reclaimed for use by other instructions, as shown in block 202.
After the long-latency operations complete, the instruction may be re-inserted into the pipeline, as shown in block 203. The instruction may be one of a plurality of instructions moved from the pipeline to the slice data buffer, based on their being identified as instructions dependent on a long-latency operation. The plurality may be moved to the slice data buffer in a scheduling order, and re-inserted into the pipeline in that same order. The instruction may then be executed, as shown in block 204.
It is noted that to allow precise exception handling and branch recovery on a checkpoint processing and recovery architecture that implements a continual flow pipeline, two types of registers should not be released until the checkpoint is no longer required: registers belonging to the checkpoint's architectural state, and registers corresponding to the architectural “live-outs” Liveout registers, as is well known, are the logical registers and corresponding physical registers that reflect the current state of a program. More specifically, a liveout register corresponds to the last or most recent instruction of a program to write to a given logical register of a processor's logical instruction set. The liveout and checkpointed registers are, however, small in number (on the order of logical registers) as compared to the physical register file.
Other physical registers can be reclaimed when (1) all subsequent instructions reading the registers have read them, and (2) the physical registers have been subsequently re-mapped, i.e., overwritten. A continual flow pipeline according to embodiments of the present invention guarantees condition (1) because completed source registers are marked as read for slice instructions before the slice instructions even complete but after they read the value of the completed source registers. Condition (2) is met during normal processing itself—for L logical registers, the (L+1)th instruction requiring a new physical register mapping will overwrite an earlier physical register mapping. Thus for every N instructions with a destination register leaving the pipeline, N−L physical registers will be overwritten and hence condition (2) will be satisfied.
Thus, by ensuring that values of completed source registers and physical register mapping information are recorded for a slice, registers can be reclaimed at such a rate that whenever an instruction requires a physical register, such a register is always available—hence achieving the continual flow property.
It is further noted that the slice data buffer can contain multiple slices due to multiple independent loads. As discussed earlier, the slices are essentially self-contained programs waiting only for load miss data values to return in order to be ready to execute. Once the load miss data values are available, the slices can be drained (re-inserted into the pipeline) in any order. Servicing of load misses may complete out of order, and thus, for example, a slice belonging to a later miss in the slice data buffer may be ready for re-insertion into the pipeline prior to an earlier slice in the slice data buffer. There are a plurality of options for handling this situation: (1) wait until the oldest slice is ready and drain the slice data buffer in a first-in, first-out order, (2) drain the slice data buffer in a first-in, first-out order when any miss in the slice data buffer returns, and (3) drain the slice data buffer sequentially from the miss serviced (may not necessarily result in draining the oldest slice first).
Several embodiments of the present invention are specifically illustrated and/or described herein. However, it will be appreciated that modifications and variations of the present invention are covered by the above teachings and within the purview of the appended claims without departing from the spirit and intended scope of the invention.