FPU Read Stage
The FPU pipeline RD-stage receives instructions issued by the CPU. The CPU issues FPU instructions from the A-stage into the FPU RD stage which consists of a single register, such that only one FPU instruction can be held at any one time. The instruction is committed when it is dispatched to X[0], where it will start execution. X[0] holds the instruction such that the CPU is free to issue another instruction into the RD-stage.
The RD-stage is also subject to hazard checks and can therefore be stalled. Should a RAW hazard be detected with a prior instruction that is already executing within the FPU pipeline, the hazard will be detected in the RD-stage which will then be stalled until such time that the hazard is resolved.
Should the CPU subsequently attempt to issue additional FPU instructions, the RD-stage will not be able to accept them which will also stall the CPU until such time that the RAW hazard has been resolved. From the CPU perspective, this scenario is viewed as a structural hazard.
The RD-stage will also stall the CPU under the following conditions:
- Whenever the number of instructions (default value is four) are in their execute X[n] stages, an instruction is pending in the RD-stage, and the CPU is attempting to issue a further instruction. In this situation, the Instruction/Hazard Tracker is full so the FPU cannot dispatch another instruction from the RD-stage into X [0] until one of the instructions currently executing passes into the WB-stage. Assuming the default value is four, this can occur when the pipeline is executing instructions that take longer than four cycles to execute, and additional FPU instructions are issued while the long instruction is still executing (i.e., not yet in the WB-stage). The longer instruction(s) execute and retire at a rate which is slower than the rate at which the Instruction/Hazard Tracker can be filled, resulting in the CPU being stalled.
- Whenever the CPU attempts to
                    issue more than two FDIV instructions while a previously issued and a dispatched
                    FDIV instruction is still executing (i.e., not yet in the WB-stage). FDIV is a
                    special case where no more than one instance can be executed within the pipeline
                    at any one time. Consequently, executing another FDIV while a prior instance is
                    still executing will cause this second FDIV to be issued but held pending in the
                    RD-stage (i.e., CPU will not stall). But attempting to issue a third FDIV
                    instruction, while the pending (second) instance has not yet been dispatched to
                    X[0], will result in a CPU (issue) stall. The RD-stage also includes special
                    logic to support the FAND and FIOR operations (refer to FANDandFIORInstructions).
