gem5
v20.0.0.0
|
Derived ThreadContext class for use with the O3CPU. More...
#include <cpu.hh>
Public Types | |
typedef Impl::O3CPU | O3CPU |
![]() | |
enum | Status { Active, Suspended, Halting, Halted } |
Public Member Functions | |
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 |
BaseTLB * | getITBPtr () override |
Returns a pointer to the ITB. More... | |
BaseTLB * | getDTBPtr () override |
Returns a pointer to the DTB. More... | |
CheckerCPU * | getCheckerCpuPtr () override |
BaseISA * | getIsaPtr () override |
TheISA::Decoder * | getDecoderPtr () override |
BaseCPU * | getCpuPtr () override |
Returns a pointer to this CPU. More... | |
int | cpuId () const override |
Reads this CPU's ID. More... | |
uint32_t | socketId () const override |
Reads this CPU's Socket ID. More... | |
ContextID | contextId () const override |
void | setContextId (ContextID id) override |
int | threadId () const override |
Returns this thread's ID number. More... | |
void | setThreadId (int id) override |
System * | getSystemPtr () override |
Returns a pointer to the system. More... | |
::Kernel::Statistics * | getKernelStats () override |
Returns a pointer to this thread's kernel statistics. More... | |
Process * | getProcessPtr () override |
Returns a pointer to this thread's process. More... | |
void | setProcessPtr (Process *p) 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... | |
Status | status () const override |
Returns this thread's status. More... | |
void | setStatus (Status new_status) override |
Sets this thread's status. More... | |
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... | |
void | dumpFuncProfile () override |
Dumps the function profiling information. More... | |
void | takeOverFrom (ThreadContext *old_context) override |
Takes over execution of a thread from another CPU. More... | |
void | regStats (const std::string &name) override |
Registers statistics associated with this TC. More... | |
Tick | readLastActivate () override |
Reads the last tick that this thread was activated on. More... | |
Tick | readLastSuspend () override |
Reads the last tick that this thread was suspended on. More... | |
void | profileClear () override |
Clears the function profiling information. More... | |
void | profileSample () override |
Samples the function profiling information. More... | |
void | copyArchRegs (ThreadContext *tc) override |
Copies the architectural registers from another TC into this TC. More... | |
void | clearArchRegs () override |
Resets all architectural registers to 0. More... | |
RegVal | readReg (RegIndex reg_idx) |
Reads an integer register. More... | |
RegVal | readIntReg (RegIndex reg_idx) const override |
RegVal | readFloatReg (RegIndex reg_idx) const override |
const VecRegContainer & | readVecReg (const RegId &id) const override |
VecRegContainer & | getWritableVecReg (const RegId &id) override |
Read vector register operand for modification, hierarchical indexing. More... | |
const VecElem & | readVecElem (const RegId ®) const override |
const VecPredRegContainer & | readVecPredReg (const RegId &id) const override |
VecPredRegContainer & | getWritableVecPredReg (const RegId &id) override |
RegVal | readCCReg (RegIndex reg_idx) const override |
void | setIntReg (RegIndex reg_idx, RegVal val) override |
Sets an integer register to a value. More... | |
void | setFloatReg (RegIndex reg_idx, RegVal val) override |
void | setVecReg (const RegId ®, const VecRegContainer &val) override |
void | setVecElem (const RegId ®, const VecElem &val) override |
void | setVecPredReg (const RegId ®, const VecPredRegContainer &val) override |
void | setCCReg (RegIndex reg_idx, RegVal val) override |
TheISA::PCState | pcState () const override |
Reads this thread's PC state. More... | |
void | pcState (const TheISA::PCState &val) override |
Sets this thread's PC state. More... | |
void | pcStateNoRecord (const TheISA::PCState &val) override |
Addr | instAddr () const override |
Reads this thread's PC. More... | |
Addr | nextInstAddr () const override |
Reads this thread's next PC. More... | |
MicroPC | microPC () const override |
Reads this thread's next PC. More... | |
RegVal | readMiscRegNoEffect (RegIndex misc_reg) const override |
Reads a miscellaneous register. More... | |
RegVal | readMiscReg (RegIndex misc_reg) override |
Reads a misc. More... | |
void | setMiscRegNoEffect (RegIndex misc_reg, RegVal val) override |
Sets a misc. More... | |
void | setMiscReg (RegIndex misc_reg, RegVal val) override |
Sets a misc. More... | |
RegId | flattenRegId (const RegId ®Id) const override |
unsigned | readStCondFailures () const override |
Returns the number of consecutive store conditional failures. More... | |
void | setStCondFailures (unsigned sc_failures) override |
Sets the number of consecutive store conditional failures. More... | |
void | syscall (Fault *fault) override |
Executes a syscall in SE mode. More... | |
Counter | readFuncExeInst () const override |
Reads the funcExeInst counter. More... | |
EndQuiesceEvent * | getQuiesceEvent () override |
Returns pointer to the quiesce event. More... | |
void | conditionalSquash () |
check if the cpu is currently in state update mode and squash if not. More... | |
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 VecRegContainer & | readVecRegFlat (RegIndex idx) const override |
VecRegContainer & | getWritableVecRegFlat (RegIndex idx) override |
Read vector register operand for modification, flat indexing. More... | |
void | setVecRegFlat (RegIndex idx, const VecRegContainer &val) override |
template<typename VecElem > | |
VecLaneT< VecElem, true > | readVecLaneFlat (RegIndex idx, int lId) const |
template<typename LD > | |
void | setVecLaneFlat (int idx, int lId, const LD &val) |
const VecElem & | readVecElemFlat (RegIndex idx, const ElemIndex &elemIndex) const override |
void | setVecElemFlat (RegIndex idx, const ElemIndex &elemIdx, const VecElem &val) override |
const VecPredRegContainer & | readVecPredRegFlat (RegIndex idx) const override |
VecPredRegContainer & | getWritableVecPredRegFlat (RegIndex idx) override |
void | setVecPredRegFlat (RegIndex idx, const VecPredRegContainer &val) override |
RegVal | readCCRegFlat (RegIndex idx) const override |
void | setCCRegFlat (RegIndex idx, RegVal val) override |
ConstVecLane8 | readVec8BitLaneReg (const RegId &id) const override |
Vector Register Lane Interfaces. More... | |
ConstVecLane16 | readVec16BitLaneReg (const RegId &id) const override |
Reads source vector 16bit operand. More... | |
ConstVecLane32 | readVec32BitLaneReg (const RegId &id) const override |
Reads source vector 32bit operand. More... | |
ConstVecLane64 | readVec64BitLaneReg (const RegId &id) const override |
Reads source vector 64bit operand. More... | |
void | setVecLane (const RegId ®, const LaneData< LaneSize::Byte > &val) override |
Write a lane of the destination vector register. More... | |
void | setVecLane (const RegId ®, const LaneData< LaneSize::TwoByte > &val) override |
void | setVecLane (const RegId ®, const LaneData< LaneSize::FourByte > &val) override |
void | setVecLane (const RegId ®, const LaneData< LaneSize::EightByte > &val) override |
![]() | |
virtual | ~ThreadContext () |
void | quiesce () |
Quiesce thread context. More... | |
void | quiesceTick (Tick resume) |
Quiesce, suspend, and schedule activate at resume. More... | |
void | setNPC (Addr val) |
virtual int | exit () |
Public Attributes | |
O3CPU * | cpu |
Pointer to the CPU. More... | |
O3ThreadState< Impl > * | thread |
Pointer to the thread state that this TC corrseponds to. More... | |
![]() | |
int | intResult = DefaultIntResult |
double | floatResult = DefaultFloatResult |
int | intOffset = 0 |
Additional Inherited Members | |
![]() | |
static void | compare (ThreadContext *one, ThreadContext *two) |
function to compare two thread contexts (for debugging) More... | |
![]() | |
static const int | ints [] |
static const double | floats [] |
static const int | DefaultIntResult = 0 |
static const double | DefaultFloatResult = 0.0 |
![]() | |
typedef TheISA::MachInst | MachInst |
using | VecRegContainer = TheISA::VecRegContainer |
using | VecElem = TheISA::VecElem |
using | VecPredRegContainer = TheISA::VecPredRegContainer |
Derived ThreadContext class for use with the O3CPU.
It provides the interface for any external objects to access a single thread's state and some general CPU state. Any time external objects try to update state through this interface, the CPU will create an event to squash all in-flight instructions in order to ensure state is maintained correctly. It must be defined specifically for the O3CPU because not all architectural state is located within the O3ThreadState (such as the commit PC, and registers), and specific actions must be taken when using this interface (such as squashing all in-flight instructions when doing a write to this interface).
typedef Impl::O3CPU O3ThreadContext< Impl >::O3CPU |
Definition at line 71 of file thread_context.hh.
|
overridevirtual |
Set the status to Active.
Implements ThreadContext.
Definition at line 88 of file thread_context_impl.hh.
References ThreadContext::Active, curTick(), and DPRINTF.
|
overridevirtual |
Resets all architectural registers to 0.
Implements ThreadContext.
Definition at line 201 of file thread_context_impl.hh.
|
inline |
check if the cpu is currently in state update mode and squash if not.
This function will return true if a trap is pending or if a fault or similar is currently writing to the thread context and doesn't want reset all the state (see noSquashFromTC).
Definition at line 469 of file thread_context.hh.
References O3ThreadState< Impl >::noSquashFromTC, ThreadState::threadId(), and O3ThreadState< Impl >::trapPending.
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 135 of file thread_context.hh.
References ThreadState::contextId().
|
overridevirtual |
Copies the architectural registers from another TC into this TC.
Implements ThreadContext.
Definition at line 185 of file thread_context_impl.hh.
References ArmISA::copyRegs(), FullSystem, ThreadContext::pcState(), and ThreadContext::readFuncExeInst().
|
inlineoverridevirtual |
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 93 of file thread_context.hh.
|
overridevirtual |
Dumps the function profiling information.
Implements ThreadContext.
Definition at line 62 of file thread_context_impl.hh.
|
overridevirtual |
Implements ThreadContext.
Definition at line 339 of file thread_context_impl.hh.
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 112 of file thread_context.hh.
|
inlineoverridevirtual |
Returns a pointer to this CPU.
Implements ThreadContext.
Definition at line 127 of file thread_context.hh.
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 98 of file thread_context.hh.
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 121 of file thread_context.hh.
References ThreadState::threadId().
|
inlineoverridevirtual |
Returns a pointer to the DTB.
Implements ThreadContext.
Definition at line 110 of file thread_context.hh.
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 115 of file thread_context.hh.
References ThreadState::threadId().
|
inlineoverridevirtual |
Returns a pointer to the ITB.
Implements ThreadContext.
Definition at line 107 of file thread_context.hh.
|
inlineoverridevirtual |
Returns a pointer to this thread's kernel statistics.
Implements ThreadContext.
Definition at line 148 of file thread_context.hh.
References ThreadState::kernelStats.
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 158 of file thread_context.hh.
References ThreadState::getPhysProxy().
|
inlineoverridevirtual |
Returns a pointer to this thread's process.
Implements ThreadContext.
Definition at line 154 of file thread_context.hh.
References ThreadState::getProcessPtr().
|
inlineoverridevirtual |
Returns pointer to the quiesce event.
Implements ThreadContext.
Definition at line 459 of file thread_context.hh.
References ThreadState::quiesceEvent.
|
inlineoverridevirtual |
Returns a pointer to the system.
Implements ThreadContext.
Definition at line 144 of file thread_context.hh.
|
overridevirtual |
Implements ThreadContext.
Definition at line 55 of file thread_context_impl.hh.
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 324 of file thread_context.hh.
References MipsISA::index.
Referenced by FullO3CPU< O3CPUImpl >::setVecLane().
|
overridevirtual |
Implements ThreadContext.
Definition at line 251 of file thread_context_impl.hh.
|
inlineoverridevirtual |
Read vector register operand for modification, hierarchical indexing.
Implements ThreadContext.
Definition at line 245 of file thread_context.hh.
References MipsISA::index.
Referenced by FullO3CPU< O3CPUImpl >::halt().
|
overridevirtual |
Read vector register operand for modification, flat indexing.
Implements ThreadContext.
Definition at line 229 of file thread_context_impl.hh.
|
overridevirtual |
Set the status to Halted.
Implements ThreadContext.
Definition at line 127 of file thread_context_impl.hh.
References DPRINTF, ThreadContext::Halted, and ThreadContext::Halting.
|
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 163 of file thread_context.hh.
References ThreadState::initMemProxies().
|
inlineoverridevirtual |
Reads this thread's PC.
Implements ThreadContext.
Definition at line 389 of file thread_context.hh.
References ThreadState::threadId().
Referenced by FullO3CPU< O3CPUImpl >::setArchVecLane().
|
inlineoverridevirtual |
Reads this thread's next PC.
Implements ThreadContext.
Definition at line 403 of file thread_context.hh.
References ThreadState::threadId().
Referenced by FullO3CPU< O3CPUImpl >::setArchVecLane().
|
inlineoverridevirtual |
Reads this thread's next PC.
Implements ThreadContext.
Definition at line 396 of file thread_context.hh.
References ThreadState::threadId().
Referenced by FullO3CPU< O3CPUImpl >::setArchVecLane().
|
inlineoverridevirtual |
Reads this thread's PC state.
Implements ThreadContext.
Definition at line 377 of file thread_context.hh.
References ThreadState::threadId(), and X86ISA::val.
Referenced by FullO3CPU< O3CPUImpl >::setArchVecLane().
|
overridevirtual |
Sets this thread's PC state.
Implements ThreadContext.
Definition at line 321 of file thread_context_impl.hh.
|
overridevirtual |
Implements ThreadContext.
Definition at line 330 of file thread_context_impl.hh.
|
overridevirtual |
Clears the function profiling information.
Implements ThreadContext.
Definition at line 171 of file thread_context_impl.hh.
|
overridevirtual |
Samples the function profiling information.
Implements ThreadContext.
Definition at line 178 of file thread_context_impl.hh.
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 330 of file thread_context.hh.
References CCRegClass, and MipsISA::index.
Referenced by FullO3CPU< O3CPUImpl >::setVecLane().
|
overridevirtual |
Implements ThreadContext.
Definition at line 258 of file thread_context_impl.hh.
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 229 of file thread_context.hh.
References FloatRegClass, and MipsISA::index.
Referenced by FullO3CPU< O3CPUImpl >::halt().
|
overridevirtual |
Implements ThreadContext.
Definition at line 215 of file thread_context_impl.hh.
|
inlineoverridevirtual |
Reads the funcExeInst counter.
Implements ThreadContext.
Definition at line 455 of file thread_context.hh.
References ThreadState::funcExeInst.
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 222 of file thread_context.hh.
References MipsISA::index, and IntRegClass.
Referenced by FullO3CPU< O3CPUImpl >::halt().
|
overridevirtual |
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 208 of file thread_context_impl.hh.
|
overridevirtual |
Reads the last tick that this thread was activated on.
Implements ThreadContext.
Definition at line 157 of file thread_context_impl.hh.
|
overridevirtual |
Reads the last tick that this thread was suspended on.
Implements ThreadContext.
Definition at line 164 of file thread_context_impl.hh.
|
inlineoverridevirtual |
Reads a misc.
register, including any side-effects the read might have as defined by the architecture.
Implements ThreadContext.
Definition at line 418 of file thread_context.hh.
References ThreadState::threadId().
Referenced by FullO3CPU< O3CPUImpl >::halt().
|
inlineoverridevirtual |
Reads a miscellaneous register.
Implements ThreadContext.
Definition at line 410 of file thread_context.hh.
References ThreadState::threadId().
Referenced by FullO3CPU< O3CPUImpl >::halt().
|
inline |
Reads an integer register.
Definition at line 216 of file thread_context.hh.
References MipsISA::index, and IntRegClass.
|
inlineoverridevirtual |
Returns the number of consecutive store conditional failures.
Implements ThreadContext.
Definition at line 435 of file thread_context.hh.
References ThreadState::storeCondFailures.
|
inlineoverridevirtual |
Reads source vector 16bit operand.
Implements ThreadContext.
Definition at line 262 of file thread_context.hh.
|
inlineoverridevirtual |
Reads source vector 32bit operand.
Implements ThreadContext.
Definition at line 270 of file thread_context.hh.
|
inlineoverridevirtual |
Reads source vector 64bit operand.
Implements ThreadContext.
Definition at line 278 of file thread_context.hh.
|
inlineoverridevirtual |
Vector Register Lane Interfaces.
Reads source vector 8bit operand.
Implements ThreadContext.
Definition at line 254 of file thread_context.hh.
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 312 of file thread_context.hh.
References RegId::elemIndex(), and MipsISA::index.
|
overridevirtual |
Implements ThreadContext.
Definition at line 236 of file thread_context_impl.hh.
|
inline |
Definition at line 488 of file thread_context.hh.
References ThreadState::threadId().
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 318 of file thread_context.hh.
References MipsISA::index.
Referenced by FullO3CPU< O3CPUImpl >::setVecLane().
|
overridevirtual |
Implements ThreadContext.
Definition at line 244 of file thread_context_impl.hh.
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 236 of file thread_context.hh.
References MipsISA::index.
|
overridevirtual |
Implements ThreadContext.
Definition at line 222 of file thread_context_impl.hh.
|
overridevirtual |
Registers statistics associated with this TC.
Implements ThreadContext.
Definition at line 147 of file thread_context_impl.hh.
References FullSystem.
|
inlineoverridevirtual |
|
inlineoverridevirtual |
Implements PCEventScope.
Definition at line 77 of file thread_context.hh.
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 88 of file thread_context.hh.
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 370 of file thread_context.hh.
References CCRegClass, and MipsISA::index.
Referenced by FullO3CPU< O3CPUImpl >::setVecLane().
|
overridevirtual |
Implements ThreadContext.
Definition at line 312 of file thread_context_impl.hh.
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 137 of file thread_context.hh.
References ThreadState::setContextId().
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 344 of file thread_context.hh.
References FloatRegClass, and MipsISA::index.
Referenced by FullO3CPU< O3CPUImpl >::setVecLane().
|
overridevirtual |
Implements ThreadContext.
Definition at line 274 of file thread_context_impl.hh.
|
inlineoverridevirtual |
Sets an integer register to a value.
Implements ThreadContext.
Definition at line 338 of file thread_context.hh.
References MipsISA::index, and IntRegClass.
Referenced by FullO3CPU< O3CPUImpl >::setVecLane().
|
overridevirtual |
Implements ThreadContext.
Definition at line 265 of file thread_context_impl.hh.
|
overridevirtual |
Sets a misc.
register, including any side-effects the write might have as defined by the architecture.
Implements ThreadContext.
Definition at line 355 of file thread_context_impl.hh.
Referenced by FullO3CPU< O3CPUImpl >::halt().
|
overridevirtual |
Sets a misc.
register.
Implements ThreadContext.
Definition at line 346 of file thread_context_impl.hh.
Referenced by FullO3CPU< O3CPUImpl >::halt().
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 156 of file thread_context.hh.
References ThreadState::setProcessPtr().
|
inlineoverridevirtual |
Sets this thread's status.
Implements ThreadContext.
Definition at line 173 of file thread_context.hh.
References MipsISA::halt, name(), ThreadState::setStatus(), and takeOverFrom().
|
inlineoverridevirtual |
Sets the number of consecutive store conditional failures.
Implements ThreadContext.
Definition at line 442 of file thread_context.hh.
References ThreadState::storeCondFailures.
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 141 of file thread_context.hh.
References ThreadState::setThreadId().
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 357 of file thread_context.hh.
References RegId::elemIndex(), MipsISA::index, and X86ISA::val.
Referenced by FullO3CPU< O3CPUImpl >::setVecLane().
|
overridevirtual |
Implements ThreadContext.
Definition at line 293 of file thread_context_impl.hh.
|
inlineoverridevirtual |
Write a lane of the destination vector register.
Implements ThreadContext.
Definition at line 286 of file thread_context.hh.
References RegId::elemIndex(), MipsISA::index, and X86ISA::val.
Referenced by FullO3CPU< O3CPUImpl >::setArchVecLane().
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 292 of file thread_context.hh.
References RegId::elemIndex(), MipsISA::index, and X86ISA::val.
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 298 of file thread_context.hh.
References RegId::elemIndex(), MipsISA::index, and X86ISA::val.
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 304 of file thread_context.hh.
References RegId::elemIndex(), MipsISA::index, and X86ISA::val.
|
inline |
Definition at line 496 of file thread_context.hh.
References ThreadState::threadId(), and X86ISA::val.
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 363 of file thread_context.hh.
References MipsISA::index.
Referenced by FullO3CPU< O3CPUImpl >::setVecLane().
|
overridevirtual |
Implements ThreadContext.
Definition at line 302 of file thread_context_impl.hh.
|
inlineoverridevirtual |
Implements ThreadContext.
Definition at line 351 of file thread_context.hh.
References MipsISA::index.
|
overridevirtual |
Implements ThreadContext.
Definition at line 283 of file thread_context_impl.hh.
|
inlineoverridevirtual |
Reads this CPU's Socket ID.
Implements ThreadContext.
Definition at line 133 of file thread_context.hh.
|
inlineoverridevirtual |
Returns this thread's status.
Implements ThreadContext.
Definition at line 169 of file thread_context.hh.
References ThreadState::status().
|
overridevirtual |
Set the status to Suspended.
Implements ThreadContext.
Definition at line 105 of file thread_context_impl.hh.
References curTick(), DPRINTF, and ThreadContext::Suspended.
|
inlineoverridevirtual |
Executes a syscall in SE mode.
Implements ThreadContext.
Definition at line 449 of file thread_context.hh.
References ThreadState::threadId().
Referenced by FullO3CPU< O3CPUImpl >::isDraining().
|
overridevirtual |
Takes over execution of a thread from another CPU.
Implements ThreadContext.
Definition at line 69 of file thread_context_impl.hh.
References ThreadContext::getDecoderPtr(), ThreadContext::getKernelStats(), ThreadContext::readFuncExeInst(), and takeOverFrom().
|
inlineoverridevirtual |
Returns this thread's ID number.
Implements ThreadContext.
Definition at line 140 of file thread_context.hh.
References ThreadState::threadId().
O3CPU* O3ThreadContext< Impl >::cpu |
Pointer to the CPU.
Definition at line 74 of file thread_context.hh.
Referenced by FullO3CPU< O3CPUImpl >::FullO3CPU().
O3ThreadState<Impl>* O3ThreadContext< Impl >::thread |
Pointer to the thread state that this TC corrseponds to.
Definition at line 104 of file thread_context.hh.
Referenced by FullO3CPU< O3CPUImpl >::FullO3CPU(), and FullO3CPU< O3CPUImpl >::tcBase().