gem5
v19.0.0.0
|
Classes | |
struct | InitParamKey |
Unique keys to retrieve various params by the initParam pseudo inst. More... | |
Functions | |
static void | panicFsOnlyPseudoInst (const char *name) |
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) |
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 | m5Syscall (ThreadContext *tc) |
void | togglesync (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) |
template<typename ABI > | |
uint64_t | pseudoInst (ThreadContext *tc, uint8_t func) |
Execute a decoded M5 pseudo instruction. More... | |
void PseudoInst::addsymbol | ( | ThreadContext * | tc, |
Addr | addr, | ||
Addr | symbolAddr | ||
) |
Definition at line 233 of file pseudo_inst.cc.
References debugSymbolTable, DPRINTF, FullSystem, ThreadContext::getSystemPtr(), ThreadContext::getVirtProxy(), SymbolTable::insert(), System::kernelSymtab, panicFsOnlyPseudoInst(), and PortProxy::readString().
Referenced by decodeAddrOffset(), and pseudoInst().
void PseudoInst::arm | ( | ThreadContext * | tc | ) |
Definition at line 91 of file pseudo_inst.cc.
References Kernel::Statistics::arm(), DPRINTF, FullSystem, ThreadContext::getKernelStats(), and panicFsOnlyPseudoInst().
Referenced by decodeAddrOffset(), and pseudoInst().
void PseudoInst::debugbreak | ( | ThreadContext * | tc | ) |
Definition at line 436 of file pseudo_inst.cc.
References Debug::breakpoint(), and DPRINTF.
Referenced by decodeAddrOffset(), and pseudoInst().
|
inlinestatic |
Definition at line 93 of file pseudo_inst.hh.
References addr, addsymbol(), arm(), bits(), MipsISA::cpuid, debugbreak(), dumpresetstats(), dumpstats(), initParam(), ArmISA::len, loadsymbol(), m5checkpoint(), m5exit(), m5fail(), m5Syscall(), ArmISA::ns, ArmISA::offset, quiesce(), quiesceCycles(), quiesceNs(), quiesceSkip(), quiesceTime(), readfile(), resetstats(), rpns(), switchcpu(), togglesync(), MipsISA::vaddr, wakeCPU(), workbegin(), workend(), and writefile().
Referenced by ArmISA::handleIprRead(), X86ISA::handleIprRead(), ArmISA::handleIprWrite(), and X86ISA::handleIprWrite().
void PseudoInst::dumpresetstats | ( | ThreadContext * | tc, |
Tick | delay, | ||
Tick | period | ||
) |
Definition at line 323 of file pseudo_inst.cc.
References curTick(), DPRINTF, ThreadContext::getCpuPtr(), SimClock::Int::ns, BaseCPU::params(), and Stats::schedStatEvent().
Referenced by decodeAddrOffset(), and pseudoInst().
void PseudoInst::dumpstats | ( | ThreadContext * | tc, |
Tick | delay, | ||
Tick | period | ||
) |
Definition at line 309 of file pseudo_inst.cc.
References curTick(), DPRINTF, ThreadContext::getCpuPtr(), SimClock::Int::ns, BaseCPU::params(), and Stats::schedStatEvent().
Referenced by decodeAddrOffset(), and pseudoInst().
uint64_t PseudoInst::initParam | ( | ThreadContext * | tc, |
uint64_t | key_str1, | ||
uint64_t | key_str2 | ||
) |
Definition at line 250 of file pseudo_inst.cc.
References DPRINTF, FullSystem, ThreadContext::getCpuPtr(), System::init_param, ArmISA::len, panic, panicFsOnlyPseudoInst(), DistIface::rankParam(), DistIface::sizeParam(), BaseCPU::system, and X86ISA::val.
Referenced by decodeAddrOffset(), and pseudoInst().
void PseudoInst::loadsymbol | ( | ThreadContext * | tc | ) |
Definition at line 181 of file pseudo_inst.cc.
References addr, DPRINTF, eat_white(), fatal, FullSystem, ThreadContext::getCpuPtr(), ThreadContext::getSystemPtr(), SymbolTable::insert(), System::kernelSymtab, panicFsOnlyPseudoInst(), System::params(), BaseCPU::system, and to_number().
Referenced by decodeAddrOffset(), and pseudoInst().
void PseudoInst::m5checkpoint | ( | ThreadContext * | tc, |
Tick | delay, | ||
Tick | period | ||
) |
Definition at line 337 of file pseudo_inst.cc.
References curTick(), DPRINTF, exitSimLoop(), ThreadContext::getCpuPtr(), SimClock::Int::ns, BaseCPU::params(), and DistIface::readyToCkpt().
Referenced by decodeAddrOffset(), and pseudoInst().
void PseudoInst::m5exit | ( | ThreadContext * | tc, |
Tick | delay | ||
) |
Definition at line 163 of file pseudo_inst.cc.
References curTick(), DPRINTF, exitSimLoop(), SimClock::Int::ns, and DistIface::readyToExit().
Referenced by decodeAddrOffset(), and pseudoInst().
void PseudoInst::m5fail | ( | ThreadContext * | tc, |
Tick | delay, | ||
uint64_t | code | ||
) |
Definition at line 173 of file pseudo_inst.cc.
References curTick(), DPRINTF, exitSimLoop(), and SimClock::Int::ns.
Referenced by decodeAddrOffset(), and pseudoInst().
void PseudoInst::m5Syscall | ( | ThreadContext * | tc | ) |
Definition at line 454 of file pseudo_inst.cc.
References DPRINTF, and ThreadContext::syscall().
Referenced by decodeAddrOffset(), and pseudoInst().
|
inlinestatic |
Definition at line 85 of file pseudo_inst.cc.
References panic.
Referenced by addsymbol(), arm(), initParam(), loadsymbol(), and readfile().
uint64_t PseudoInst::pseudoInst | ( | ThreadContext * | tc, |
uint8_t | func | ||
) |
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) |
Definition at line 139 of file pseudo_inst.hh.
References addsymbol(), arm(), debugbreak(), DPRINTF, dumpresetstats(), dumpstats(), initParam(), loadsymbol(), m5checkpoint(), m5exit(), m5fail(), GenericISA::m5PageFault(), m5Syscall(), panic, quiesce(), quiesceCycles(), quiesceNs(), quiesceTime(), readfile(), resetstats(), rpns(), switchcpu(), togglesync(), wakeCPU(), warn, workbegin(), workend(), and writefile().
void PseudoInst::quiesce | ( | ThreadContext * | tc | ) |
Definition at line 102 of file pseudo_inst.cc.
References DPRINTF, and ThreadContext::quiesce().
Referenced by decodeAddrOffset(), DefaultFetch< Impl >::fetch(), pseudoInst(), and ThreadContext::~ThreadContext().
void PseudoInst::quiesceCycles | ( | ThreadContext * | tc, |
uint64_t | cycles | ||
) |
Definition at line 123 of file pseudo_inst.cc.
References Clocked::clockEdge(), DPRINTF, ThreadContext::getCpuPtr(), and ThreadContext::quiesceTick().
Referenced by decodeAddrOffset(), and pseudoInst().
void PseudoInst::quiesceNs | ( | ThreadContext * | tc, |
uint64_t | ns | ||
) |
Definition at line 116 of file pseudo_inst.cc.
References curTick(), DPRINTF, SimClock::Int::ns, and ThreadContext::quiesceTick().
Referenced by decodeAddrOffset(), FreeBSD::UDelayEvent::process(), Linux::UDelayEvent::process(), and pseudoInst().
void PseudoInst::quiesceSkip | ( | ThreadContext * | tc | ) |
Definition at line 109 of file pseudo_inst.cc.
References DPRINTF, ThreadContext::getCpuPtr(), Clocked::nextCycle(), and ThreadContext::quiesceTick().
Referenced by decodeAddrOffset().
uint64_t PseudoInst::quiesceTime | ( | ThreadContext * | tc | ) |
Definition at line 130 of file pseudo_inst.cc.
References DPRINTF, SimClock::Int::ns, ThreadContext::readLastActivate(), and ThreadContext::readLastSuspend().
Referenced by decodeAddrOffset(), and pseudoInst().
uint64_t PseudoInst::readfile | ( | ThreadContext * | tc, |
Addr | vaddr, | ||
uint64_t | len, | ||
uint64_t | offset | ||
) |
Definition at line 351 of file pseudo_inst.cc.
References DPRINTF, ArmISA::fd, FullSystem, ThreadContext::getSystemPtr(), ThreadContext::getVirtProxy(), ArmISA::len, MipsISA::p, panic, panicFsOnlyPseudoInst(), System::params(), ULL, and PortProxy::writeBlob().
Referenced by decodeAddrOffset(), and pseudoInst().
void PseudoInst::resetstats | ( | ThreadContext * | tc, |
Tick | delay, | ||
Tick | period | ||
) |
Definition at line 295 of file pseudo_inst.cc.
References curTick(), DPRINTF, ThreadContext::getCpuPtr(), SimClock::Int::ns, BaseCPU::params(), and Stats::schedStatEvent().
Referenced by decodeAddrOffset(), and pseudoInst().
uint64_t PseudoInst::rpns | ( | ThreadContext * | tc | ) |
Definition at line 139 of file pseudo_inst.cc.
References curTick(), DPRINTF, and SimClock::Int::ns.
Referenced by decodeAddrOffset(), and pseudoInst().
void PseudoInst::switchcpu | ( | ThreadContext * | tc | ) |
Definition at line 443 of file pseudo_inst.cc.
References DPRINTF, and exitSimLoop().
Referenced by decodeAddrOffset(), and pseudoInst().
void PseudoInst::togglesync | ( | ThreadContext * | tc | ) |
Definition at line 462 of file pseudo_inst.cc.
References DPRINTF, and DistIface::toggleSync().
Referenced by decodeAddrOffset(), and pseudoInst().
void PseudoInst::wakeCPU | ( | ThreadContext * | tc, |
uint64_t | cpuid | ||
) |
Definition at line 146 of file pseudo_inst.cc.
References ThreadContext::activate(), MipsISA::cpuid, DPRINTF, ThreadContext::getSystemPtr(), System::numContexts(), ThreadContext::status(), ThreadContext::Suspended, System::threadContexts, and warn.
Referenced by FullO3CPU< O3CPUImpl >::deactivateStage(), decodeAddrOffset(), and pseudoInst().
void PseudoInst::workbegin | ( | ThreadContext * | tc, |
uint64_t | workid, | ||
uint64_t | threadid | ||
) |
Definition at line 474 of file pseudo_inst.cc.
References BaseCPU::cpuId(), DPRINTF, exitSimLoop(), ThreadContext::getCpuPtr(), ThreadContext::getSystemPtr(), System::incWorkItemsBegin(), System::markWorkItem(), System::params(), BaseCPU::workItemBegin(), and System::workItemBegin().
Referenced by decodeAddrOffset(), and pseudoInst().
void PseudoInst::workend | ( | ThreadContext * | tc, |
uint64_t | workid, | ||
uint64_t | threadid | ||
) |
Definition at line 537 of file pseudo_inst.cc.
References BaseCPU::cpuId(), DPRINTF, exitSimLoop(), ThreadContext::getCpuPtr(), ThreadContext::getSystemPtr(), System::incWorkItemsEnd(), System::markWorkItem(), System::params(), BaseCPU::workItemEnd(), and System::workItemEnd().
Referenced by decodeAddrOffset(), and pseudoInst().
uint64_t PseudoInst::writefile | ( | ThreadContext * | tc, |
Addr | vaddr, | ||
uint64_t | len, | ||
uint64_t | offset, | ||
Addr | filename_addr | ||
) |
Definition at line 393 of file pseudo_inst.cc.
References OutputDirectory::close(), OutputDirectory::create(), DPRINTF, ThreadContext::getVirtProxy(), ArmISA::len, OutputDirectory::open(), X86ISA::os, panic, PortProxy::readBlob(), PortProxy::readString(), simout, and OutputStream::stream().
Referenced by decodeAddrOffset(), and pseudoInst().