| gem5
    v22.1.0.0
    | 
| 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 gem5::pseudo_inst::addsymbol | ( | ThreadContext * | tc, | 
| Addr | addr, | ||
| Addr | symbolAddr | ||
| ) | 
Definition at line 259 of file pseudo_inst.cc.
References gem5::X86ISA::addr, gem5::loader::debugSymbolTable, DPRINTF, gem5::FullSystem, gem5::ThreadContext::getSystemPtr(), gem5::loader::Symbol::Global, gem5::loader::SymbolTable::insert(), gem5::Workload::insertSymbol(), gem5::PortProxy::readString(), and gem5::System::workload.
Referenced by pseudoInstWork().
| void gem5::pseudo_inst::arm | ( | ThreadContext * | tc | ) | 
Definition at line 108 of file pseudo_inst.cc.
References DPRINTF, gem5::ThreadContext::getSystemPtr(), gem5::Workload::recordArm(), and gem5::System::workload.
Referenced by pseudoInstWork().
| void gem5::pseudo_inst::debugbreak | ( | ThreadContext * | tc | ) | 
Definition at line 460 of file pseudo_inst.cc.
References gem5::debug::breakpoint(), and DPRINTF.
Referenced by pseudoInstWork().
| 
 | inlinestatic | 
Definition at line 63 of file pseudo_inst.hh.
References gem5::bits(), and gem5::ArmISA::offset.
Referenced by gem5::ArmSemihosting::callGem5PseudoOp32(), gem5::ArmSemihosting::callGem5PseudoOp64(), gem5::X86ISA::TLB::finalizePhysical(), and gem5::ArmISA::MMU::finalizePhysical().
| void gem5::pseudo_inst::dumpresetstats | ( | ThreadContext * | tc, | 
| Tick | delay, | ||
| Tick | period | ||
| ) | 
Definition at line 338 of file pseudo_inst.cc.
References gem5::curTick(), DPRINTF, gem5::ThreadContext::getCpuPtr(), gem5::sim_clock::as_int::ns, gem5::SimObject::params(), and gem5::statistics::schedStatEvent().
Referenced by pseudoInstWork().
| void gem5::pseudo_inst::dumpstats | ( | ThreadContext * | tc, | 
| Tick | delay, | ||
| Tick | period | ||
| ) | 
Definition at line 324 of file pseudo_inst.cc.
References gem5::curTick(), DPRINTF, gem5::ThreadContext::getCpuPtr(), gem5::sim_clock::as_int::ns, gem5::SimObject::params(), and gem5::statistics::schedStatEvent().
Referenced by pseudoInstWork().
| uint64_t gem5::pseudo_inst::initParam | ( | ThreadContext * | tc, | 
| uint64_t | key_str1, | ||
| uint64_t | key_str2 | ||
| ) | 
Definition at line 280 of file pseudo_inst.cc.
References DPRINTF, gem5::ThreadContext::getCpuPtr(), gem5::System::init_param, len, gem5::letoh(), panic, gem5::DistIface::rankParam(), gem5::DistIface::sizeParam(), and gem5::BaseCPU::system.
Referenced by pseudoInstWork().
| void gem5::pseudo_inst::loadsymbol | ( | ThreadContext * | tc | ) | 
Definition at line 207 of file pseudo_inst.cc.
References gem5::X86ISA::addr, DPRINTF, gem5::eat_white(), fatal, gem5::ThreadContext::getCpuPtr(), gem5::ThreadContext::getSystemPtr(), gem5::Workload::insertSymbol(), gem5::SimObject::params(), gem5::BaseCPU::system, gem5::to_number(), and gem5::System::workload.
Referenced by pseudoInstWork().
| void gem5::pseudo_inst::m5checkpoint | ( | ThreadContext * | tc, | 
| Tick | delay, | ||
| Tick | period | ||
| ) | 
Definition at line 353 of file pseudo_inst.cc.
References gem5::curTick(), DPRINTF, gem5::exitSimLoop(), gem5::ThreadContext::getCpuPtr(), gem5::sim_clock::as_int::ns, gem5::SimObject::params(), and gem5::DistIface::readyToCkpt().
Referenced by pseudoInstWork().
| void gem5::pseudo_inst::m5exit | ( | ThreadContext * | tc, | 
| Tick | delay | ||
| ) | 
Definition at line 179 of file pseudo_inst.cc.
References gem5::curTick(), DPRINTF, gem5::exitSimLoop(), gem5::sim_clock::as_int::ns, and gem5::DistIface::readyToExit().
Referenced by pseudoInstWork().
| void gem5::pseudo_inst::m5fail | ( | ThreadContext * | tc, | 
| Tick | delay, | ||
| uint64_t | code | ||
| ) | 
Definition at line 199 of file pseudo_inst.cc.
References gem5::curTick(), DPRINTF, gem5::exitSimLoop(), and gem5::sim_clock::as_int::ns.
Referenced by pseudoInstWork().
| uint64_t gem5::pseudo_inst::m5sum | ( | ThreadContext * | tc, | 
| uint64_t | a, | ||
| uint64_t | b, | ||
| uint64_t | c, | ||
| uint64_t | d, | ||
| uint64_t | e, | ||
| uint64_t | f | ||
| ) | 
Definition at line 190 of file pseudo_inst.cc.
References gem5::ArmISA::a, gem5::ArmISA::b, gem5::VegaISA::c, gem5::ArmISA::d, DPRINTF, gem5::ArmISA::e, and gem5::VegaISA::f.
Referenced by pseudoInstWork().
| void gem5::pseudo_inst::m5Syscall | ( | ThreadContext * | tc | ) | 
| bool gem5::pseudo_inst::pseudoInst | ( | ThreadContext * | tc, | 
| uint8_t | func | ||
| ) | 
Definition at line 249 of file pseudo_inst.hh.
| bool gem5::pseudo_inst::pseudoInst | ( | ThreadContext * | tc, | 
| uint8_t | func, | ||
| uint64_t & | result | ||
| ) | 
Definition at line 242 of file pseudo_inst.hh.
| bool gem5::pseudo_inst::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 114 of file pseudo_inst.hh.
References addsymbol(), arm(), debugbreak(), DPRINTF, dumpresetstats(), dumpstats(), initParam(), loadsymbol(), m5checkpoint(), m5exit(), m5fail(), m5sum(), panic, gem5::ThreadContext::pcState(), quiesce(), quiesceCycles(), quiesceNs(), quiesceTime(), readfile(), resetstats(), rpns(), switchcpu(), togglesync(), triggerWorkloadEvent(), wakeCPU(), warn, workbegin(), workend(), and writefile().
| void gem5::pseudo_inst::quiesce | ( | ThreadContext * | tc | ) | 
Definition at line 118 of file pseudo_inst.cc.
References DPRINTF, and gem5::ThreadContext::quiesce().
Referenced by gem5::o3::Fetch::fetch(), and pseudoInstWork().
| void gem5::pseudo_inst::quiesceCycles | ( | ThreadContext * | tc, | 
| uint64_t | cycles | ||
| ) | 
Definition at line 139 of file pseudo_inst.cc.
References gem5::Clocked::clockEdge(), DPRINTF, gem5::ThreadContext::getCpuPtr(), and gem5::ThreadContext::quiesceTick().
Referenced by pseudoInstWork().
| void gem5::pseudo_inst::quiesceNs | ( | ThreadContext * | tc, | 
| uint64_t | ns | ||
| ) | 
Definition at line 132 of file pseudo_inst.cc.
References gem5::curTick(), DPRINTF, gem5::ArmISA::ns, gem5::sim_clock::as_int::ns, and gem5::ThreadContext::quiesceTick().
Referenced by pseudoInstWork().
| void gem5::pseudo_inst::quiesceSkip | ( | ThreadContext * | tc | ) | 
Definition at line 125 of file pseudo_inst.cc.
References DPRINTF, gem5::ThreadContext::getCpuPtr(), gem5::Clocked::nextCycle(), and gem5::ThreadContext::quiesceTick().
| uint64_t gem5::pseudo_inst::quiesceTime | ( | ThreadContext * | tc | ) | 
Definition at line 146 of file pseudo_inst.cc.
References DPRINTF, gem5::sim_clock::as_int::ns, gem5::ThreadContext::readLastActivate(), and gem5::ThreadContext::readLastSuspend().
Referenced by pseudoInstWork().
| uint64_t gem5::pseudo_inst::readfile | ( | ThreadContext * | tc, | 
| Addr | vaddr, | ||
| uint64_t | len, | ||
| uint64_t | offset | ||
| ) | 
Definition at line 367 of file pseudo_inst.cc.
References DPRINTF, gem5::ArmISA::fd, gem5::FullSystem, gem5::ThreadContext::getSystemPtr(), len, gem5::ArmISA::offset, gem5::VegaISA::p, panic, gem5::SimObject::params(), gem5::MipsISA::vaddr, and gem5::PortProxy::writeBlob().
Referenced by pseudoInstWork().
| void gem5::pseudo_inst::resetstats | ( | ThreadContext * | tc, | 
| Tick | delay, | ||
| Tick | period | ||
| ) | 
Definition at line 310 of file pseudo_inst.cc.
References gem5::curTick(), DPRINTF, gem5::ThreadContext::getCpuPtr(), gem5::sim_clock::as_int::ns, gem5::SimObject::params(), and gem5::statistics::schedStatEvent().
Referenced by pseudoInstWork().
| uint64_t gem5::pseudo_inst::rpns | ( | ThreadContext * | tc | ) | 
Definition at line 155 of file pseudo_inst.cc.
References gem5::curTick(), DPRINTF, and gem5::sim_clock::as_int::ns.
Referenced by pseudoInstWork().
| void gem5::pseudo_inst::switchcpu | ( | ThreadContext * | tc | ) | 
Definition at line 467 of file pseudo_inst.cc.
References DPRINTF, and gem5::exitSimLoop().
Referenced by pseudoInstWork().
| void gem5::pseudo_inst::togglesync | ( | ThreadContext * | tc | ) | 
Definition at line 474 of file pseudo_inst.cc.
References DPRINTF, and gem5::DistIface::toggleSync().
Referenced by pseudoInstWork().
| void gem5::pseudo_inst::triggerWorkloadEvent | ( | ThreadContext * | tc | ) | 
Definition at line 481 of file pseudo_inst.cc.
References DPRINTF, gem5::Workload::event(), gem5::ThreadContext::getSystemPtr(), and gem5::System::workload.
Referenced by pseudoInstWork().
| void gem5::pseudo_inst::wakeCPU | ( | ThreadContext * | tc, | 
| uint64_t | cpuid | ||
| ) | 
Definition at line 162 of file pseudo_inst.cc.
References gem5::ThreadContext::activate(), gem5::MipsISA::cpuid, DPRINTF, gem5::ThreadContext::getSystemPtr(), gem5::System::Threads::size(), gem5::ThreadContext::status(), gem5::ThreadContext::Suspended, gem5::System::threads, and warn.
Referenced by pseudoInstWork().
| void gem5::pseudo_inst::workbegin | ( | ThreadContext * | tc, | 
| uint64_t | workid, | ||
| uint64_t | threadid | ||
| ) | 
Definition at line 493 of file pseudo_inst.cc.
References gem5::BaseCPU::cpuId(), DPRINTF, gem5::exitSimLoop(), gem5::ThreadContext::getCpuPtr(), gem5::ThreadContext::getSystemPtr(), gem5::System::incWorkItemsBegin(), gem5::System::markWorkItem(), gem5::SimObject::params(), gem5::BaseCPU::workItemBegin(), and gem5::System::workItemBegin().
Referenced by pseudoInstWork().
| void gem5::pseudo_inst::workend | ( | ThreadContext * | tc, | 
| uint64_t | workid, | ||
| uint64_t | threadid | ||
| ) | 
Definition at line 556 of file pseudo_inst.cc.
References gem5::BaseCPU::cpuId(), DPRINTF, gem5::exitSimLoop(), gem5::ThreadContext::getCpuPtr(), gem5::ThreadContext::getSystemPtr(), gem5::System::incWorkItemsEnd(), gem5::System::markWorkItem(), gem5::SimObject::params(), gem5::BaseCPU::workItemEnd(), and gem5::System::workItemEnd().
Referenced by pseudoInstWork().
| uint64_t gem5::pseudo_inst::writefile | ( | ThreadContext * | tc, | 
| Addr | vaddr, | ||
| uint64_t | len, | ||
| uint64_t | offset, | ||
| Addr | filename_addr | ||
| ) | 
Definition at line 409 of file pseudo_inst.cc.
References gem5::OutputDirectory::close(), gem5::OutputDirectory::create(), DPRINTF, gem5::FullSystem, len, gem5::ArmISA::offset, gem5::OutputDirectory::open(), gem5::X86ISA::os, panic, gem5::PortProxy::readBlob(), gem5::PortProxy::readString(), gem5::simout, gem5::OutputStream::stream(), and gem5::MipsISA::vaddr.
Referenced by pseudoInstWork().