Go to the documentation of this file.
45 #ifndef __CPU_MINOR_FETCH2_HH__
46 #define __CPU_MINOR_FETCH2_HH__
55 #include "params/MinorCPU.hh"
214 const MinorCPUParams ¶ms,
This is a simple scalar statistic, like a counter.
Line fetch data in the forward direction.
Id for lines and instructions.
InstSeqNum lastStreamSeqNum
Stream sequence number of the last seen line used to identify changes of instruction stream.
Data members after this line are cycle-to-cycle state.
bool processMoreThanOneInput
If true, more than one input word can be processed each cycle if there is room in the output to conta...
MinorCPU is an in-order CPU model with four fixed pipeline stages:
statistics::Scalar loadInstructions
void updateBranchPrediction(const BranchData &branch)
Update local branch prediction structures from feedback from Execute.
This stage receives lines of data from Fetch1, separates them into instructions and passes them to De...
unsigned int inputIndex
Index into an incompletely processed input line that instructions are to be extracted from.
branch_prediction::BPredUnit & branchPredictor
Branch predictor passed from Python configuration.
Latch< ForwardLineData >::Output inp
Input port carrying lines from Fetch1.
Latch< BranchData >::Input predictionOut
Output port carrying predictions back to Fetch1.
Interface for things with names.
const ForwardLineData * getInput(ThreadID tid)
Get a piece of data to work on from the inputBuffer, or 0 if there is no data.
statistics::Scalar vecInstructions
Latch< BranchData >::Output branchInp
Input port carrying branches from Execute.
Fetch2ThreadInfo()
Default constructor.
virtual std::string name() const
GenericISA::DelaySlotPCState< 4 > PCState
InstSeqNum predictionSeqNum
Fetch2 is the source of prediction sequence numbers.
std::vector< Fetch2ThreadInfo > fetchInfo
Forward data betwen Execute and Fetch1 carrying change-of-address/stream information.
statistics::Scalar intInstructions
Stats.
Fetch2ThreadInfo(const Fetch2ThreadInfo &other)
void dumpAllInput(ThreadID tid)
Dump the whole contents of the input buffer.
GEM5_DEPRECATED_NAMESPACE(GuestABI, guest_abi)
void evaluate()
Pass on input/buffer data to the output if you can.
bool isDrained()
Is this stage drained? For Fetch2, draining is initiated by Execute halting Fetch1 causing Fetch2 to ...
std::vector< InputBuffer< ForwardLineData > > inputBuffer
void popInput(ThreadID tid)
Pop an element off the input buffer, if there are any.
MinorCPU & cpu
Pointer back to the containing CPU.
statistics::Scalar amoInstructions
Fetch2Stats(MinorCPU *cpu)
Latch< ForwardInstData >::Input out
Output port carrying instructions into Decode.
Fetch2(const std::string &name, MinorCPU &cpu_, const MinorCPUParams ¶ms, Latch< ForwardLineData >::Output inp_, Latch< BranchData >::Output branchInp_, Latch< BranchData >::Input predictionOut_, Latch< ForwardInstData >::Input out_, std::vector< InputBuffer< ForwardInstData >> &next_stage_input_buffer)
TheISA::PCState pc
Remembered program counter value.
bool havePC
PC is currently valid.
Basically a wrapper class to hold both the branch predictor and the BTB.
InstSeqNum expectedStreamSeqNum
Stream sequence number remembered from last time the predictionSeqNum changed.
gem5::minor::Fetch2::Fetch2Stats stats
InstSeqNum fetchSeqNum
Fetch2 is the source of fetch sequence numbers.
statistics::Scalar fpInstructions
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
statistics::Scalar storeInstructions
std::vector< InputBuffer< ForwardInstData > > & nextStageReserve
Interface to reserve space in the next stage.
ThreadID getScheduledThread()
Use the current threading policy to determine the next thread to fetch from.
bool blocked
Blocked indication for report.
int16_t ThreadID
Thread index/ID type.
unsigned int outputWidth
Width of output of this stage/input of next in instructions.
void predictBranch(MinorDynInstPtr inst, BranchData &branch)
Predicts branches for the given instruction.
Generated on Wed Jul 28 2021 12:10:24 for gem5 by doxygen 1.8.17