|
gem5
v20.1.0.5
|
#include <exetrace.hh>
Public Member Functions | |
| ExeTracerRecord (Tick _when, ThreadContext *_thread, const StaticInstPtr _staticInst, TheISA::PCState _pc, const StaticInstPtr _macroStaticInst=NULL) | |
| void | traceInst (const StaticInstPtr &inst, bool ran) |
| void | dump () |
Public Member Functions inherited from Trace::InstRecord | |
| InstRecord (Tick _when, ThreadContext *_thread, const StaticInstPtr _staticInst, TheISA::PCState _pc, const StaticInstPtr _macroStaticInst=NULL) | |
| virtual | ~InstRecord () |
| void | setWhen (Tick new_when) |
| void | setMem (Addr a, Addr s, unsigned f) |
| template<typename T , size_t N> | |
| void | setData (std::array< T, N > d) |
| void | setData (uint64_t d) |
| void | setData (uint32_t d) |
| void | setData (uint16_t d) |
| void | setData (uint8_t d) |
| void | setData (int64_t d) |
| void | setData (int32_t d) |
| void | setData (int16_t d) |
| void | setData (int8_t d) |
| void | setData (double d) |
| void | setData (::VecRegContainer< TheISA::VecRegSizeBytes > &d) |
| void | setData (::VecPredRegContainer< TheISA::VecPredRegSizeBits, TheISA::VecPredRegHasPackedRepr > &d) |
| void | setFetchSeq (InstSeqNum seq) |
| void | setCPSeq (InstSeqNum seq) |
| void | setPredicate (bool val) |
| void | setFaulting (bool val) |
| Tick | getWhen () const |
| ThreadContext * | getThread () const |
| StaticInstPtr | getStaticInst () const |
| TheISA::PCState | getPCState () const |
| StaticInstPtr | getMacroStaticInst () const |
| Addr | getAddr () const |
| Addr | getSize () const |
| unsigned | getFlags () const |
| bool | getMemValid () const |
| uint64_t | getIntData () const |
| double | getFloatData () const |
| int | getDataStatus () const |
| InstSeqNum | getFetchSeq () const |
| bool | getFetchSeqValid () const |
| InstSeqNum | getCpSeq () const |
| bool | getCpSeqValid () const |
| bool | getFaulting () const |
Additional Inherited Members | |
Protected Types inherited from Trace::InstRecord | |
| enum | DataStatus { DataInvalid = 0, DataInt8 = 1, DataInt16 = 2, DataInt32 = 4, DataInt64 = 8, DataDouble = 3, DataVec = 5, DataVecPred = 6 } |
Protected Attributes inherited from Trace::InstRecord | |
| Tick | when |
| ThreadContext * | thread |
| StaticInstPtr | staticInst |
| TheISA::PCState | pc |
| StaticInstPtr | macroStaticInst |
| Addr | addr |
| The address that was accessed. More... | |
| Addr | size |
| The size of the memory request. More... | |
| unsigned | flags |
| The flags that were assigned to the request. More... | |
| union { | |
| uint64_t as_int | |
| double as_double | |
| ::VecRegContainer< TheISA::VecRegSizeBytes > * as_vec | |
| ::VecPredRegContainer< TheISA::VecPredRegSizeBits, TheISA::VecPredRegHasPackedRepr > * as_pred | |
| } | data |
| InstSeqNum | fetch_seq |
| InstSeqNum | cp_seq |
| enum Trace::InstRecord::DataStatus | data_status |
| bool | mem_valid |
| bool | fetch_seq_valid |
| bool | cp_seq_valid |
| bool | predicate |
| is the predicate for execution this inst true or false (not execed)? More... | |
| bool | faulting |
| Did the execution of this instruction fault? (requires ExecFaulting to be enabled) More... | |
Definition at line 44 of file exetrace.hh.
|
inline |
Definition at line 47 of file exetrace.hh.
|
virtual |
Implements Trace::InstRecord.
Reimplemented in Trace::NativeTraceRecord.
Definition at line 180 of file exetrace.cc.
| void Trace::ExeTracerRecord::traceInst | ( | const StaticInstPtr & | inst, |
| bool | ran | ||
| ) |
Definition at line 62 of file exetrace.cc.
References addr, ccprintf(), data, Loader::debugSymbolTable, StaticInst::disassemble(), Trace::Logger::dprintf_flag(), FullSystem, Trace::getDebugLogger(), ArmISA::getExecutingAsid(), ArmISA::i, ArmISA::inUserMode(), StaticInst::isMicroop(), StaticInst::opClass(), MipsISA::pc, StaticInst::printFlags(), ArmISA::VecPredRegSizeBits, and ArmISA::VecRegSizeBytes.
Referenced by Trace::ArmNativeTrace::check().