Go to the documentation of this file.
48 using namespace ArmISA;
69 return std::make_shared<PCAlignmentFault>(
pc);
73 return std::make_shared<PrefetchAbort>(
78 panic(
"Internal error in instruction decoder\n");
81 panic(
"Decoder fault instruction without decoder fault.\n");
84 panic(
"Unhandled fault type");
95 return "UnalignedInstruction";
98 return "DecoderPanic";
101 panic(
"Unhandled fault type");
119 flags[IsNonSpeculative] =
true;
124 const std::string& _fullMnemonic)
125 : ArmStaticInst(_mnemonic, _machInst, No_OpClass),
126 fullMnemonic(_fullMnemonic)
130 flags[IsNonSpeculative] =
true;
143 return csprintf(
"%-10s (unimplemented)",
151 :
ArmStaticInst(_mnemonic, _machInst, No_OpClass), warned(false)
155 flags[IsNonSpeculative] =
true;
160 const std::string& _fullMnemonic)
161 : ArmStaticInst(_mnemonic, _machInst, No_OpClass), warned(false),
162 fullMnemonic(_fullMnemonic)
166 flags[IsNonSpeculative] =
true;
173 warn(
"\tinstruction '%s' unimplemented\n",
185 return csprintf(
"%-10s (unimplemented)",
196 return std::make_shared<IllegalInstSetStateFault>();
207 pc_state.debugStep(
false);
212 bool ldx =
sd->getSstep()->getLdx();
214 return std::make_shared<SoftwareStepFault>(
machInst, ldx,
WarnUnimplemented(const char *_mnemonic, ArmISA::ExtMachInst _machInst)
constexpr decltype(nullptr) NoFault
@ UNALIGNED
Unaligned instruction fault.
std::string fullMnemonic
Full mnemonic for MRC and MCR instructions including the coproc.
std::string generateDisassembly(Addr pc, const loader::SymbolTable *symtab) const override
Internal function to generate disassembly string.
Fault execute(ExecContext *xc, Trace::InstRecord *traceData) const override
std::string generateDisassembly(Addr pc, const loader::SymbolTable *symtab) const override
Internal function to generate disassembly string.
std::string csprintf(const char *format, const Args &...args)
ArmISA::DecoderFault faultId
@ PANIC
Internal gem5 error.
Fault execute(ExecContext *xc, Trace::InstRecord *traceData) const override
Fault execute(ExecContext *xc, Trace::InstRecord *traceData) const override
Fault execute(ExecContext *xc, Trace::InstRecord *traceData) const override
std::shared_ptr< FaultBase > Fault
const char * faultName() const
virtual TheISA::PCState pcState() const =0
DecoderFaultInst(ArmISA::ExtMachInst _machInst)
virtual ThreadContext * tcBase() const =0
Returns a pointer to the ThreadContext.
std::bitset< Num_Flags > flags
Flag values for this instruction.
bool warned
Have we warned on this instruction yet?
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
DecoderFault
Instruction decoder fault codes in ExtMachInst.
std::string fullMnemonic
Full mnemonic for MRC and MCR instructions including the coproc.
FailUnimplemented(const char *_mnemonic, ArmISA::ExtMachInst _machInst)
std::string generateDisassembly(Addr pc, const loader::SymbolTable *symtab) const override
Internal function to generate disassembly string.
Fault execute(ExecContext *xc, Trace::InstRecord *traceData) const override
IllegalExecInst(ArmISA::ExtMachInst _machInst)
SelfDebug * getSelfDebug() const
The ExecContext is an abstract base class the provides the interface used by the ISA to manipulate th...
Addr instAddr() const
Returns the memory address the bytes of this instruction came from.
const char * mnemonic
Base mnemonic (e.g., "add").
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
DebugStep(ArmISA::ExtMachInst _machInst)
#define panic(...)
This implements a cprintf based panic() function.
Generated on Tue Sep 7 2021 14:53:41 for gem5 by doxygen 1.8.17