38 #ifndef __ARCH_GENERIC_DEBUGFAULTS_HH__ 39 #define __ARCH_GENERIC_DEBUGFAULTS_HH__ 67 template <
class ...Args>
85 template <
class Flavor>
91 template <
class F,
class OnceToken>
95 static std::map<OnceToken, bool> tokenMap;
96 return tokenMap[token];
100 template <
class OnceToken,
class ...Args>
102 const Args &...args) :
103 M5DebugFault(format, args...), once(lookUpToken<Flavor>(token))
134 template <
class Base>
146 template <
class Base>
158 template <
class Base>
173 #endif // __ARCH_GENERIC_DEBUGFAULTS_HH__ #define panic(...)
This implements a cprintf based panic() function.
void debugFunc() override
void invoke(ThreadContext *tc, const StaticInstPtr &inst=StaticInst::nullStaticInstPtr) override
#define fatal(...)
This implements a cprintf based fatal() function.
virtual TheISA::PCState pcState() const =0
static bool & lookUpToken(const OnceToken &token)
void invoke(ThreadContext *tc, const StaticInstPtr &inst=StaticInst::nullStaticInstPtr) override
virtual void debugFunc()=0
FaultName name() const override
FaultName name() const override
M5DebugFault(const std::string &format, const Args &...args)
FaultName name() const override
ThreadContext is the external interface to all thread state for anything outside of the CPU...
std::string csprintf(const char *format, const Args &...args)
void advancePC(ThreadContext *tc, const StaticInstPtr &inst)
void debugFunc() override
Bitfield< 31, 29 > format
virtual void advancePC(TheISA::PCState &pcState) const =0
void debugFunc() override
static StaticInstPtr nullStaticInstPtr
Pointer to a statically allocated "null" instruction object.
FaultName name() const override
void debugFunc() override
M5DebugFault(std::string _m)
M5DebugOnceFault(const OnceToken &token, const std::string &format, const Args &...args)