Go to the documentation of this file.
45 #ifndef __CPU_MINOR_EXECUTE_HH__
46 #define __CPU_MINOR_EXECUTE_HH__
255 bool &failed_predicate,
Fault &fault);
303 bool &completed_mem_issue);
312 void commit(
ThreadID thread_id,
bool only_commit_microops,
bool discard,
324 Execute(
const std::string &name_,
326 const BaseMinorCPUParams ¶ms,
358 unsigned int drain();
ThreadID getCommittingThread()
Use the current threading policy to determine the next thread to decode from.
void tryToBranch(MinorDynInstPtr inst, Fault fault, BranchData &branch)
Generate Branch data based (into branch) on an observed (or not) change in PC while executing an inst...
Id for lines and instructions.
unsigned int inputIndex
Index that we've completed upto in getInput data.
unsigned int drain()
Like the drain interface on SimObject.
unsigned int commitLimit
Number of instructions that can be committed per cycle.
Provide a non-protected base class for Minor's Ports as derived classes are created by Fetch1 and Exe...
A collection of MinorFUs.
MinorFUPool & fuDescriptions
Descriptions of the functional units we want to generate.
friend std::ostream & operator<<(std::ostream &os, DrainState state)
Wrapper for a queue type to act as a pipeline stage input queue.
ThreadID checkInterrupts(BranchData &branch, bool &interrupted)
Check all threads for possible interrupts.
MinorCPU is an in-order CPU model with four fixed pipeline stages:
LSQ lsq
Dcache port to pass on to the CPU.
Queue< QueuedInst, ReportTraitsAdaptor< QueuedInst > > * inFUMemInsts
Memory ref instructions still in the FUs.
void evaluate()
Pass on input/buffer data to the output if you can.
bool takeInterrupt(ThreadID thread_id, BranchData &branch)
Act on an interrupt.
Forward flowing data between Fetch2,Decode,Execute carrying a packet of instructions of a width appro...
bool setTraceTimeOnIssue
Modify instruction trace times on issue.
bool isInterrupted(ThreadID thread_id) const
Has an interrupt been raised.
bool hasInterrupt(ThreadID thread_id)
Checks if a specific thread has an interrupt.
unsigned int memoryCommitLimit
Number of memory instructions that can be committed per cycle.
void commit(ThreadID thread_id, bool only_commit_microops, bool discard, BranchData &branch)
Try and commit instructions from the ends of the functional unit pipelines.
InstSeqNum streamSeqNum
Source of sequence number for instuction streams.
unsigned int noCostFUIndex
The FU index of the non-existent costless FU for instructions which pass the MinorDynInst::isNoCostIn...
Cycles is a wrapper class for representing cycle counts, i.e.
Derived SenderState to carry data access info.
ThreadID getIssuingThread()
LSQ & getLSQ()
To allow ExecContext to find the LSQ.
Interface for things with names.
std::vector< InputBuffer< ForwardInstData > > inputBuffer
Execute(const std::string &name_, MinorCPU &cpu_, const BaseMinorCPUParams ¶ms, Latch< ForwardInstData >::Output inp_, Latch< BranchData >::Input out_)
const ForwardInstData * getInput(ThreadID tid)
Get a piece of data to work on from the inputBuffer, or 0 if there is no data.
Cycles longestFuLatency
Longest latency of any FU, useful for setting up the activity recoder.
std::shared_ptr< FaultBase > Fault
bool processMoreThanOneInput
If true, more than one input line can be processed each cycle if there is room to execute more instru...
bool isDrained()
After thread suspension, has Execute been drained of in-flight instructions and memory accesses.
bool commitInst(MinorDynInstPtr inst, bool early_memory_issue, BranchData &branch, Fault &fault, bool &committed, bool &completed_mem_issue)
Commit a single instruction.
void doInstCommitAccounting(MinorDynInstPtr inst)
Do the stats handling and instruction count and PC event events related to the new instruction/op cou...
ForwardInstData instsBeingCommitted
Structure for reporting insts currently being processed/retired for MinorTrace.
std::vector< Scoreboard > scoreboard
Scoreboard of instruction dependencies.
Forward data betwen Execute and Fetch1 carrying change-of-address/stream information.
bool isInbetweenInsts(ThreadID thread_id) const
Are we between instructions? Can we be interrupted?
MinorCPU::MinorCPUPort & getDcachePort()
Returns the DcachePort owned by this Execute to pass upwards.
void updateBranchData(ThreadID tid, BranchData::Reason reason, MinorDynInstPtr inst, const PCStateBase &target, BranchData &branch)
Actually create a branch to communicate to Fetch1/Fetch2 and, if that is a stream-changing branch upd...
GEM5_DEPRECATED_NAMESPACE(GuestABI, guest_abi)
bool tryPCEvents(ThreadID thread_id)
Try to act on PC-related events.
ExecuteThreadInfo(unsigned int insts_committed)
Constructor.
bool lastCommitWasEndOfMacroop
The last commit was the end of a full instruction so an interrupt can safely happen.
void popInput(ThreadID tid)
Pop an element off the input buffer, if there are any.
bool setTraceTimeOnCommit
Modify instruction trace times on commit.
ExecuteThreadInfo(const ExecuteThreadInfo &other)
void setDrainState(ThreadID thread_id, DrainState state)
Set the drain state (with useful debugging messages)
void handleMemResponse(MinorDynInstPtr inst, LSQ::LSQRequestPtr response, BranchData &branch, Fault &fault)
Handle extracting mem ref responses from the memory queues and completing the associated instructions...
DrainState drainState
State progression for draining NotDraining -> ...
Latch< ForwardInstData >::Output inp
Input port carrying instructions from Decode.
Queue< QueuedInst, ReportTraitsAdaptor< QueuedInst > > * inFlightInsts
In-order instructions either in FUs or the LSQ.
bool executeMemRefInst(MinorDynInstPtr inst, BranchData &branch, bool &failed_predicate, Fault &fault)
Execute a memory reference instruction.
Latch< BranchData >::Input out
Input port carrying stream changes to Fetch1.
bool allowEarlyMemIssue
Allow mem refs to leave their FUs before reaching the head of the in flight insts queue if their depe...
DrainState
Stage cycle-by-cycle state.
unsigned int numFuncUnits
Number of functional units to produce.
InstSeqNum lastPredictionSeqNum
A prediction number for use where one isn't available from an instruction.
std::vector< FUPipeline * > funcUnits
The execution functional units.
unsigned int issueLimit
Number of instructions that can be issued per cycle.
std::vector< ExecuteThreadInfo > executeInfo
unsigned int issue(ThreadID thread_id)
Try and issue instructions from the inputBuffer.
MinorCPU & cpu
Pointer back to the containing CPU.
ThreadID interruptPriority
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
bool instIsHeadInst(MinorDynInstPtr inst)
Returns true if the given instruction is at the head of the inFlightInsts instruction queue.
unsigned int memoryIssueLimit
Number of memory ops that can be issued per cycle.
int16_t ThreadID
Thread index/ID type.
bool instIsRightStream(MinorDynInstPtr inst)
Does the given instruction have the right stream sequence number to be committed?
Generated on Wed Jul 13 2022 10:39:15 for gem5 by doxygen 1.8.17