gem5
v21.0.0.0
|
Namespaces | |
InitParamKey | |
Unique keys to retrieve various params by the initParam pseudo inst. | |
Functions | |
void | arm (ThreadContext *tc) |
void | quiesce (ThreadContext *tc) |
void | quiesceSkip (ThreadContext *tc) |
void | quiesceNs (ThreadContext *tc, uint64_t ns) |
void | quiesceCycles (ThreadContext *tc, uint64_t cycles) |
uint64_t | quiesceTime (ThreadContext *tc) |
uint64_t | rpns (ThreadContext *tc) |
void | wakeCPU (ThreadContext *tc, uint64_t cpuid) |
void | m5exit (ThreadContext *tc, Tick delay) |
uint64_t | m5sum (ThreadContext *tc, uint64_t a, uint64_t b, uint64_t c, uint64_t d, uint64_t e, uint64_t f) |
void | m5fail (ThreadContext *tc, Tick delay, uint64_t code) |
void | loadsymbol (ThreadContext *tc) |
void | addsymbol (ThreadContext *tc, Addr addr, Addr symbolAddr) |
uint64_t | initParam (ThreadContext *tc, uint64_t key_str1, uint64_t key_str2) |
void | resetstats (ThreadContext *tc, Tick delay, Tick period) |
void | dumpstats (ThreadContext *tc, Tick delay, Tick period) |
void | dumpresetstats (ThreadContext *tc, Tick delay, Tick period) |
void | m5checkpoint (ThreadContext *tc, Tick delay, Tick period) |
uint64_t | readfile (ThreadContext *tc, Addr vaddr, uint64_t len, uint64_t offset) |
uint64_t | writefile (ThreadContext *tc, Addr vaddr, uint64_t len, uint64_t offset, Addr filename_addr) |
void | debugbreak (ThreadContext *tc) |
void | switchcpu (ThreadContext *tc) |
void | togglesync (ThreadContext *tc) |
void | triggerWorkloadEvent (ThreadContext *tc) |
void | workbegin (ThreadContext *tc, uint64_t workid, uint64_t threadid) |
void | workend (ThreadContext *tc, uint64_t workid, uint64_t threadid) |
static void | decodeAddrOffset (Addr offset, uint8_t &func) |
void | m5Syscall (ThreadContext *tc) |
template<typename ABI , bool store_ret> | |
bool | pseudoInstWork (ThreadContext *tc, uint8_t func, uint64_t &result) |
Execute a decoded M5 pseudo instruction. More... | |
template<typename ABI , bool store_ret = false> | |
bool | pseudoInst (ThreadContext *tc, uint8_t func, uint64_t &result) |
template<typename ABI , bool store_ret = true> | |
bool | pseudoInst (ThreadContext *tc, uint8_t func) |
void PseudoInst::addsymbol | ( | ThreadContext * | tc, |
Addr | addr, | ||
Addr | symbolAddr | ||
) |
Definition at line 253 of file pseudo_inst.cc.
References X86ISA::addr, Loader::debugSymbolTable, DPRINTF, ThreadContext::getSystemPtr(), ThreadContext::getVirtProxy(), Loader::Symbol::Global, Loader::SymbolTable::insert(), Workload::insertSymbol(), PortProxy::readString(), and System::workload.
Referenced by pseudoInstWork().
void PseudoInst::arm | ( | ThreadContext * | tc | ) |
Definition at line 102 of file pseudo_inst.cc.
References DPRINTF, ThreadContext::getSystemPtr(), Workload::recordArm(), and System::workload.
Referenced by pseudoInstWork().
void PseudoInst::debugbreak | ( | ThreadContext * | tc | ) |
Definition at line 440 of file pseudo_inst.cc.
References Debug::breakpoint(), and DPRINTF.
Referenced by pseudoInstWork().
|
inlinestatic |
Definition at line 60 of file pseudo_inst.hh.
References bits(), and ArmISA::offset.
Referenced by ArmSemihosting::callGem5PseudoOp32(), ArmSemihosting::callGem5PseudoOp64(), X86ISA::TLB::finalizePhysical(), and ArmISA::TLB::finalizePhysical().
void PseudoInst::dumpresetstats | ( | ThreadContext * | tc, |
Tick | delay, | ||
Tick | period | ||
) |
Definition at line 328 of file pseudo_inst.cc.
References curTick(), DPRINTF, ThreadContext::getCpuPtr(), SimClock::Int::ns, SimObject::params(), and Stats::schedStatEvent().
Referenced by pseudoInstWork().
void PseudoInst::dumpstats | ( | ThreadContext * | tc, |
Tick | delay, | ||
Tick | period | ||
) |
Definition at line 314 of file pseudo_inst.cc.
References curTick(), DPRINTF, ThreadContext::getCpuPtr(), SimClock::Int::ns, SimObject::params(), and Stats::schedStatEvent().
Referenced by pseudoInstWork().
uint64_t PseudoInst::initParam | ( | ThreadContext * | tc, |
uint64_t | key_str1, | ||
uint64_t | key_str2 | ||
) |
Definition at line 270 of file pseudo_inst.cc.
References PseudoInst::InitParamKey::DEFAULT, PseudoInst::InitParamKey::DIST_RANK, PseudoInst::InitParamKey::DIST_SIZE, DPRINTF, ThreadContext::getCpuPtr(), System::init_param, ArmISA::len, letoh(), panic, DistIface::rankParam(), DistIface::sizeParam(), and BaseCPU::system.
Referenced by pseudoInstWork().
void PseudoInst::loadsymbol | ( | ThreadContext * | tc | ) |
Definition at line 201 of file pseudo_inst.cc.
References X86ISA::addr, DPRINTF, eat_white(), fatal, ThreadContext::getCpuPtr(), ThreadContext::getSystemPtr(), Workload::insertSymbol(), SimObject::params(), BaseCPU::system, to_number(), and System::workload.
Referenced by pseudoInstWork().
void PseudoInst::m5checkpoint | ( | ThreadContext * | tc, |
Tick | delay, | ||
Tick | period | ||
) |
Definition at line 342 of file pseudo_inst.cc.
References curTick(), DPRINTF, exitSimLoop(), ThreadContext::getCpuPtr(), SimClock::Int::ns, SimObject::params(), and DistIface::readyToCkpt().
Referenced by pseudoInstWork().
void PseudoInst::m5exit | ( | ThreadContext * | tc, |
Tick | delay | ||
) |
Definition at line 173 of file pseudo_inst.cc.
References curTick(), DPRINTF, exitSimLoop(), SimClock::Int::ns, and DistIface::readyToExit().
Referenced by pseudoInstWork().
void PseudoInst::m5fail | ( | ThreadContext * | tc, |
Tick | delay, | ||
uint64_t | code | ||
) |
Definition at line 193 of file pseudo_inst.cc.
References curTick(), DPRINTF, exitSimLoop(), and SimClock::Int::ns.
Referenced by pseudoInstWork().
uint64_t PseudoInst::m5sum | ( | ThreadContext * | tc, |
uint64_t | a, | ||
uint64_t | b, | ||
uint64_t | c, | ||
uint64_t | d, | ||
uint64_t | e, | ||
uint64_t | f | ||
) |
Definition at line 184 of file pseudo_inst.cc.
References ArmISA::a, ArmISA::b, ArmISA::c, ArmISA::d, DPRINTF, ArmISA::e, and ArmISA::f.
Referenced by pseudoInstWork().
void PseudoInst::m5Syscall | ( | ThreadContext * | tc | ) |
bool PseudoInst::pseudoInst | ( | ThreadContext * | tc, |
uint8_t | func | ||
) |
Definition at line 246 of file pseudo_inst.hh.
bool PseudoInst::pseudoInst | ( | ThreadContext * | tc, |
uint8_t | func, | ||
uint64_t & | result | ||
) |
Definition at line 239 of file pseudo_inst.hh.
bool PseudoInst::pseudoInstWork | ( | ThreadContext * | tc, |
uint8_t | func, | ||
uint64_t & | result | ||
) |
Execute a decoded M5 pseudo instruction.
The ISA-specific code is responsible to decode the pseudo inst function number and subfunction number. After that has been done, the rest of the instruction can be implemented in an ISA-agnostic manner using the ISA-specific getArguments functions.
func | M5 pseudo op major function number (see utility/m5/m5ops.h) |
result | A reference to a uint64_t to store a result in. |
Definition at line 111 of file pseudo_inst.hh.
References addsymbol(), arm(), debugbreak(), DPRINTF, dumpresetstats(), dumpstats(), initParam(), loadsymbol(), m5checkpoint(), m5exit(), m5fail(), m5sum(), panic, ThreadContext::pcState(), quiesce(), quiesceCycles(), quiesceNs(), quiesceTime(), readfile(), resetstats(), rpns(), switchcpu(), togglesync(), triggerWorkloadEvent(), wakeCPU(), warn, workbegin(), workend(), and writefile().
void PseudoInst::quiesce | ( | ThreadContext * | tc | ) |
Definition at line 112 of file pseudo_inst.cc.
References DPRINTF, and ThreadContext::quiesce().
Referenced by DefaultFetch< Impl >::fetch(), and pseudoInstWork().
void PseudoInst::quiesceCycles | ( | ThreadContext * | tc, |
uint64_t | cycles | ||
) |
Definition at line 133 of file pseudo_inst.cc.
References Clocked::clockEdge(), DPRINTF, ThreadContext::getCpuPtr(), and ThreadContext::quiesceTick().
Referenced by pseudoInstWork().
void PseudoInst::quiesceNs | ( | ThreadContext * | tc, |
uint64_t | ns | ||
) |
Definition at line 126 of file pseudo_inst.cc.
References curTick(), DPRINTF, SimClock::Int::ns, ArmISA::ns, and ThreadContext::quiesceTick().
Referenced by pseudoInstWork().
void PseudoInst::quiesceSkip | ( | ThreadContext * | tc | ) |
Definition at line 119 of file pseudo_inst.cc.
References DPRINTF, ThreadContext::getCpuPtr(), Clocked::nextCycle(), and ThreadContext::quiesceTick().
uint64_t PseudoInst::quiesceTime | ( | ThreadContext * | tc | ) |
Definition at line 140 of file pseudo_inst.cc.
References DPRINTF, SimClock::Int::ns, ThreadContext::readLastActivate(), and ThreadContext::readLastSuspend().
Referenced by pseudoInstWork().
uint64_t PseudoInst::readfile | ( | ThreadContext * | tc, |
Addr | vaddr, | ||
uint64_t | len, | ||
uint64_t | offset | ||
) |
Definition at line 356 of file pseudo_inst.cc.
References DPRINTF, ArmISA::fd, ThreadContext::getSystemPtr(), ThreadContext::getVirtProxy(), ArmISA::len, ArmISA::offset, MipsISA::p, panic, SimObject::params(), ULL, MipsISA::vaddr, and PortProxy::writeBlob().
Referenced by pseudoInstWork().
void PseudoInst::resetstats | ( | ThreadContext * | tc, |
Tick | delay, | ||
Tick | period | ||
) |
Definition at line 300 of file pseudo_inst.cc.
References curTick(), DPRINTF, ThreadContext::getCpuPtr(), SimClock::Int::ns, SimObject::params(), and Stats::schedStatEvent().
Referenced by pseudoInstWork().
uint64_t PseudoInst::rpns | ( | ThreadContext * | tc | ) |
Definition at line 149 of file pseudo_inst.cc.
References curTick(), DPRINTF, and SimClock::Int::ns.
Referenced by pseudoInstWork().
void PseudoInst::switchcpu | ( | ThreadContext * | tc | ) |
Definition at line 447 of file pseudo_inst.cc.
References DPRINTF, and exitSimLoop().
Referenced by pseudoInstWork().
void PseudoInst::togglesync | ( | ThreadContext * | tc | ) |
Definition at line 454 of file pseudo_inst.cc.
References DPRINTF, and DistIface::toggleSync().
Referenced by pseudoInstWork().
void PseudoInst::triggerWorkloadEvent | ( | ThreadContext * | tc | ) |
Definition at line 461 of file pseudo_inst.cc.
References DPRINTF, Workload::event(), ThreadContext::getSystemPtr(), and System::workload.
Referenced by pseudoInstWork().
void PseudoInst::wakeCPU | ( | ThreadContext * | tc, |
uint64_t | cpuid | ||
) |
Definition at line 156 of file pseudo_inst.cc.
References ThreadContext::activate(), MipsISA::cpuid, DPRINTF, ThreadContext::getSystemPtr(), System::Threads::size(), ThreadContext::status(), ThreadContext::Suspended, System::threads, and warn.
Referenced by pseudoInstWork().
void PseudoInst::workbegin | ( | ThreadContext * | tc, |
uint64_t | workid, | ||
uint64_t | threadid | ||
) |
Definition at line 473 of file pseudo_inst.cc.
References BaseCPU::cpuId(), DPRINTF, exitSimLoop(), ThreadContext::getCpuPtr(), ThreadContext::getSystemPtr(), System::incWorkItemsBegin(), System::markWorkItem(), SimObject::params(), BaseCPU::workItemBegin(), and System::workItemBegin().
Referenced by pseudoInstWork().
void PseudoInst::workend | ( | ThreadContext * | tc, |
uint64_t | workid, | ||
uint64_t | threadid | ||
) |
Definition at line 536 of file pseudo_inst.cc.
References BaseCPU::cpuId(), DPRINTF, exitSimLoop(), ThreadContext::getCpuPtr(), ThreadContext::getSystemPtr(), System::incWorkItemsEnd(), System::markWorkItem(), SimObject::params(), BaseCPU::workItemEnd(), and System::workItemEnd().
Referenced by pseudoInstWork().
uint64_t PseudoInst::writefile | ( | ThreadContext * | tc, |
Addr | vaddr, | ||
uint64_t | len, | ||
uint64_t | offset, | ||
Addr | filename_addr | ||
) |
Definition at line 394 of file pseudo_inst.cc.
References OutputDirectory::close(), OutputDirectory::create(), DPRINTF, ThreadContext::getVirtProxy(), ArmISA::len, ArmISA::offset, OutputDirectory::open(), X86ISA::os, panic, PortProxy::readBlob(), PortProxy::readString(), simout, OutputStream::stream(), and MipsISA::vaddr.
Referenced by pseudoInstWork().