Go to the documentation of this file.
48 using namespace ArmISA;
68 return std::make_shared<PCAlignmentFault>(
pc);
72 return std::make_shared<PrefetchAbort>(
77 panic(
"Internal error in instruction decoder\n");
80 panic(
"Decoder fault instruction without decoder fault.\n");
83 panic(
"Unhandled fault type");
94 return "UnalignedInstruction";
97 return "DecoderPanic";
100 panic(
"Unhandled fault type");
118 flags[IsNonSpeculative] =
true;
123 const std::string& _fullMnemonic)
124 : ArmStaticInst(_mnemonic, _machInst, No_OpClass),
125 fullMnemonic(_fullMnemonic)
129 flags[IsNonSpeculative] =
true;
142 return csprintf(
"%-10s (unimplemented)",
150 :
ArmStaticInst(_mnemonic, _machInst, No_OpClass), warned(false)
154 flags[IsNonSpeculative] =
true;
159 const std::string& _fullMnemonic)
160 : ArmStaticInst(_mnemonic, _machInst, No_OpClass), warned(false),
161 fullMnemonic(_fullMnemonic)
165 flags[IsNonSpeculative] =
true;
172 warn(
"\tinstruction '%s' unimplemented\n",
184 return csprintf(
"%-10s (unimplemented)",
195 return std::make_shared<IllegalInstSetStateFault>();
206 pc_state.debugStep(
false);
211 bool ldx =
sd->getSstep()->getLdx();
213 return std::make_shared<SoftwareStepFault>(
machInst, ldx,
Addr instAddr() const
Returns the memory address of the instruction this PC points to.
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
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.
virtual const PCStateBase & pcState() const =0
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...
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 Dec 21 2021 11:34:20 for gem5 by doxygen 1.8.17