Go to the documentation of this file.
   50 #include "config/the_isa.hh" 
   56 #include "params/BaseCPU.hh" 
   72       isa(dynamic_cast<TheISA::
ISA *>(_isa)),
 
   73       predicate(true), memAccPredicate(true),
 
   74       comInstEventQueue(
"instruction-based event queue"),
 
   76       htmTransactionStarts(0), htmTransactionStops(0)
 
   79     const auto ®Classes = 
isa->regClasses();
 
   90     : 
SimpleThread(_cpu, _thread_num, _sys, nullptr, _mmu, _isa)
 
   99     isa->takeOverFrom(
this, oldContext);
 
  175     assert(baseSimpleCpu);
 
  
Tick curTick()
The universal simulation clock.
void unserialize(ThreadContext &tc, CheckpointIn &cp)
@ CCRegClass
Condition-code register.
std::unique_ptr< BaseHTMCheckpoint > BaseHTMCheckpointPtr
int64_t htmTransactionStops
virtual void copyRegsFrom(ThreadContext *src)=0
@ Halted
Permanently shut down.
Struct for holding general thread state that is needed across CPU models.
void copyArchRegs(ThreadContext *tc) override
@ FloatRegClass
Floating-point register.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
void serialize(CheckpointOut &cp) const override
Serialize an object.
virtual ContextID contextId() const =0
SimpleThread(BaseCPU *_cpu, int _thread_num, System *_system, BaseMMU *_mmu, BaseISA *_isa)
void clearArchRegs() override
std::unique_ptr< BaseHTMCheckpoint > _htmCheckpoint
void activate() override
Set the status to Active.
int64_t htmTransactionStarts
The SimpleThread object provides a combination of the ThreadState object and the ThreadContext interf...
virtual TheISA::Decoder * getDecoderPtr()=0
void takeOverFrom(ThreadContext &ntc, ThreadContext &otc)
Copy state between thread contexts in preparation for CPU handover.
virtual Status status() const =0
virtual void htmSendAbortSignal(HtmFailureFaultCause cause)=0
This function is used to instruct the memory subsystem that a transaction should be aborted and the s...
void htmAbortTransaction(uint64_t htm_uid, HtmFailureFaultCause cause) override
Tick lastSuspend
Last time suspend was called on this thread.
virtual void suspendContext(ThreadID thread_num)
Notify the CPU that the indicated context is now suspended.
void copyState(ThreadContext *oldContext)
ThreadContext is the external interface to all thread state for anything outside of the CPU.
void setHtmCheckpointPtr(BaseHTMCheckpointPtr new_cpt) override
@ Suspended
Temporarily inactive.
unsigned storeCondFailures
virtual void haltContext(ThreadID thread_num)
Notify the CPU that the indicated context is now halted.
BaseISA * getIsaPtr() override
void takeOverFrom(ThreadContext *oldContext) override
std::vector< RegVal > floatRegs
void serialize(const ThreadContext &tc, CheckpointOut &cp)
Thread context serialization helpers.
void halt() override
Set the status to Halted.
BaseHTMCheckpointPtr & getHtmCheckpointPtr() override
std::vector< RegVal > ccRegs
Tick lastActivate
Last time activate was called on this thread.
@ VecRegClass
Vector Register.
virtual void activateContext(ThreadID thread_num)
Notify the CPU that the indicated context is now active.
void suspend() override
Set the status to Suspended.
ThreadContext::Status _status
std::vector< TheISA::VecPredRegContainer > vecPredRegs
std::vector< TheISA::VecRegContainer > vecRegs
std::ostream CheckpointOut
virtual int threadId() const =0
@ IntRegClass
Integer register.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
std::vector< RegVal > intRegs
Status status() const override
void serialize(CheckpointOut &cp) const override
Serialize an object.
Generated on Tue Sep 21 2021 12:25:08 for gem5 by  doxygen 1.8.17