gem5
v20.0.0.0
|
Namespaces | |
InitParamKey | |
Unique keys to retrieve various params by the initParam pseudo inst. | |
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 > | |
bool | pseudoInst (ThreadContext *tc, uint8_t func, uint64_t &result) |
Execute a decoded M5 pseudo instruction. More... | |
void PseudoInst::addsymbol | ( | ThreadContext * | tc, |
Addr | addr, | ||
Addr | symbolAddr | ||
) |
Definition at line 255 of file pseudo_inst.cc.
References Loader::debugSymbolTable, DPRINTF, FullSystem, ThreadContext::getSystemPtr(), ThreadContext::getVirtProxy(), Loader::SymbolTable::insert(), Workload::insertSymbol(), panicFsOnlyPseudoInst(), PortProxy::readString(), and System::workload.
Referenced by decodeAddrOffset(), and pseudoInst().
void PseudoInst::arm | ( | ThreadContext * | tc | ) |
Definition at line 113 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 449 of file pseudo_inst.cc.
References Debug::breakpoint(), and DPRINTF.
Referenced by decodeAddrOffset(), and pseudoInst().
|
inlinestatic |
Definition at line 91 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 ArmSemihosting::callGem5PseudoOp32(), ArmSemihosting::callGem5PseudoOp64(), X86ISA::TLB::finalizePhysical(), and ArmISA::TLB::finalizePhysical().
void PseudoInst::dumpresetstats | ( | ThreadContext * | tc, |
Tick | delay, | ||
Tick | period | ||
) |
Definition at line 334 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 320 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 272 of file pseudo_inst.cc.
References PseudoInst::InitParamKey::DEFAULT, PseudoInst::InitParamKey::DIST_RANK, PseudoInst::InitParamKey::DIST_SIZE, DPRINTF, FullSystem, ThreadContext::getCpuPtr(), System::init_param, ArmISA::len, letoh(), panic, panicFsOnlyPseudoInst(), DistIface::rankParam(), DistIface::sizeParam(), and BaseCPU::system.
Referenced by decodeAddrOffset(), and pseudoInst().
void PseudoInst::loadsymbol | ( | ThreadContext * | tc | ) |
Definition at line 203 of file pseudo_inst.cc.
References addr, DPRINTF, eat_white(), fatal, FullSystem, ThreadContext::getCpuPtr(), ThreadContext::getSystemPtr(), Workload::insertSymbol(), panicFsOnlyPseudoInst(), System::params(), BaseCPU::system, to_number(), and System::workload.
Referenced by decodeAddrOffset(), and pseudoInst().
void PseudoInst::m5checkpoint | ( | ThreadContext * | tc, |
Tick | delay, | ||
Tick | period | ||
) |
Definition at line 348 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 185 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 195 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 467 of file pseudo_inst.cc.
References DPRINTF, and ThreadContext::syscall().
Referenced by decodeAddrOffset(), and pseudoInst().
|
inlinestatic |
Definition at line 107 of file pseudo_inst.cc.
References panic.
Referenced by addsymbol(), arm(), initParam(), loadsymbol(), and readfile().
bool PseudoInst::pseudoInst | ( | 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 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 124 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 145 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 138 of file pseudo_inst.cc.
References curTick(), DPRINTF, SimClock::Int::ns, and ThreadContext::quiesceTick().
Referenced by decodeAddrOffset(), and pseudoInst().
void PseudoInst::quiesceSkip | ( | ThreadContext * | tc | ) |
Definition at line 131 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 152 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 362 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 306 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 161 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 456 of file pseudo_inst.cc.
References DPRINTF, and exitSimLoop().
Referenced by decodeAddrOffset(), and pseudoInst().
void PseudoInst::togglesync | ( | ThreadContext * | tc | ) |
Definition at line 475 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 168 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 487 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 550 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 404 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().