gem5
v20.0.0.3
|
#include <dyn_inst.hh>
Public Types | |
enum | { MaxInstSrcRegs = TheISA::MaxInstSrcRegs, MaxInstDestRegs = TheISA::MaxInstDestRegs } |
typedef Impl::O3CPU | O3CPU |
Typedef for the CPU. More... | |
typedef TheISA::MachInst | MachInst |
Binary machine instruction type. More... | |
using | VecRegContainer = TheISA::VecRegContainer |
Register types. More... | |
using | VecElem = TheISA::VecElem |
using | VecPredRegContainer = TheISA::VecPredRegContainer |
![]() | |
enum | { MaxInstSrcRegs = TheISA::MaxInstSrcRegs, MaxInstDestRegs = TheISA::MaxInstDestRegs } |
typedef Impl::CPUType | ImplCPU |
typedef ImplCPU::ImplState | ImplState |
using | VecRegContainer = TheISA::VecRegContainer |
using | LSQRequestPtr = typename Impl::CPUPol::LSQ::LSQRequest * |
using | LQIterator = typename Impl::CPUPol::LSQUnit::LQIterator |
using | SQIterator = typename Impl::CPUPol::LSQUnit::SQIterator |
typedef Impl::DynInstPtr | DynInstPtr |
typedef RefCountingPtr< BaseDynInst< Impl > > | BaseDynInstPtr |
typedef std::list< DynInstPtr >::iterator | ListIt |
![]() | |
typedef TheISA::PCState | PCState |
using | VecRegContainer = TheISA::VecRegContainer |
using | VecElem = TheISA::VecElem |
using | VecPredRegContainer = TheISA::VecPredRegContainer |
Public Member Functions | |
BaseO3DynInst (const StaticInstPtr &staticInst, const StaticInstPtr ¯oop, TheISA::PCState pc, TheISA::PCState predPC, InstSeqNum seq_num, O3CPU *cpu) | |
BaseDynInst constructor given a binary instruction. More... | |
BaseO3DynInst (const StaticInstPtr &_staticInst, const StaticInstPtr &_macroop) | |
BaseDynInst constructor given a static inst pointer. More... | |
~BaseO3DynInst () | |
Fault | execute () |
Executes the instruction. More... | |
Fault | initiateAcc () |
Initiates the access. More... | |
Fault | completeAcc (PacketPtr pkt) |
Completes the access. More... | |
RegVal | readMiscReg (int misc_reg) override |
Reads a misc. More... | |
void | setMiscReg (int misc_reg, RegVal val) override |
Sets a misc. More... | |
RegVal | readMiscRegOperand (const StaticInst *si, int idx) override |
Reads a misc. More... | |
void | setMiscRegOperand (const StaticInst *si, int idx, RegVal val) override |
Sets a misc. More... | |
void | updateMiscRegs () |
Called at the commit stage to update the misc. More... | |
void | forwardOldRegs () |
void | trap (const Fault &fault) |
Traps to handle specified fault. More... | |
void | syscall (Fault *fault) override |
Emulates a syscall. More... | |
RegVal | readIntRegOperand (const StaticInst *si, int idx) override |
Reads an integer register. More... | |
RegVal | readFloatRegOperandBits (const StaticInst *si, int idx) override |
Reads a floating point register in its binary format, instead of by value. More... | |
const VecRegContainer & | readVecRegOperand (const StaticInst *si, int idx) const override |
Vector Register Interfaces. More... | |
VecRegContainer & | getWritableVecRegOperand (const StaticInst *si, int idx) override |
Read destination vector register operand for modification. More... | |
VecElem | readVecElemOperand (const StaticInst *si, int idx) const override |
Vector Elem Interfaces. More... | |
const VecPredRegContainer & | readVecPredRegOperand (const StaticInst *si, int idx) const override |
Predicate registers interface. More... | |
VecPredRegContainer & | getWritableVecPredRegOperand (const StaticInst *si, int idx) override |
Gets destination predicate register operand for modification. More... | |
RegVal | readCCRegOperand (const StaticInst *si, int idx) override |
void | setIntRegOperand (const StaticInst *si, int idx, RegVal val) override |
void | setFloatRegOperandBits (const StaticInst *si, int idx, RegVal val) override |
Records an fp register being set to an integer value. More... | |
void | setVecRegOperand (const StaticInst *si, int idx, const VecRegContainer &val) override |
Record a vector register being set to a value. More... | |
void | setVecElemOperand (const StaticInst *si, int idx, const VecElem val) override |
Record a vector register being set to a value. More... | |
void | setVecPredRegOperand (const StaticInst *si, int idx, const VecPredRegContainer &val) override |
Record a vector register being set to a value. More... | |
void | setCCRegOperand (const StaticInst *si, int idx, RegVal val) override |
Records a CC register being set to a value. More... | |
ConstVecLane8 | readVec8BitLaneOperand (const StaticInst *si, int idx) const override |
Vector Register Lane Interfaces. More... | |
ConstVecLane16 | readVec16BitLaneOperand (const StaticInst *si, int idx) const override |
Reads source vector 16bit operand. More... | |
ConstVecLane32 | readVec32BitLaneOperand (const StaticInst *si, int idx) const override |
Reads source vector 32bit operand. More... | |
ConstVecLane64 | readVec64BitLaneOperand (const StaticInst *si, int idx) const override |
Reads source vector 64bit operand. More... | |
template<typename LD > | |
void | setVecLaneOperandT (const StaticInst *si, int idx, const LD &val) |
Write a lane of the destination vector operand. More... | |
virtual void | setVecLaneOperand (const StaticInst *si, int idx, const LaneData< LaneSize::Byte > &val) override |
Write a lane of the destination vector operand. More... | |
virtual void | setVecLaneOperand (const StaticInst *si, int idx, const LaneData< LaneSize::TwoByte > &val) override |
virtual void | setVecLaneOperand (const StaticInst *si, int idx, const LaneData< LaneSize::FourByte > &val) override |
virtual void | setVecLaneOperand (const StaticInst *si, int idx, const LaneData< LaneSize::EightByte > &val) override |
![]() | |
BaseCPU * | getCpuPtr () |
void | recordResult (bool f) |
Records changes to result? More... | |
bool | effAddrValid () const |
Is the effective virtual address valid. More... | |
void | effAddrValid (bool b) |
bool | memOpDone () const |
Whether or not the memory operation is done. More... | |
void | memOpDone (bool f) |
bool | notAnInst () const |
void | setNotAnInst () |
void | demapPage (Addr vaddr, uint64_t asn) |
Invalidate a page in the DTLB and ITLB. More... | |
void | demapInstPage (Addr vaddr, uint64_t asn) |
void | demapDataPage (Addr vaddr, uint64_t asn) |
Fault | initiateMemRead (Addr addr, unsigned size, Request::Flags flags, const std::vector< bool > &byte_enable=std::vector< bool >()) |
Fault | writeMem (uint8_t *data, unsigned size, Addr addr, Request::Flags flags, uint64_t *res, const std::vector< bool > &byte_enable=std::vector< bool >()) |
Fault | initiateMemAMO (Addr addr, unsigned size, Request::Flags flags, AtomicOpFunctorPtr amo_op) |
bool | translationStarted () const |
True if the DTB address translation has started. More... | |
void | translationStarted (bool f) |
bool | translationCompleted () const |
True if the DTB address translation has completed. More... | |
void | translationCompleted (bool f) |
bool | possibleLoadViolation () const |
True if this address was found to match a previous load and they issued out of order. More... | |
void | possibleLoadViolation (bool f) |
bool | hitExternalSnoop () const |
True if the address hit a external snoop while sitting in the LSQ. More... | |
void | hitExternalSnoop (bool f) |
bool | isTranslationDelayed () const |
Returns true if the DTB address translation is being delayed due to a hw page table walk. More... | |
PhysRegIdPtr | renamedDestRegIdx (int idx) const |
Returns the physical register index of the i'th destination register. More... | |
PhysRegIdPtr | renamedSrcRegIdx (int idx) const |
Returns the physical register index of the i'th source register. More... | |
const RegId & | flattenedDestRegIdx (int idx) const |
Returns the flattened register index of the i'th destination register. More... | |
PhysRegIdPtr | prevDestRegIdx (int idx) const |
Returns the physical register index of the previous physical register that remapped to the same logical register index. More... | |
void | renameDestReg (int idx, PhysRegIdPtr renamed_dest, PhysRegIdPtr previous_rename) |
Renames a destination register to a physical register. More... | |
void | renameSrcReg (int idx, PhysRegIdPtr renamed_src) |
Renames a source logical register to the physical register which has/will produce that logical register's result. More... | |
void | flattenDestReg (int idx, const RegId &flattened_dest) |
Flattens a destination architectural register index into a logical index. More... | |
BaseDynInst (const StaticInstPtr &staticInst, const StaticInstPtr ¯oop, TheISA::PCState pc, TheISA::PCState predPC, InstSeqNum seq_num, ImplCPU *cpu) | |
BaseDynInst constructor given a binary instruction. More... | |
BaseDynInst (const StaticInstPtr &staticInst, const StaticInstPtr ¯oop) | |
BaseDynInst constructor given a StaticInst pointer. More... | |
~BaseDynInst () | |
BaseDynInst destructor. More... | |
void | dump () |
Dumps out contents of this BaseDynInst. More... | |
void | dump (std::string &outstring) |
Dumps out contents of this BaseDynInst into given string. More... | |
int | cpuId () const |
Read this CPU's ID. More... | |
uint32_t | socketId () const |
Read this CPU's Socket ID. More... | |
MasterID | masterId () const |
Read this CPU's data requestor ID. More... | |
ContextID | contextId () const |
Read this context's system-wide ID. More... | |
Fault | getFault () const |
Returns the fault type. More... | |
Fault & | getFault () |
TODO: This I added for the LSQRequest side to be able to modify the fault. More... | |
bool | doneTargCalc () |
Checks whether or not this instruction has had its branch target calculated yet. More... | |
void | setPredTarg (const TheISA::PCState &_predPC) |
Set the predicted target of this current instruction. More... | |
const TheISA::PCState & | readPredTarg () |
Addr | predInstAddr () |
Returns the predicted PC immediately after the branch. More... | |
Addr | predNextInstAddr () |
Returns the predicted PC two instructions after the branch. More... | |
Addr | predMicroPC () |
Returns the predicted micro PC after the branch. More... | |
bool | readPredTaken () |
Returns whether the instruction was predicted taken or not. More... | |
void | setPredTaken (bool predicted_taken) |
bool | mispredicted () |
Returns whether the instruction mispredicted. More... | |
bool | isNop () const |
bool | isMemRef () const |
bool | isLoad () const |
bool | isStore () const |
bool | isAtomic () const |
bool | isStoreConditional () const |
bool | isInstPrefetch () const |
bool | isDataPrefetch () const |
bool | isInteger () const |
bool | isFloating () const |
bool | isVector () const |
bool | isControl () const |
bool | isCall () const |
bool | isReturn () const |
bool | isDirectCtrl () const |
bool | isIndirectCtrl () const |
bool | isCondCtrl () const |
bool | isUncondCtrl () const |
bool | isCondDelaySlot () const |
bool | isThreadSync () const |
bool | isSerializing () const |
bool | isSerializeBefore () const |
bool | isSerializeAfter () const |
bool | isSquashAfter () const |
bool | isMemBarrier () const |
bool | isWriteBarrier () const |
bool | isNonSpeculative () const |
bool | isQuiesce () const |
bool | isIprAccess () const |
bool | isUnverifiable () const |
bool | isSyscall () const |
bool | isMacroop () const |
bool | isMicroop () const |
bool | isDelayedCommit () const |
bool | isLastMicroop () const |
bool | isFirstMicroop () const |
bool | isMicroBranch () const |
void | setSerializeBefore () |
Temporarily sets this instruction as a serialize before instruction. More... | |
void | clearSerializeBefore () |
Clears the serializeBefore part of this instruction. More... | |
bool | isTempSerializeBefore () |
Checks if this serializeBefore is only temporarily set. More... | |
void | setSerializeAfter () |
Temporarily sets this instruction as a serialize after instruction. More... | |
void | clearSerializeAfter () |
Clears the serializeAfter part of this instruction. More... | |
bool | isTempSerializeAfter () |
Checks if this serializeAfter is only temporarily set. More... | |
void | setSerializeHandled () |
Sets the serialization part of this instruction as handled. More... | |
bool | isSerializeHandled () |
Checks if the serialization part of this instruction has been handled. More... | |
OpClass | opClass () const |
Returns the opclass of this instruction. More... | |
TheISA::PCState | branchTarget () const |
Returns the branch target address. More... | |
int8_t | numSrcRegs () const |
Returns the number of source registers. More... | |
int8_t | numDestRegs () const |
Returns the number of destination registers. More... | |
int8_t | numFPDestRegs () const |
int8_t | numIntDestRegs () const |
int8_t | numCCDestRegs () const |
int8_t | numVecDestRegs () const |
int8_t | numVecElemDestRegs () const |
int8_t | numVecPredDestRegs () const |
const RegId & | destRegIdx (int i) const |
Returns the logical register index of the i'th destination register. More... | |
const RegId & | srcRegIdx (int i) const |
Returns the logical register index of the i'th source register. More... | |
uint8_t | resultSize () |
Return the size of the instResult queue. More... | |
InstResult | popResult (InstResult dflt=InstResult()) |
Pops a result off the instResult queue. More... | |
void | markSrcRegReady () |
Records that one of the source registers is ready. More... | |
void | markSrcRegReady (RegIndex src_idx) |
Marks a specific register as ready. More... | |
bool | isReadySrcRegIdx (int idx) const |
Returns if a source register is ready. More... | |
void | setCompleted () |
Sets this instruction as completed. More... | |
bool | isCompleted () const |
Returns whether or not this instruction is completed. More... | |
void | setResultReady () |
Marks the result as ready. More... | |
bool | isResultReady () const |
Returns whether or not the result is ready. More... | |
void | setCanIssue () |
Sets this instruction as ready to issue. More... | |
bool | readyToIssue () const |
Returns whether or not this instruction is ready to issue. More... | |
void | clearCanIssue () |
Clears this instruction being able to issue. More... | |
void | setIssued () |
Sets this instruction as issued from the IQ. More... | |
bool | isIssued () const |
Returns whether or not this instruction has issued. More... | |
void | clearIssued () |
Clears this instruction as being issued. More... | |
void | setExecuted () |
Sets this instruction as executed. More... | |
bool | isExecuted () const |
Returns whether or not this instruction has executed. More... | |
void | setCanCommit () |
Sets this instruction as ready to commit. More... | |
void | clearCanCommit () |
Clears this instruction as being ready to commit. More... | |
bool | readyToCommit () const |
Returns whether or not this instruction is ready to commit. More... | |
void | setAtCommit () |
bool | isAtCommit () |
void | setCommitted () |
Sets this instruction as committed. More... | |
bool | isCommitted () const |
Returns whether or not this instruction is committed. More... | |
void | setSquashed () |
Sets this instruction as squashed. More... | |
bool | isSquashed () const |
Returns whether or not this instruction is squashed. More... | |
void | setInIQ () |
Sets this instruction as a entry the IQ. More... | |
void | clearInIQ () |
Sets this instruction as a entry the IQ. More... | |
bool | isInIQ () const |
Returns whether or not this instruction has issued. More... | |
void | setSquashedInIQ () |
Sets this instruction as squashed in the IQ. More... | |
bool | isSquashedInIQ () const |
Returns whether or not this instruction is squashed in the IQ. More... | |
void | setInLSQ () |
Sets this instruction as a entry the LSQ. More... | |
void | removeInLSQ () |
Sets this instruction as a entry the LSQ. More... | |
bool | isInLSQ () const |
Returns whether or not this instruction is in the LSQ. More... | |
void | setSquashedInLSQ () |
Sets this instruction as squashed in the LSQ. More... | |
bool | isSquashedInLSQ () const |
Returns whether or not this instruction is squashed in the LSQ. More... | |
void | setInROB () |
Sets this instruction as a entry the ROB. More... | |
void | clearInROB () |
Sets this instruction as a entry the ROB. More... | |
bool | isInROB () const |
Returns whether or not this instruction is in the ROB. More... | |
void | setSquashedInROB () |
Sets this instruction as squashed in the ROB. More... | |
bool | isSquashedInROB () const |
Returns whether or not this instruction is squashed in the ROB. More... | |
bool | isPinnedRegsRenamed () const |
Returns whether pinned registers are renamed. More... | |
void | setPinnedRegsRenamed () |
Sets the destination registers as renamed. More... | |
bool | isPinnedRegsWritten () const |
Returns whether destination registers are written. More... | |
void | setPinnedRegsWritten () |
Sets destination registers as written. More... | |
bool | isPinnedRegsSquashDone () const |
Return whether dest registers' pinning status updated after squash. More... | |
void | setPinnedRegsSquashDone () |
Sets dest registers' status updated after squash. More... | |
TheISA::PCState | pcState () const |
Read the PC state of this instruction. More... | |
void | pcState (const TheISA::PCState &val) |
Set the PC state of this instruction. More... | |
Addr | instAddr () const |
Read the PC of this instruction. More... | |
Addr | nextInstAddr () const |
Read the PC of the next instruction. More... | |
Addr | microPC () const |
Read the micro PC of this instruction. More... | |
bool | readPredicate () const |
void | setPredicate (bool val) |
bool | readMemAccPredicate () const |
void | setMemAccPredicate (bool val) |
void | setTid (ThreadID tid) |
Sets the thread id. More... | |
void | setThreadState (ImplState *state) |
Sets the pointer to the thread state. More... | |
ThreadContext * | tcBase () const |
Returns the thread context. More... | |
bool | eaSrcsReady () const |
Returns whether or not the eff. More... | |
bool | strictlyOrdered () const |
Is this instruction's memory access strictly ordered? More... | |
void | strictlyOrdered (bool so) |
bool | hasRequest () const |
Has this instruction generated a memory request. More... | |
void | setRequest () |
Assert this instruction has generated a memory request. More... | |
ListIt & | getInstListIt () |
Returns iterator to this instruction in the list of all insts. More... | |
void | setInstListIt (ListIt _instListIt) |
Sets iterator for this instruction in the list of all insts. More... | |
unsigned int | readStCondFailures () const |
Returns the number of consecutive store conditional failures. More... | |
void | setStCondFailures (unsigned int sc_failures) |
Sets the number of consecutive store conditional failures. More... | |
void | armMonitor (Addr address) |
bool | mwait (PacketPtr pkt) |
void | mwaitAtomic (ThreadContext *tc) |
AddressMonitor * | getAddrMonitor () |
template<typename T > | |
void | setScalarResult (T &&t) |
Pushes a result onto the instResult queue. More... | |
template<typename T > | |
void | setVecResult (T &&t) |
Full vector result. More... | |
template<typename T > | |
void | setVecElemResult (T &&t) |
Vector element result. More... | |
template<typename T > | |
void | setVecPredResult (T &&t) |
Predicate result. More... | |
![]() | |
virtual Fault | readMem (Addr addr, uint8_t *data, unsigned int size, Request::Flags flags, const std::vector< bool > &byte_enable=std::vector< bool >()) |
Perform an atomic memory read operation. More... | |
virtual Fault | initiateMemRead (Addr addr, unsigned int size, Request::Flags flags, const std::vector< bool > &byte_enable=std::vector< bool >()) |
Initiate a timing memory read operation. More... | |
virtual Fault | writeMem (uint8_t *data, unsigned int size, Addr addr, Request::Flags flags, uint64_t *res, const std::vector< bool > &byte_enable=std::vector< bool >())=0 |
For atomic-mode contexts, perform an atomic memory write operation. More... | |
virtual Fault | amoMem (Addr addr, uint8_t *data, unsigned int size, Request::Flags flags, AtomicOpFunctorPtr amo_op) |
For atomic-mode contexts, perform an atomic AMO (a.k.a., Atomic Read-Modify-Write Memory Operation) More... | |
virtual Fault | initiateMemAMO (Addr addr, unsigned int size, Request::Flags flags, AtomicOpFunctorPtr amo_op) |
For timing-mode contexts, initiate an atomic AMO (atomic read-modify-write memory operation) More... | |
![]() | |
RefCounted () | |
We initialize the reference count to zero and the first object to take ownership of it must increment it to one. More... | |
virtual | ~RefCounted () |
We make the destructor virtual because we're likely to have virtual functions on reference counted objects. More... | |
void | incref () const |
Increment the reference count. More... | |
void | decref () const |
Decrement the reference count and destroy the object if all references are gone. More... | |
Static Public Attributes | |
static constexpr auto | NumVecElemPerVecReg = TheISA::NumVecElemPerVecReg |
Protected Attributes | |
std::array< RegVal, TheISA::MaxMiscDestRegs > | _destMiscRegVal |
Values to be written to the destination misc. More... | |
std::array< short, TheISA::MaxMiscDestRegs > | _destMiscRegIdx |
Indexes of the destination misc. More... | |
uint8_t | _numDestMiscRegs |
Number of destination misc. More... | |
![]() | |
std::queue< InstResult > | instResult |
The result of the instruction; assumes an instruction can have many destination registers. More... | |
TheISA::PCState | pc |
PC state for this instruction. More... | |
std::bitset< MaxInstSrcRegs > | _readySrcRegIdx |
Whether or not the source register is ready. More... | |
std::array< RegId, TheISA::MaxInstDestRegs > | _flatDestRegIdx |
Flattened register index of the destination registers of this instruction. More... | |
std::array< PhysRegIdPtr, TheISA::MaxInstDestRegs > | _destRegIdx |
Physical register index of the destination registers of this instruction. More... | |
std::array< PhysRegIdPtr, TheISA::MaxInstSrcRegs > | _srcRegIdx |
Physical register index of the source registers of this instruction. More... | |
std::array< PhysRegIdPtr, TheISA::MaxInstDestRegs > | _prevDestRegIdx |
Physical register index of the previous producers of the architected destinations. More... | |
Private Member Functions | |
void | initVars () |
Initializes variables. More... | |
Additional Inherited Members | |
![]() | |
InstSeqNum | seqNum |
The sequence number of the instruction. More... | |
const StaticInstPtr | staticInst |
The StaticInst used by this BaseDynInst. More... | |
ImplCPU * | cpu |
Pointer to the Impl's CPU object. More... | |
ImplState * | thread |
Pointer to the thread state. More... | |
Fault | fault |
The kind of fault this instruction has generated. More... | |
Trace::InstRecord * | traceData |
InstRecord that tracks this instructions. More... | |
ThreadID | threadNumber |
The thread this instruction is from. More... | |
ListIt | instListIt |
Iterator pointing to this BaseDynInst in the list of all insts. More... | |
TheISA::PCState | predPC |
Predicted PC state after this instruction. More... | |
const StaticInstPtr | macroop |
The Macroop if one exists. More... | |
uint8_t | readyRegs |
How many source registers are ready. More... | |
Addr | effAddr |
The effective virtual address (lds & stores only). More... | |
Addr | physEffAddr |
The effective physical address. More... | |
unsigned | memReqFlags |
The memory request flags (from translation). More... | |
unsigned | effSize |
The size of the request. More... | |
uint8_t * | memData |
Pointer to the data for the memory access. More... | |
int16_t | lqIdx |
Load queue index. More... | |
LQIterator | lqIt |
int16_t | sqIdx |
Store queue index. More... | |
SQIterator | sqIt |
LSQRequestPtr | savedReq |
Saved memory request (needed when the DTB address translation is delayed due to a hw page table walk). More... | |
RequestPtr | reqToVerify |
![]() | |
enum | Status { IqEntry, RobEntry, LsqEntry, Completed, ResultReady, CanIssue, Issued, Executed, CanCommit, AtCommit, Committed, Squashed, SquashedInIQ, SquashedInLSQ, SquashedInROB, PinnedRegsRenamed, PinnedRegsWritten, PinnedRegsSquashDone, RecoverInst, BlockingInst, ThreadsyncWait, SerializeBefore, SerializeAfter, SerializeHandled, NumStatus } |
enum | Flags { NotAnInst, TranslationStarted, TranslationCompleted, PossibleLoadViolation, HitExternalSnoop, EffAddrValid, RecordResult, Predicate, MemAccPredicate, PredTaken, IsStrictlyOrdered, ReqMade, MemOpDone, MaxFlags } |
Definition at line 58 of file dyn_inst.hh.
typedef TheISA::MachInst BaseO3DynInst< Impl >::MachInst |
Binary machine instruction type.
Definition at line 65 of file dyn_inst.hh.
typedef Impl::O3CPU BaseO3DynInst< Impl >::O3CPU |
Typedef for the CPU.
Definition at line 62 of file dyn_inst.hh.
using BaseO3DynInst< Impl >::VecElem = TheISA::VecElem |
Definition at line 68 of file dyn_inst.hh.
using BaseO3DynInst< Impl >::VecPredRegContainer = TheISA::VecPredRegContainer |
Definition at line 70 of file dyn_inst.hh.
using BaseO3DynInst< Impl >::VecRegContainer = TheISA::VecRegContainer |
Register types.
Definition at line 67 of file dyn_inst.hh.
anonymous enum |
Enumerator | |
---|---|
MaxInstSrcRegs | |
MaxInstDestRegs |
Definition at line 72 of file dyn_inst.hh.
BaseO3DynInst< Impl >::BaseO3DynInst | ( | const StaticInstPtr & | staticInst, |
const StaticInstPtr & | macroop, | ||
TheISA::PCState | pc, | ||
TheISA::PCState | predPC, | ||
InstSeqNum | seq_num, | ||
O3CPU * | cpu | ||
) |
BaseDynInst constructor given a binary instruction.
Definition at line 49 of file dyn_inst_impl.hh.
References BaseO3DynInst< Impl >::initVars().
BaseO3DynInst< Impl >::BaseO3DynInst | ( | const StaticInstPtr & | _staticInst, |
const StaticInstPtr & | _macroop | ||
) |
BaseDynInst constructor given a static inst pointer.
Definition at line 59 of file dyn_inst_impl.hh.
References BaseO3DynInst< Impl >::initVars().
BaseO3DynInst< Impl >::~BaseO3DynInst | ( | ) |
Definition at line 66 of file dyn_inst_impl.hh.
References StaticInst::disassemble(), DPRINTFR, DTRACE, BaseDynInst< Impl >::instAddr(), BaseDynInst< Impl >::microPC(), BaseDynInst< Impl >::seqNum, BaseDynInst< Impl >::staticInst, and X86ISA::val.
Fault BaseO3DynInst< Impl >::completeAcc | ( | PacketPtr | pkt | ) |
Completes the access.
Only valid for memory operations.
Definition at line 162 of file dyn_inst_impl.hh.
References StaticInst::completeAcc(), BaseDynInst< Impl >::cpu, BaseDynInst< Impl >::fault, BaseDynInst< Impl >::isStoreConditional(), Packet::req, BaseDynInst< Impl >::reqToVerify, BaseDynInst< Impl >::staticInst, BaseDynInst< Impl >::thread, and BaseDynInst< Impl >::traceData.
Fault BaseO3DynInst< Impl >::execute | ( | ) |
Executes the instruction.
Definition at line 126 of file dyn_inst_impl.hh.
References StaticInst::execute(), BaseDynInst< Impl >::fault, BaseDynInst< Impl >::staticInst, BaseDynInst< Impl >::thread, and BaseDynInst< Impl >::traceData.
|
inline |
Definition at line 208 of file dyn_inst.hh.
References CCRegClass, RegId::classValue(), BaseDynInst< Impl >::cpu, StaticInst::destRegIdx(), BaseDynInst< Impl >::fault, FloatRegClass, RefCountingPtr< T >::get(), IntRegClass, MiscRegClass, BaseDynInst< Impl >::numDestRegs(), panic, BaseDynInst< Impl >::prevDestRegIdx(), BaseO3DynInst< Impl >::setCCRegOperand(), BaseO3DynInst< Impl >::setFloatRegOperandBits(), BaseO3DynInst< Impl >::setIntRegOperand(), BaseO3DynInst< Impl >::setVecElemOperand(), BaseO3DynInst< Impl >::setVecPredRegOperand(), BaseO3DynInst< Impl >::setVecRegOperand(), BaseDynInst< Impl >::staticInst, BaseO3DynInst< Impl >::syscall(), BaseO3DynInst< Impl >::trap(), VecElemClass, VecPredRegClass, and VecRegClass.
|
inlineoverridevirtual |
Gets destination predicate register operand for modification.
Implements ExecContext.
Definition at line 370 of file dyn_inst.hh.
References BaseDynInst< Impl >::_destRegIdx, and BaseDynInst< Impl >::cpu.
|
inlineoverridevirtual |
Read destination vector register operand for modification.
Implements ExecContext.
Definition at line 290 of file dyn_inst.hh.
References BaseDynInst< Impl >::_destRegIdx, and BaseDynInst< Impl >::cpu.
Fault BaseO3DynInst< Impl >::initiateAcc | ( | ) |
Initiates the access.
Only valid for memory operations.
Definition at line 144 of file dyn_inst_impl.hh.
References BaseDynInst< Impl >::fault, StaticInst::initiateAcc(), BaseDynInst< Impl >::staticInst, BaseDynInst< Impl >::thread, and BaseDynInst< Impl >::traceData.
|
private |
Initializes variables.
Definition at line 104 of file dyn_inst_impl.hh.
References BaseO3DynInst< Impl >::_numDestMiscRegs, and BaseDynInst< Impl >::_readySrcRegIdx.
Referenced by BaseO3DynInst< Impl >::BaseO3DynInst().
|
inlineoverridevirtual |
Implements ExecContext.
Definition at line 376 of file dyn_inst.hh.
References BaseDynInst< Impl >::_srcRegIdx, and BaseDynInst< Impl >::cpu.
|
inlineoverridevirtual |
Reads a floating point register in its binary format, instead of by value.
Implements ExecContext.
Definition at line 275 of file dyn_inst.hh.
References BaseDynInst< Impl >::_srcRegIdx, and BaseDynInst< Impl >::cpu.
|
inlineoverridevirtual |
Reads an integer register.
Implements ExecContext.
Definition at line 269 of file dyn_inst.hh.
References BaseDynInst< Impl >::_srcRegIdx, and BaseDynInst< Impl >::cpu.
|
inlineoverridevirtual |
Reads a misc.
register, including any side-effects the read might have as defined by the architecture.
Implements ExecContext.
Definition at line 138 of file dyn_inst.hh.
References BaseDynInst< Impl >::cpu, and BaseDynInst< Impl >::threadNumber.
|
inlineoverridevirtual |
Reads a misc.
register, including any side-effects the read might have as defined by the architecture.
Implements ExecContext.
Definition at line 172 of file dyn_inst.hh.
References BaseDynInst< Impl >::cpu, RegId::index(), RegId::isMiscReg(), X86ISA::reg, StaticInst::srcRegIdx(), and BaseDynInst< Impl >::threadNumber.
|
inlineoverridevirtual |
Reads source vector 16bit operand.
Implements ExecContext.
Definition at line 306 of file dyn_inst.hh.
References BaseDynInst< Impl >::_srcRegIdx, and BaseDynInst< Impl >::cpu.
|
inlineoverridevirtual |
Reads source vector 32bit operand.
Implements ExecContext.
Definition at line 313 of file dyn_inst.hh.
References BaseDynInst< Impl >::_srcRegIdx, and BaseDynInst< Impl >::cpu.
|
inlineoverridevirtual |
Reads source vector 64bit operand.
Implements ExecContext.
Definition at line 320 of file dyn_inst.hh.
References BaseDynInst< Impl >::_srcRegIdx, and BaseDynInst< Impl >::cpu.
|
inlineoverridevirtual |
Vector Register Lane Interfaces.
Reads source vector 8bit operand.
Implements ExecContext.
Definition at line 299 of file dyn_inst.hh.
References BaseDynInst< Impl >::_srcRegIdx, and BaseDynInst< Impl >::cpu.
|
inlineoverridevirtual |
Vector Elem Interfaces.
Reads an element of a vector register.
Implements ExecContext.
Definition at line 358 of file dyn_inst.hh.
References BaseDynInst< Impl >::_srcRegIdx, and BaseDynInst< Impl >::cpu.
|
inlineoverridevirtual |
Predicate registers interface.
Reads source predicate register operand.
Implements ExecContext.
Definition at line 364 of file dyn_inst.hh.
References BaseDynInst< Impl >::_srcRegIdx, and BaseDynInst< Impl >::cpu.
|
inlineoverridevirtual |
Vector Register Interfaces.
Reads source vector register operand.
Implements ExecContext.
Definition at line 281 of file dyn_inst.hh.
References BaseDynInst< Impl >::_srcRegIdx, and BaseDynInst< Impl >::cpu.
|
inlineoverridevirtual |
Records a CC register being set to a value.
Reimplemented from BaseDynInst< Impl >.
Definition at line 422 of file dyn_inst.hh.
References BaseDynInst< Impl >::_destRegIdx, BaseDynInst< Impl >::cpu, and BaseDynInst< Impl >::setCCRegOperand().
Referenced by BaseO3DynInst< Impl >::forwardOldRegs().
|
inlineoverridevirtual |
Records an fp register being set to an integer value.
Reimplemented from BaseDynInst< Impl >.
Definition at line 392 of file dyn_inst.hh.
References BaseDynInst< Impl >::_destRegIdx, BaseDynInst< Impl >::cpu, and BaseDynInst< Impl >::setFloatRegOperandBits().
Referenced by BaseO3DynInst< Impl >::forwardOldRegs().
|
inlineoverridevirtual |
Reimplemented from BaseDynInst< Impl >.
Definition at line 385 of file dyn_inst.hh.
References BaseDynInst< Impl >::_destRegIdx, BaseDynInst< Impl >::cpu, and BaseDynInst< Impl >::setIntRegOperand().
Referenced by BaseO3DynInst< Impl >::forwardOldRegs().
|
inlineoverridevirtual |
Sets a misc.
register, including any side-effects the write might have as defined by the architecture.
Writes to misc. registers are recorded and deferred until the commit stage, when updateMiscRegs() is called. First, check if the misc reg has been written before and update its value to be committed instead of making a new entry. If not, make a new entry and record the write.
Implements ExecContext.
Definition at line 147 of file dyn_inst.hh.
References BaseO3DynInst< Impl >::_numDestMiscRegs, PowerISA::MaxMiscDestRegs, and X86ISA::val.
Referenced by BaseO3DynInst< Impl >::setMiscRegOperand().
|
inlineoverridevirtual |
Sets a misc.
register, including any side-effects the write might have as defined by the architecture.
Implements ExecContext.
Definition at line 183 of file dyn_inst.hh.
References StaticInst::destRegIdx(), RegId::index(), RegId::isMiscReg(), X86ISA::reg, BaseO3DynInst< Impl >::setMiscReg(), and X86ISA::val.
|
inlineoverridevirtual |
Record a vector register being set to a value.
Reimplemented from BaseDynInst< Impl >.
Definition at line 406 of file dyn_inst.hh.
References BaseDynInst< Impl >::_destRegIdx, BaseDynInst< Impl >::cpu, and BaseDynInst< Impl >::setVecElemOperand().
Referenced by BaseO3DynInst< Impl >::forwardOldRegs().
|
inlineoverridevirtual |
Write a lane of the destination vector operand.
Implements ExecContext.
Definition at line 333 of file dyn_inst.hh.
References BaseO3DynInst< Impl >::setVecLaneOperandT().
|
inlineoverridevirtual |
Implements ExecContext.
Definition at line 339 of file dyn_inst.hh.
References BaseO3DynInst< Impl >::setVecLaneOperandT().
|
inlineoverridevirtual |
Implements ExecContext.
Definition at line 345 of file dyn_inst.hh.
References BaseO3DynInst< Impl >::setVecLaneOperandT().
|
inlineoverridevirtual |
Implements ExecContext.
Definition at line 351 of file dyn_inst.hh.
References BaseO3DynInst< Impl >::setVecLaneOperandT().
|
inline |
Write a lane of the destination vector operand.
Definition at line 328 of file dyn_inst.hh.
References BaseDynInst< Impl >::_destRegIdx, and BaseDynInst< Impl >::cpu.
Referenced by BaseO3DynInst< Impl >::setVecLaneOperand().
|
inlineoverridevirtual |
Record a vector register being set to a value.
Reimplemented from BaseDynInst< Impl >.
Definition at line 415 of file dyn_inst.hh.
References BaseDynInst< Impl >::_destRegIdx, BaseDynInst< Impl >::cpu, and BaseDynInst< Impl >::setVecPredRegOperand().
Referenced by BaseO3DynInst< Impl >::forwardOldRegs().
|
inlineoverridevirtual |
Record a vector register being set to a value.
Reimplemented from BaseDynInst< Impl >.
Definition at line 399 of file dyn_inst.hh.
References BaseDynInst< Impl >::_destRegIdx, BaseDynInst< Impl >::cpu, and BaseDynInst< Impl >::setVecRegOperand().
Referenced by BaseO3DynInst< Impl >::forwardOldRegs().
|
overridevirtual |
Emulates a syscall.
Implements ExecContext.
Definition at line 193 of file dyn_inst_impl.hh.
References BaseDynInst< Impl >::cpu, BaseDynInst< Impl >::pcState(), and BaseDynInst< Impl >::threadNumber.
Referenced by BaseO3DynInst< Impl >::forwardOldRegs().
void BaseO3DynInst< Impl >::trap | ( | const Fault & | fault | ) |
Traps to handle specified fault.
Definition at line 186 of file dyn_inst_impl.hh.
References BaseDynInst< Impl >::cpu, BaseDynInst< Impl >::staticInst, and BaseDynInst< Impl >::threadNumber.
Referenced by BaseO3DynInst< Impl >::forwardOldRegs().
|
inline |
Called at the commit stage to update the misc.
registers.
Definition at line 192 of file dyn_inst.hh.
References BaseO3DynInst< Impl >::_numDestMiscRegs, BaseDynInst< Impl >::cpu, ArmISA::i, and BaseDynInst< Impl >::thread.
|
protected |
Indexes of the destination misc.
registers. They are needed to defer the write accesses to the misc. registers until the commit stage, when the instruction is out of its speculative state.
Definition at line 115 of file dyn_inst.hh.
|
protected |
Values to be written to the destination misc.
registers.
Definition at line 109 of file dyn_inst.hh.
|
protected |
Number of destination misc.
registers.
Definition at line 118 of file dyn_inst.hh.
Referenced by BaseO3DynInst< Impl >::initVars(), BaseO3DynInst< Impl >::setMiscReg(), and BaseO3DynInst< Impl >::updateMiscRegs().
|
static |
Definition at line 69 of file dyn_inst.hh.