diff options
Diffstat (limited to 'src/arch/arm/faults.hh')
-rw-r--r-- | src/arch/arm/faults.hh | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/src/arch/arm/faults.hh b/src/arch/arm/faults.hh index de5061bed..8f860970d 100644 --- a/src/arch/arm/faults.hh +++ b/src/arch/arm/faults.hh @@ -545,6 +545,15 @@ class SystemError : public ArmFaultVals<SystemError> bool routeToHyp(ThreadContext *tc) const override; }; +/// System error (AArch64 only) +class SoftwareBreakpoint : public ArmFaultVals<SoftwareBreakpoint> +{ + public: + SoftwareBreakpoint(ExtMachInst _mach_inst, uint32_t _iss); + + bool routeToHyp(ThreadContext *tc) const override; +}; + // A fault that flushes the pipe, excluding the faulting instructions class ArmSev : public ArmFaultVals<ArmSev> { @@ -583,6 +592,7 @@ template<> ArmFault::FaultVals ArmFaultVals<SecureMonitorTrap>::vals; template<> ArmFault::FaultVals ArmFaultVals<PCAlignmentFault>::vals; template<> ArmFault::FaultVals ArmFaultVals<SPAlignmentFault>::vals; template<> ArmFault::FaultVals ArmFaultVals<SystemError>::vals; +template<> ArmFault::FaultVals ArmFaultVals<SoftwareBreakpoint>::vals; template<> ArmFault::FaultVals ArmFaultVals<ArmSev>::vals; |