| gem5
    v21.0.1.0
    | 
The SimpleThread object provides a combination of the ThreadState object and the ThreadContext interface. More...
#include <simple_thread.hh>
 
  
| Public Types | |
| typedef ThreadContext::Status | Status | 
|  Public Types inherited from ThreadState | |
| typedef ThreadContext::Status | Status | 
|  Public Types inherited from ThreadContext | |
| enum | Status { Active, Suspended, Halting, Halted } | 
| Public Member Functions | |
| std::string | name () const | 
| SimpleThread (BaseCPU *_cpu, int _thread_num, System *_system, BaseMMU *_mmu, BaseISA *_isa) | |
| SimpleThread (BaseCPU *_cpu, int _thread_num, System *_system, Process *_process, BaseMMU *_mmu, BaseISA *_isa) | |
| virtual | ~SimpleThread () | 
| void | takeOverFrom (ThreadContext *oldContext) override | 
| void | copyState (ThreadContext *oldContext) | 
| void | serialize (CheckpointOut &cp) const override | 
| Serialize an object.  More... | |
| void | unserialize (CheckpointIn &cp) override | 
| Unserialize an object.  More... | |
| ThreadContext * | getTC () | 
| Returns the pointer to this SimpleThread's ThreadContext.  More... | |
| void | demapPage (Addr vaddr, uint64_t asn) | 
| bool | schedule (PCEvent *e) override | 
| bool | remove (PCEvent *e) override | 
| void | scheduleInstCountEvent (Event *event, Tick count) override | 
| void | descheduleInstCountEvent (Event *event) override | 
| Tick | getCurrentInstCount () override | 
| BaseCPU * | getCpuPtr () override | 
| int | cpuId () const override | 
| uint32_t | socketId () const override | 
| int | threadId () const override | 
| void | setThreadId (int id) override | 
| ContextID | contextId () const override | 
| void | setContextId (ContextID id) override | 
| BaseMMU * | getMMUPtr () override | 
| CheckerCPU * | getCheckerCpuPtr () override | 
| BaseISA * | getIsaPtr () override | 
| TheISA::Decoder * | getDecoderPtr () override | 
| System * | getSystemPtr () override | 
| PortProxy & | getPhysProxy () override | 
| PortProxy & | getVirtProxy () override | 
| void | initMemProxies (ThreadContext *tc) override | 
| Initialise the physical and virtual port proxies and tie them to the data port of the CPU.  More... | |
| Process * | getProcessPtr () override | 
| void | setProcessPtr (Process *p) override | 
| Status | status () const override | 
| void | setStatus (Status newStatus) override | 
| void | activate () override | 
| Set the status to Active.  More... | |
| void | suspend () override | 
| Set the status to Suspended.  More... | |
| void | halt () override | 
| Set the status to Halted.  More... | |
| Tick | readLastActivate () override | 
| Tick | readLastSuspend () override | 
| void | copyArchRegs (ThreadContext *tc) override | 
| void | clearArchRegs () override | 
| RegVal | readIntReg (RegIndex reg_idx) const override | 
| RegVal | readFloatReg (RegIndex reg_idx) const override | 
| const TheISA::VecRegContainer & | readVecReg (const RegId ®) const override | 
| TheISA::VecRegContainer & | getWritableVecReg (const RegId ®) override | 
| const TheISA::VecElem & | readVecElem (const RegId ®) const override | 
| const TheISA::VecPredRegContainer & | readVecPredReg (const RegId ®) const override | 
| TheISA::VecPredRegContainer & | getWritableVecPredReg (const RegId ®) override | 
| RegVal | readCCReg (RegIndex reg_idx) const override | 
| void | setIntReg (RegIndex reg_idx, RegVal val) override | 
| void | setFloatReg (RegIndex reg_idx, RegVal val) override | 
| void | setVecReg (const RegId ®, const TheISA::VecRegContainer &val) override | 
| void | setVecElem (const RegId ®, const TheISA::VecElem &val) override | 
| void | setVecPredReg (const RegId ®, const TheISA::VecPredRegContainer &val) override | 
| void | setCCReg (RegIndex reg_idx, RegVal val) override | 
| TheISA::PCState | pcState () const override | 
| void | pcState (const TheISA::PCState &val) override | 
| void | pcStateNoRecord (const TheISA::PCState &val) override | 
| Addr | instAddr () const override | 
| Addr | nextInstAddr () const override | 
| MicroPC | microPC () const override | 
| bool | readPredicate () const | 
| void | setPredicate (bool val) | 
| RegVal | readMiscRegNoEffect (RegIndex misc_reg) const override | 
| RegVal | readMiscReg (RegIndex misc_reg) override | 
| void | setMiscRegNoEffect (RegIndex misc_reg, RegVal val) override | 
| void | setMiscReg (RegIndex misc_reg, RegVal val) override | 
| RegId | flattenRegId (const RegId ®Id) const override | 
| unsigned | readStCondFailures () const override | 
| bool | readMemAccPredicate () | 
| void | setMemAccPredicate (bool val) | 
| void | setStCondFailures (unsigned sc_failures) override | 
| Counter | readFuncExeInst () const override | 
| RegVal | readIntRegFlat (RegIndex idx) const override | 
| Flat register interfaces.  More... | |
| void | setIntRegFlat (RegIndex idx, RegVal val) override | 
| RegVal | readFloatRegFlat (RegIndex idx) const override | 
| void | setFloatRegFlat (RegIndex idx, RegVal val) override | 
| const TheISA::VecRegContainer & | readVecRegFlat (RegIndex reg) const override | 
| TheISA::VecRegContainer & | getWritableVecRegFlat (RegIndex reg) override | 
| void | setVecRegFlat (RegIndex reg, const TheISA::VecRegContainer &val) override | 
| template<typename T > | |
| VecLaneT< T, true > | readVecLaneFlat (RegIndex reg, int lId) const | 
| template<typename LD > | |
| void | setVecLaneFlat (RegIndex reg, int lId, const LD &val) | 
| const TheISA::VecElem & | readVecElemFlat (RegIndex reg, const ElemIndex &elemIndex) const override | 
| void | setVecElemFlat (RegIndex reg, const ElemIndex &elemIndex, const TheISA::VecElem &val) override | 
| const TheISA::VecPredRegContainer & | readVecPredRegFlat (RegIndex reg) const override | 
| TheISA::VecPredRegContainer & | getWritableVecPredRegFlat (RegIndex reg) override | 
| void | setVecPredRegFlat (RegIndex reg, const TheISA::VecPredRegContainer &val) override | 
| RegVal | readCCRegFlat (RegIndex idx) const override | 
| void | setCCRegFlat (RegIndex idx, RegVal val) override | 
| void | htmAbortTransaction (uint64_t htm_uid, HtmFailureFaultCause cause) override | 
| BaseHTMCheckpointPtr & | getHtmCheckpointPtr () override | 
| void | setHtmCheckpointPtr (BaseHTMCheckpointPtr new_cpt) override | 
| template<typename T > | |
| VecLaneT< T, true > | readVecLane (const RegId ®) const | 
| Vector Register Lane Interfaces.  More... | |
| virtual ConstVecLane8 | readVec8BitLaneReg (const RegId ®) const override | 
| Reads source vector 8bit operand.  More... | |
| virtual ConstVecLane16 | readVec16BitLaneReg (const RegId ®) const override | 
| Reads source vector 16bit operand.  More... | |
| virtual ConstVecLane32 | readVec32BitLaneReg (const RegId ®) const override | 
| Reads source vector 32bit operand.  More... | |
| virtual ConstVecLane64 | readVec64BitLaneReg (const RegId ®) const override | 
| Reads source vector 64bit operand.  More... | |
| template<typename LD > | |
| void | setVecLaneT (const RegId ®, const LD &val) | 
| Write a lane of the destination vector register.  More... | |
| virtual void | setVecLane (const RegId ®, const LaneData< LaneSize::Byte > &val) override | 
| Write a lane of the destination vector register.  More... | |
| virtual void | setVecLane (const RegId ®, const LaneData< LaneSize::TwoByte > &val) override | 
| virtual void | setVecLane (const RegId ®, const LaneData< LaneSize::FourByte > &val) override | 
| virtual void | setVecLane (const RegId ®, const LaneData< LaneSize::EightByte > &val) override | 
|  Public Member Functions inherited from ThreadState | |
| ThreadState (BaseCPU *cpu, ThreadID _tid, Process *_process) | |
| virtual | ~ThreadState () | 
| void | serialize (CheckpointOut &cp) const override | 
| Serialize an object.  More... | |
| void | unserialize (CheckpointIn &cp) override | 
| Unserialize an object.  More... | |
| int | cpuId () const | 
| uint32_t | socketId () const | 
| ContextID | contextId () const | 
| void | setContextId (ContextID id) | 
| void | setThreadId (ThreadID id) | 
| ThreadID | threadId () const | 
| Tick | readLastActivate () const | 
| Tick | readLastSuspend () const | 
| void | initMemProxies (ThreadContext *tc) | 
| Initialise the physical and virtual port proxies and tie them to the data port of the CPU.  More... | |
| PortProxy & | getPhysProxy () | 
| PortProxy & | getVirtProxy () | 
| Process * | getProcessPtr () | 
| void | setProcessPtr (Process *p) | 
| Counter | readFuncExeInst () const | 
| Reads the number of instructions functionally executed and committed.  More... | |
| void | setFuncExeInst (Counter new_val) | 
| Sets the total number of instructions functionally executed and committed.  More... | |
| Status | status () const | 
| Returns the status of this thread.  More... | |
| void | setStatus (Status new_status) | 
| Sets the status of this thread.  More... | |
|  Public Member Functions inherited from Serializable | |
| Serializable () | |
| virtual | ~Serializable () | 
| void | serializeSection (CheckpointOut &cp, const char *name) const | 
| Serialize an object into a new section.  More... | |
| void | serializeSection (CheckpointOut &cp, const std::string &name) const | 
| void | unserializeSection (CheckpointIn &cp, const char *name) | 
| Unserialize an a child object.  More... | |
| void | unserializeSection (CheckpointIn &cp, const std::string &name) | 
|  Public Member Functions inherited from ThreadContext | |
| bool | getUseForClone () | 
| void | setUseForClone (bool new_val) | 
| virtual | ~ThreadContext () | 
| void | quiesce () | 
| Quiesce thread context.  More... | |
| void | quiesceTick (Tick resume) | 
| Quiesce, suspend, and schedule activate at resume.  More... | |
| virtual void | regStats (const std::string &name) | 
| void | setNPC (Addr val) | 
| virtual int | exit () | 
| Public Attributes | |
| PCEventQueue | pcEventQueue | 
| EventQueue | comInstEventQueue | 
| An instruction-based event queue.  More... | |
| System * | system | 
| BaseMMU * | mmu | 
| TheISA::Decoder | decoder | 
| int64_t | htmTransactionStarts | 
| int64_t | htmTransactionStops | 
|  Public Attributes inherited from ThreadState | |
| Counter | numInst | 
| Number of instructions committed.  More... | |
| Counter | numOp | 
| Number of ops (including micro ops) committed.  More... | |
| ThreadState::ThreadStateStats | threadStats | 
| Counter | numLoad | 
| Number of simulated loads, used for tracking events based on the number of loads committed.  More... | |
| Counter | startNumLoad | 
| The number of simulated loads committed prior to this run.  More... | |
| Tick | lastActivate | 
| Last time activate was called on this thread.  More... | |
| Tick | lastSuspend | 
| Last time suspend was called on this thread.  More... | |
| Counter | funcExeInst | 
| unsigned | storeCondFailures | 
|  Public Attributes inherited from ThreadContext | |
| int | intResult = DefaultIntResult | 
| double | floatResult = DefaultFloatResult | 
| int | intOffset = 0 | 
| Protected Attributes | |
| std::array< RegVal, TheISA::NumFloatRegs > | floatRegs | 
| std::array< RegVal, TheISA::NumIntRegs > | intRegs | 
| std::array< TheISA::VecRegContainer, TheISA::NumVecRegs > | vecRegs | 
| std::array< TheISA::VecPredRegContainer, TheISA::NumVecPredRegs > | vecPredRegs | 
| std::array< RegVal, TheISA::NumCCRegs > | ccRegs | 
| TheISA::ISA *const | isa | 
| TheISA::PCState | _pcState | 
| std::unique_ptr< BaseHTMCheckpoint > | _htmCheckpoint | 
| bool | predicate | 
| Did this instruction execute or is it predicated false.  More... | |
| bool | memAccPredicate | 
| True if the memory access should be skipped for this instruction.  More... | |
|  Protected Attributes inherited from ThreadState | |
| ThreadContext::Status | _status | 
| BaseCPU * | baseCpu | 
| ContextID | _contextId | 
| ThreadID | _threadId | 
| Process * | process | 
| PortProxy * | physProxy | 
| A port proxy outgoing only for functional accesses to physical addresses.  More... | |
| PortProxy * | virtProxy | 
| A translating port proxy, outgoing only, for functional accesse to virtual addresses.  More... | |
|  Protected Attributes inherited from ThreadContext | |
| bool | useForClone = false | 
| Additional Inherited Members | |
|  Static Public Member Functions inherited from Serializable | |
| static const std::string & | currentSection () | 
| Gets the fully-qualified name of the active section.  More... | |
| static void | serializeAll (const std::string &cpt_dir) | 
| Serializes all the SimObjects.  More... | |
| static void | unserializeGlobals (CheckpointIn &cp) | 
|  Static Public Member Functions inherited from ThreadContext | |
| static void | compare (ThreadContext *one, ThreadContext *two) | 
| function to compare two thread contexts (for debugging)  More... | |
|  Static Public Attributes inherited from ThreadContext | |
| static const int | ints [] | 
| static const double | floats [] | 
| static const int | DefaultIntResult = 0 | 
| static const double | DefaultFloatResult = 0.0 | 
The SimpleThread object provides a combination of the ThreadState object and the ThreadContext interface.
It implements the ThreadContext interface and adds to the ThreadState object by adding all the objects needed for simple functional execution, including a simple architectural register file, and pointers to the ITB and DTB in full system mode. For CPU models that do not need more advanced ways to hold state (i.e. a separate physical register file, or separate fetch and commit PC's), this SimpleThread class provides all the necessary state for full architecture-level functional simulation. See the AtomicSimpleCPU or TimingSimpleCPU for examples.
Definition at line 90 of file simple_thread.hh.
Definition at line 93 of file simple_thread.hh.
| SimpleThread::SimpleThread | ( | BaseCPU * | _cpu, | 
| int | _thread_num, | ||
| System * | _system, | ||
| BaseMMU * | _mmu, | ||
| BaseISA * | _isa | ||
| ) | 
Definition at line 80 of file simple_thread.cc.
References clearArchRegs(), and isa.
| SimpleThread::SimpleThread | ( | BaseCPU * | _cpu, | 
| int | _thread_num, | ||
| System * | _system, | ||
| Process * | _process, | ||
| BaseMMU * | _mmu, | ||
| BaseISA * | _isa | ||
| ) | 
Definition at line 66 of file simple_thread.cc.
References clearArchRegs(), and isa.
| 
 | inlinevirtual | 
Definition at line 147 of file simple_thread.hh.
| 
 | overridevirtual | 
Set the status to Active.
Implements ThreadContext.
Definition at line 135 of file simple_thread.cc.
References ThreadState::_status, ThreadState::_threadId, BaseCPU::activateContext(), ThreadContext::Active, ThreadState::baseCpu, curTick(), ThreadState::lastActivate, and status().
Referenced by BaseKvmCPU::wakeup().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 253 of file simple_thread.hh.
References _pcState, ccRegs, floatRegs, intRegs, isa, vecPredRegs, and vecRegs.
Referenced by CheckerThreadContext< TC >::clearArchRegs(), and SimpleThread().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 202 of file simple_thread.hh.
References ThreadState::contextId().
Referenced by Minor::ExecContext::contextId(), TimingSimpleCPU::fetch(), TimingSimpleCPU::htmSendAbortSignal(), TimingSimpleCPU::initiateHtmCmd(), TimingSimpleCPU::initiateMemAMO(), TimingSimpleCPU::initiateMemRead(), and TimingSimpleCPU::writeMem().
| 
 | overridevirtual | 
Implements ThreadContext.
Definition at line 169 of file simple_thread.cc.
References ArmISA::copyRegs().
Referenced by CheckerThreadContext< TC >::copyArchRegs(), and copyState().
| void SimpleThread::copyState | ( | ThreadContext * | oldContext | ) | 
Definition at line 107 of file simple_thread.cc.
References ThreadState::_contextId, ThreadState::_status, ThreadState::_threadId, ThreadContext::contextId(), copyArchRegs(), FullSystem, ThreadState::funcExeInst, ThreadContext::readFuncExeInst(), ThreadContext::status(), and ThreadContext::threadId().
Referenced by CheckerThreadContext< TC >::takeOverFrom().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 198 of file simple_thread.hh.
References ThreadState::cpuId().
| 
 | inline | 
Definition at line 168 of file simple_thread.hh.
References BaseMMU::demapPage(), mmu, and MipsISA::vaddr.
Referenced by SimpleExecContext::demapPage().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 186 of file simple_thread.hh.
References comInstEventQueue, EventQueue::deschedule(), and MipsISA::event.
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 207 of file simple_thread.hh.
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 196 of file simple_thread.hh.
References ThreadState::baseCpu.
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 191 of file simple_thread.hh.
References comInstEventQueue, and EventQueue::getCurTick().
| 
 | inlineoverridevirtual | 
| 
 | overridevirtual | 
Implements ThreadContext.
Definition at line 189 of file simple_thread.cc.
References _htmCheckpoint.
| 
 | inlineoverridevirtual | 
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 205 of file simple_thread.hh.
References mmu.
Referenced by Minor::ExecContext::demapPage().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 215 of file simple_thread.hh.
References ThreadState::getPhysProxy().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 223 of file simple_thread.hh.
References ThreadState::getProcessPtr().
| 
 | inlineoverridevirtual | 
| 
 | inline | 
Returns the pointer to this SimpleThread's ThreadContext.
Used when a ThreadContext must be passed to objects outside of the CPU.
Definition at line 165 of file simple_thread.hh.
Referenced by AtomicSimpleCPU::amoMem(), BaseSimpleCPU::BaseSimpleCPU(), BaseSimpleCPU::checkForInterrupts(), BaseKvmCPU::doMMIOAccess(), TimingSimpleCPU::fetch(), TimingSimpleCPU::handleReadPacket(), TimingSimpleCPU::handleWritePacket(), TimingSimpleCPU::initiateMemAMO(), TimingSimpleCPU::initiateMemRead(), MinorCPU::MinorCPU(), BaseSimpleCPU::preExecute(), AtomicSimpleCPU::readMem(), CheckerCPU::setSystem(), Minor::ExecContext::tcBase(), SimpleExecContext::tcBase(), AtomicSimpleCPU::tick(), AtomicSimpleCPU::writeMem(), and TimingSimpleCPU::writeMem().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 216 of file simple_thread.hh.
References ThreadState::getVirtProxy().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 417 of file simple_thread.hh.
References DPRINTF, getWritableVecPredRegFlat(), isa, ArmISA::NumVecPredRegs, and X86ISA::reg.
Referenced by Minor::ExecContext::getWritableVecPredRegOperand(), CheckerCPU::getWritableVecPredRegOperand(), and SimpleExecContext::getWritableVecPredRegOperand().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 646 of file simple_thread.hh.
References X86ISA::reg, and vecPredRegs.
Referenced by getWritableVecPredReg().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 303 of file simple_thread.hh.
References DPRINTF, getWritableVecRegFlat(), isa, ArmISA::NumVecRegs, and X86ISA::reg.
Referenced by Minor::ExecContext::getWritableVecRegOperand(), CheckerCPU::getWritableVecRegOperand(), and SimpleExecContext::getWritableVecRegOperand().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 601 of file simple_thread.hh.
References X86ISA::reg, and vecRegs.
Referenced by getWritableVecReg().
| 
 | overridevirtual | 
Set the status to Halted.
Implements ThreadContext.
Definition at line 159 of file simple_thread.cc.
References ThreadState::_status, ThreadState::_threadId, ThreadState::baseCpu, BaseCPU::haltContext(), ThreadContext::Halted, and status().
| 
 | overridevirtual | 
Implements ThreadContext.
Definition at line 176 of file simple_thread.cc.
References ThreadState::baseCpu, BaseSimpleCPU::htmSendAbortSignal(), htmTransactionStarts, and htmTransactionStops.
| 
 | inlineoverridevirtual | 
Initialise the physical and virtual port proxies and tie them to the data port of the CPU.
tc ThreadContext for the virtual-to-physical translation
Implements ThreadContext.
Definition at line 218 of file simple_thread.hh.
References ThreadState::initMemProxies().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 514 of file simple_thread.hh.
References _pcState.
Referenced by TimingSimpleCPU::htmSendAbortSignal(), TimingSimpleCPU::initiateHtmCmd(), TimingSimpleCPU::initiateMemAMO(), TimingSimpleCPU::initiateMemRead(), CheckerCPU::instAddr(), BaseSimpleCPU::setupFetchRequest(), and TimingSimpleCPU::writeMem().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 516 of file simple_thread.hh.
References _pcState.
Referenced by AtomicSimpleCPU::isCpuDrained(), TimingSimpleCPU::isCpuDrained(), and CheckerCPU::microPC().
| 
 | inline | 
Definition at line 116 of file simple_thread.hh.
References ThreadState::baseCpu, csprintf(), SimObject::name(), and threadId().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 515 of file simple_thread.hh.
References _pcState.
Referenced by CheckerCPU::nextInstAddr().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 505 of file simple_thread.hh.
References _pcState.
Referenced by BaseSimpleCPU::advancePC(), AtomicSimpleCPU::amoMem(), Minor::LSQ::LSQRequest::completeDisabledMemAccess(), CheckerCPU::dumpAndExit(), TimingSimpleCPU::fetch(), CheckerCPU::genMemFragmentRequest(), Minor::ExecContext::pcState(), CheckerThreadContext< TC >::pcState(), CheckerCPU::pcState(), SimpleExecContext::pcState(), BaseSimpleCPU::preExecute(), SimPoint::profile(), AtomicSimpleCPU::tick(), Minor::LSQ::tryToSendToTransfers(), and Minor::LSQ::LSQRequest::tryToSuppressFault().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 506 of file simple_thread.hh.
References _pcState, and X86ISA::val.
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 509 of file simple_thread.hh.
References _pcState, and X86ISA::val.
Implements ThreadContext.
Definition at line 430 of file simple_thread.hh.
References DPRINTF, isa, ArmISA::NumCCRegs, and readCCRegFlat().
Referenced by CheckerCPU::readCCRegOperand(), Minor::ExecContext::readCCRegOperand(), and SimpleExecContext::readCCRegOperand().
Implements ThreadContext.
Definition at line 658 of file simple_thread.hh.
References ccRegs.
Referenced by readCCReg().
Implements ThreadContext.
Definition at line 281 of file simple_thread.hh.
References DPRINTF, isa, ArmISA::NumFloatRegs, and readFloatRegFlat().
Referenced by Minor::ExecContext::readFloatRegOperandBits(), CheckerCPU::readFloatRegOperandBits(), and SimpleExecContext::readFloatRegOperandBits().
Implements ThreadContext.
Definition at line 584 of file simple_thread.hh.
References floatRegs.
Referenced by readFloatReg().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 571 of file simple_thread.hh.
References ThreadState::readFuncExeInst().
Implements ThreadContext.
Definition at line 270 of file simple_thread.hh.
References DPRINTF, isa, ArmISA::NumIntRegs, and readIntRegFlat().
Referenced by Minor::ExecContext::readIntRegOperand(), CheckerCPU::readIntRegOperand(), and SimpleExecContext::readIntRegOperand().
Flat register interfaces.
Some architectures have different registers visible in different modes. Such architectures "flatten" a register (see flattenRegId()) to map it into the gem5 register file. This interface provides a flat interface to the underlying register file, which allows for example serialization code to access all registers.
Implements ThreadContext.
Definition at line 576 of file simple_thread.hh.
References intRegs.
Referenced by readIntReg().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 240 of file simple_thread.hh.
References ThreadState::readLastActivate().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 245 of file simple_thread.hh.
References ThreadState::readLastSuspend().
| 
 | inline | 
Definition at line 553 of file simple_thread.hh.
References memAccPredicate.
Referenced by Minor::ExecContext::readMemAccPredicate(), CheckerCPU::readMemAccPredicate(), and SimpleExecContext::readMemAccPredicate().
Implements ThreadContext.
Definition at line 527 of file simple_thread.hh.
References isa.
Referenced by Minor::ExecContext::readMiscReg(), CheckerCPU::readMiscReg(), SimpleExecContext::readMiscReg(), Minor::ExecContext::readMiscRegOperand(), SimpleExecContext::readMiscRegOperand(), and CheckerCPU::readMiscRegOperand().
Implements ThreadContext.
Definition at line 521 of file simple_thread.hh.
References isa.
Referenced by Minor::ExecContext::readMiscRegNoEffect(), and CheckerCPU::readMiscRegNoEffect().
| 
 | inline | 
Definition at line 517 of file simple_thread.hh.
References predicate.
Referenced by Minor::ExecContext::readPredicate(), CheckerCPU::readPredicate(), and SimpleExecContext::readPredicate().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 550 of file simple_thread.hh.
References ThreadState::storeCondFailures.
Referenced by CheckerCPU::readStCondFailures(), and SimpleExecContext::readStCondFailures().
| 
 | inlineoverridevirtual | 
Reads source vector 16bit operand.
Implements ThreadContext.
Definition at line 337 of file simple_thread.hh.
References X86ISA::reg.
Referenced by CheckerCPU::readVec16BitLaneOperand(), and Minor::ExecContext::readVec16BitLaneOperand().
| 
 | inlineoverridevirtual | 
Reads source vector 32bit operand.
Implements ThreadContext.
Definition at line 344 of file simple_thread.hh.
References X86ISA::reg.
Referenced by CheckerCPU::readVec32BitLaneOperand(), and Minor::ExecContext::readVec32BitLaneOperand().
| 
 | inlineoverridevirtual | 
Reads source vector 64bit operand.
Implements ThreadContext.
Definition at line 351 of file simple_thread.hh.
References X86ISA::reg.
Referenced by CheckerCPU::readVec64BitLaneOperand(), and Minor::ExecContext::readVec64BitLaneOperand().
| 
 | inlineoverridevirtual | 
Reads source vector 8bit operand.
Implements ThreadContext.
Definition at line 330 of file simple_thread.hh.
References X86ISA::reg.
Referenced by CheckerCPU::readVec8BitLaneOperand(), and Minor::ExecContext::readVec8BitLaneOperand().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 393 of file simple_thread.hh.
References DPRINTF, isa, ArmISA::NumVecRegs, readVecElemFlat(), and X86ISA::reg.
Referenced by Minor::ExecContext::readVecElemOperand(), CheckerCPU::readVecElemOperand(), and SimpleExecContext::readVecElemOperand().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 627 of file simple_thread.hh.
References X86ISA::reg, and vecRegs.
Referenced by readVecElem().
Vector Register Lane Interfaces.
Reads source vector <T> operand.
Definition at line 318 of file simple_thread.hh.
References DPRINTF, isa, ArmISA::NumVecRegs, and X86ISA::reg.
Referenced by SimpleExecContext::readVecLaneOperand().
| 
 | inline | 
Definition at line 614 of file simple_thread.hh.
References X86ISA::reg, and vecRegs.
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 405 of file simple_thread.hh.
References DPRINTF, isa, ArmISA::NumVecPredRegs, readVecPredRegFlat(), and X86ISA::reg.
Referenced by Minor::ExecContext::readVecPredRegOperand(), CheckerCPU::readVecPredRegOperand(), and SimpleExecContext::readVecPredRegOperand().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 640 of file simple_thread.hh.
References X86ISA::reg, and vecPredRegs.
Referenced by readVecPredReg().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 292 of file simple_thread.hh.
References DPRINTF, isa, ArmISA::NumVecRegs, readVecRegFlat(), and X86ISA::reg.
Referenced by Minor::ExecContext::readVecRegOperand(), CheckerCPU::readVecRegOperand(), and SimpleExecContext::readVecRegOperand().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 595 of file simple_thread.hh.
References X86ISA::reg, and vecRegs.
Referenced by readVecReg().
| 
 | inlineoverridevirtual | 
Implements PCEventScope.
Definition at line 178 of file simple_thread.hh.
References ArmISA::e, pcEventQueue, and PCEventQueue::remove().
| 
 | inlineoverridevirtual | 
Implements PCEventScope.
Definition at line 177 of file simple_thread.hh.
References ArmISA::e, pcEventQueue, and PCEventQueue::schedule().
Implements ThreadContext.
Definition at line 181 of file simple_thread.hh.
References comInstEventQueue, X86ISA::count, MipsISA::event, and EventQueue::schedule().
| 
 | overridevirtual | 
Serialize an object.
Output an object's state into the current checkpoint section.
| cp | Checkpoint state | 
Implements Serializable.
Definition at line 120 of file simple_thread.cc.
References ThreadState::serialize().
Referenced by BaseKvmCPU::serializeThread().
Implements ThreadContext.
Definition at line 496 of file simple_thread.hh.
References DPRINTF, isa, ArmISA::NumCCRegs, setCCRegFlat(), and X86ISA::val.
Referenced by CheckerThreadContext< TC >::setCCReg(), CheckerCPU::setCCRegOperand(), Minor::ExecContext::setCCRegOperand(), and SimpleExecContext::setCCRegOperand().
Implements ThreadContext.
Definition at line 659 of file simple_thread.hh.
References ccRegs, and X86ISA::val.
Referenced by setCCReg().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 203 of file simple_thread.hh.
References ThreadState::setContextId().
Referenced by CheckerThreadContext< TC >::setContextId().
Implements ThreadContext.
Definition at line 452 of file simple_thread.hh.
References DPRINTF, isa, ArmISA::NumFloatRegs, setFloatRegFlat(), and X86ISA::val.
Referenced by CheckerThreadContext< TC >::setFloatReg(), Minor::ExecContext::setFloatRegOperandBits(), SimpleExecContext::setFloatRegOperandBits(), and CheckerCPU::setFloatRegOperandBits().
Implements ThreadContext.
Definition at line 589 of file simple_thread.hh.
References floatRegs, and X86ISA::val.
Referenced by setFloatReg().
| 
 | overridevirtual | 
Implements ThreadContext.
Definition at line 195 of file simple_thread.cc.
References _htmCheckpoint.
Implements ThreadContext.
Definition at line 442 of file simple_thread.hh.
References DPRINTF, isa, ArmISA::NumIntRegs, setIntRegFlat(), and X86ISA::val.
Referenced by Minor::ExecContext::ExecContext(), BaseSimpleCPU::preExecute(), CheckerThreadContext< TC >::setIntReg(), Minor::ExecContext::setIntRegOperand(), SimpleExecContext::setIntRegOperand(), and CheckerCPU::setIntRegOperand().
Implements ThreadContext.
Definition at line 578 of file simple_thread.hh.
References intRegs, and X86ISA::val.
Referenced by setIntReg().
| 
 | inline | 
Definition at line 559 of file simple_thread.hh.
References memAccPredicate, and X86ISA::val.
Referenced by Minor::ExecContext::setMemAccPredicate(), CheckerCPU::setMemAccPredicate(), and SimpleExecContext::setMemAccPredicate().
Implements ThreadContext.
Definition at line 539 of file simple_thread.hh.
References isa, and X86ISA::val.
Referenced by Minor::ExecContext::setMiscReg(), CheckerThreadContext< TC >::setMiscReg(), CheckerCPU::setMiscReg(), SimpleExecContext::setMiscReg(), Minor::ExecContext::setMiscRegOperand(), and SimpleExecContext::setMiscRegOperand().
Implements ThreadContext.
Definition at line 533 of file simple_thread.hh.
References isa, and X86ISA::val.
Referenced by CheckerThreadContext< TC >::setMiscRegNoEffect(), and CheckerCPU::setMiscRegNoEffect().
| 
 | inline | 
Definition at line 518 of file simple_thread.hh.
References predicate, and X86ISA::val.
Referenced by Minor::ExecContext::setPredicate(), CheckerCPU::setPredicate(), and SimpleExecContext::setPredicate().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 224 of file simple_thread.hh.
References MipsISA::p, and ThreadState::setProcessPtr().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 228 of file simple_thread.hh.
References ThreadState::_status.
Referenced by MinorCPU::MinorCPU(), and CheckerThreadContext< TC >::setStatus().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 565 of file simple_thread.hh.
References ThreadState::storeCondFailures.
Referenced by SimpleExecContext::setStCondFailures().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 201 of file simple_thread.hh.
References ThreadState::setThreadId().
Referenced by CheckerThreadContext< TC >::setThreadId().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 475 of file simple_thread.hh.
References DPRINTF, isa, ArmISA::NumVecRegs, X86ISA::reg, setVecElemFlat(), and X86ISA::val.
Referenced by CheckerThreadContext< TC >::setVecElem(), Minor::ExecContext::setVecElemOperand(), CheckerCPU::setVecElemOperand(), and SimpleExecContext::setVecElemOperand().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 633 of file simple_thread.hh.
References X86ISA::reg, X86ISA::val, and vecRegs.
Referenced by setVecElem().
| 
 | inlineoverridevirtual | 
Write a lane of the destination vector register.
Implements ThreadContext.
Definition at line 368 of file simple_thread.hh.
References X86ISA::reg, setVecLaneT(), and X86ISA::val.
Referenced by CheckerCPU::setVecLaneOperandT(), Minor::ExecContext::setVecLaneOperandT(), and SimpleExecContext::setVecLaneOperandT().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 385 of file simple_thread.hh.
References X86ISA::reg, setVecLaneT(), and X86ISA::val.
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 379 of file simple_thread.hh.
References X86ISA::reg, setVecLaneT(), and X86ISA::val.
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 373 of file simple_thread.hh.
References X86ISA::reg, setVecLaneT(), and X86ISA::val.
| 
 | inline | 
Definition at line 621 of file simple_thread.hh.
References X86ISA::reg, X86ISA::val, and vecRegs.
Referenced by setVecLaneT().
| 
 | inline | 
Write a lane of the destination vector register.
Definition at line 359 of file simple_thread.hh.
References DPRINTF, isa, ArmISA::NumVecRegs, X86ISA::reg, setVecLaneFlat(), and X86ISA::val.
Referenced by setVecLane().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 485 of file simple_thread.hh.
References DPRINTF, isa, ArmISA::NumVecPredRegs, X86ISA::reg, setVecPredRegFlat(), and X86ISA::val.
Referenced by CheckerThreadContext< TC >::setVecPredReg(), Minor::ExecContext::setVecPredRegOperand(), CheckerCPU::setVecPredRegOperand(), and SimpleExecContext::setVecPredRegOperand().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 652 of file simple_thread.hh.
References X86ISA::reg, X86ISA::val, and vecPredRegs.
Referenced by setVecPredReg().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 465 of file simple_thread.hh.
References DPRINTF, isa, ArmISA::NumVecRegs, X86ISA::reg, setVecRegFlat(), and X86ISA::val.
Referenced by CheckerThreadContext< TC >::setVecReg(), Minor::ExecContext::setVecRegOperand(), SimpleExecContext::setVecRegOperand(), and CheckerCPU::setVecRegOperand().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 607 of file simple_thread.hh.
References X86ISA::reg, X86ISA::val, and vecRegs.
Referenced by setVecReg().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 199 of file simple_thread.hh.
References ThreadState::socketId().
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 226 of file simple_thread.hh.
References ThreadState::_status.
Referenced by activate(), halt(), suspend(), and BaseKvmCPU::wakeup().
| 
 | overridevirtual | 
Set the status to Suspended.
Implements ThreadContext.
Definition at line 146 of file simple_thread.cc.
References ThreadState::_status, ThreadState::_threadId, ThreadState::baseCpu, curTick(), ThreadState::lastActivate, ThreadState::lastSuspend, status(), BaseCPU::suspendContext(), and ThreadContext::Suspended.
Referenced by X86KvmCPU::deliverInterrupts(), and BaseKvmCPU::handleKvmExit().
| 
 | overridevirtual | 
Implements ThreadContext.
Definition at line 95 of file simple_thread.cc.
References decoder, ThreadState::funcExeInst, ThreadContext::getDecoderPtr(), isa, ThreadContext::readFuncExeInst(), and ThreadState::storeCondFailures.
| 
 | inlineoverridevirtual | 
Implements ThreadContext.
Definition at line 200 of file simple_thread.hh.
References ThreadState::threadId().
Referenced by SimpleExecContext::armMonitor(), SimpleExecContext::getAddrMonitor(), SimpleExecContext::mwait(), SimpleExecContext::mwaitAtomic(), and name().
| 
 | overridevirtual | 
Unserialize an object.
Read an object's state from the current checkpoint section.
| cp | Checkpoint state | 
Implements Serializable.
Definition at line 128 of file simple_thread.cc.
References ThreadState::unserialize().
Referenced by BaseKvmCPU::unserializeThread().
| 
 | protected | 
Definition at line 107 of file simple_thread.hh.
Referenced by getHtmCheckpointPtr(), and setHtmCheckpointPtr().
| 
 | protected | 
Definition at line 104 of file simple_thread.hh.
Referenced by clearArchRegs(), instAddr(), microPC(), nextInstAddr(), pcState(), and pcStateNoRecord().
| 
 | protected | 
Definition at line 101 of file simple_thread.hh.
Referenced by clearArchRegs(), readCCRegFlat(), and setCCRegFlat().
| EventQueue SimpleThread::comInstEventQueue | 
An instruction-based event queue.
Used for scheduling events based on number of instructions committed.
Definition at line 126 of file simple_thread.hh.
Referenced by descheduleInstCountEvent(), Minor::Execute::doInstCommitAccounting(), getCurrentInstCount(), BaseSimpleCPU::preExecute(), scheduleInstCountEvent(), BaseKvmCPU::setupInstStop(), and BaseKvmCPU::tick().
| TheISA::Decoder SimpleThread::decoder | 
Definition at line 132 of file simple_thread.hh.
Referenced by BaseSimpleCPU::advancePC(), BaseSimpleCPU::checkForInterrupts(), getDecoderPtr(), BaseSimpleCPU::preExecute(), and takeOverFrom().
| 
 | protected | 
Definition at line 96 of file simple_thread.hh.
Referenced by clearArchRegs(), readFloatRegFlat(), and setFloatRegFlat().
| int64_t SimpleThread::htmTransactionStarts | 
Definition at line 135 of file simple_thread.hh.
Referenced by TimingSimpleCPU::completeIfetch(), SimpleExecContext::getHtmTransactionalDepth(), and htmAbortTransaction().
| int64_t SimpleThread::htmTransactionStops | 
Definition at line 136 of file simple_thread.hh.
Referenced by TimingSimpleCPU::completeDataAccess(), SimpleExecContext::getHtmTransactionalDepth(), and htmAbortTransaction().
| 
 | protected | 
Definition at line 97 of file simple_thread.hh.
Referenced by clearArchRegs(), readIntRegFlat(), and setIntRegFlat().
| 
 | protected | 
Definition at line 102 of file simple_thread.hh.
Referenced by clearArchRegs(), flattenRegId(), getIsaPtr(), getWritableVecPredReg(), getWritableVecReg(), readCCReg(), readFloatReg(), readIntReg(), readMiscReg(), readMiscRegNoEffect(), readVecElem(), readVecLane(), readVecPredReg(), readVecReg(), setCCReg(), setFloatReg(), setIntReg(), setMiscReg(), setMiscRegNoEffect(), setVecElem(), setVecLaneT(), setVecPredReg(), setVecReg(), SimpleThread(), and takeOverFrom().
| 
 | protected | 
True if the memory access should be skipped for this instruction.
Definition at line 113 of file simple_thread.hh.
Referenced by readMemAccPredicate(), and setMemAccPredicate().
| BaseMMU* SimpleThread::mmu | 
Definition at line 130 of file simple_thread.hh.
Referenced by AtomicSimpleCPU::amoMem(), demapPage(), TimingSimpleCPU::fetch(), getMMUPtr(), TimingSimpleCPU::initiateMemAMO(), TimingSimpleCPU::initiateMemRead(), Minor::ExecContext::mwaitAtomic(), CheckerCPU::mwaitAtomic(), SimpleExecContext::mwaitAtomic(), AtomicSimpleCPU::readMem(), AtomicSimpleCPU::tick(), AtomicSimpleCPU::writeMem(), and TimingSimpleCPU::writeMem().
| PCEventQueue SimpleThread::pcEventQueue | 
Definition at line 121 of file simple_thread.hh.
Referenced by remove(), and schedule().
| 
 | protected | 
Did this instruction execute or is it predicated false.
Definition at line 110 of file simple_thread.hh.
Referenced by readPredicate(), and setPredicate().
| System* SimpleThread::system | 
Definition at line 128 of file simple_thread.hh.
Referenced by getSystemPtr().
| 
 | protected | 
Definition at line 100 of file simple_thread.hh.
Referenced by clearArchRegs(), getWritableVecPredRegFlat(), readVecPredRegFlat(), and setVecPredRegFlat().
| 
 | protected | 
Definition at line 98 of file simple_thread.hh.
Referenced by clearArchRegs(), getWritableVecRegFlat(), readVecElemFlat(), readVecLaneFlat(), readVecRegFlat(), setVecElemFlat(), setVecLaneFlat(), and setVecRegFlat().