Go to the documentation of this file.
28 #ifndef __SIM_WORKLOAD_HH__
29 #define __SIM_WORKLOAD_HH__
36 #include "enums/ByteOrder.hh"
37 #include "params/StubWorkload.hh"
38 #include "params/Workload.hh"
62 : statistics::
Group(parent,
"inst"),
64 "number of arm instructions executed"),
66 "number of quiesce instructions executed")
111 panic(
"syscall() not implemented.");
117 warn(
"Unhandled workload event.");
133 template <
class T,
typename... Args>
136 const std::string &desc, Args... args)
143 std::forward<Args>(args)...);
150 return addFuncEvent<T>(
symtab, lbl, lbl);
153 template <
class T,
typename... Args>
158 T *
e = addFuncEvent<T>(
symtab, lbl, std::forward<Args>(args)...);
159 panic_if(!
e,
"Failed to find symbol '%s'", lbl);
191 #endif // __SIM_WORKLOAD_HH__
This is a simple scalar statistic, like a counter.
WorkloadStats(Workload *workload)
gem5::Workload::WorkloadStats stats
virtual Addr getEntry() const =0
InstStats(statistics::Group *parent)
const_iterator end() const
const loader::SymbolTable & symtab(ThreadContext *tc) override
T * addFuncEvent(const loader::SymbolTable &symtab, const char *lbl, const std::string &desc, Args... args)
Add a function-based event to the given function, to be looked up in the specified symbol table.
virtual loader::Arch getArch() const =0
ByteOrder byteOrder() const override
loader::SymbolTable _symtab
ThreadContext is the external interface to all thread state for anything outside of the CPU.
virtual void event(ThreadContext *tc)
T * addFuncEventOrPanic(const loader::SymbolTable &symtab, const char *lbl, Args... args)
const Params & params() const
#define ADD_STAT(n,...)
Convenience macro to add a stat to a statistics group.
Addr getEntry() const override
std::set< ThreadContext * > threads
Abstract superclass for simulation objects.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
bool trapToGdb(int signal, ContextID ctx_id)
loader::Arch getArch() const override
virtual const loader::SymbolTable & symtab(ThreadContext *tc)=0
T * addFuncEvent(const loader::SymbolTable &symtab, const char *lbl)
const_iterator find(Addr address) const
Search for a symbol by its address.
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
bool insert(const Symbol &symbol)
Insert a new symbol in the table if it does not already exist.
void startup() override
startup() is the final initialization call before simulation.
virtual void replaceThreadContext(ThreadContext *tc)
int ContextID
Globally unique thread context ID.
statistics::Scalar quiesce
bool insertSymbol(const loader::Symbol &symbol) override
virtual Addr fixFuncEventAddr(Addr addr) const
Workload(const WorkloadParams ¶ms)
virtual void setSystem(System *sys)
virtual void registerThreadContext(ThreadContext *tc)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
virtual bool insertSymbol(const loader::Symbol &symbol)=0
StubWorkload(const StubWorkloadParams ¶ms)
virtual void syscall(ThreadContext *tc)
#define panic(...)
This implements a cprintf based panic() function.
gem5::Workload::WorkloadStats::InstStats instStats
virtual ByteOrder byteOrder() const =0
Generated on Wed May 4 2022 12:14:03 for gem5 by doxygen 1.8.17