| gem5 v23.0.0.1
    | 
#include <faults.hh>
 
  
| Protected Member Functions | |
| RiscvFault (FaultName n, FaultType ft, ExceptionCode c) | |
| FaultName | name () const override | 
| bool | isInterrupt () const | 
| bool | isNonMaskableInterrupt () const | 
| ExceptionCode | exception () const | 
| virtual RegVal | trap_value () const | 
| virtual void | invokeSE (ThreadContext *tc, const StaticInstPtr &inst) | 
| void | invoke (ThreadContext *tc, const StaticInstPtr &inst) override | 
| Protected Attributes | |
| const FaultName | _name | 
| const FaultType | _fault_type | 
| ExceptionCode | _code | 
| Additional Inherited Members | |
|  Public Member Functions inherited from gem5::FaultBase | |
| virtual FaultName | name () const =0 | 
| virtual void | invoke (ThreadContext *tc, const StaticInstPtr &inst=nullStaticInstPtr) | 
| virtual | ~FaultBase () | 
| 
 | inlineprotected | 
| 
 | inlineprotected | 
| 
 | overrideprotectedvirtual | 
Reimplemented from gem5::FaultBase.
Definition at line 60 of file faults.cc.
References _code, gem5::X86ISA::addr, gem5::StaticInst::advancePC(), gem5::PCStateBase::as(), gem5::bits(), gem5::RiscvISA::CAUSE_INTERRUPT_MASKS, gem5::BaseISA::clearLoadReservation(), gem5::ThreadContext::contextId(), DPRINTFS, gem5::FullSystem, gem5::ThreadContext::getCpuPtr(), gem5::ThreadContext::getIsaPtr(), gem5::PCStateBase::instAddr(), invokeSE(), isInterrupt(), isNonMaskableInterrupt(), gem5::mbits(), gem5::RiscvISA::MISCREG_MCAUSE, gem5::RiscvISA::MISCREG_MEDELEG, gem5::RiscvISA::MISCREG_MEPC, gem5::RiscvISA::MISCREG_MIDELEG, gem5::RiscvISA::MISCREG_MTVAL, gem5::RiscvISA::MISCREG_MTVEC, gem5::RiscvISA::MISCREG_NMIE, gem5::RiscvISA::MISCREG_NMIVEC, gem5::RiscvISA::MISCREG_PRV, gem5::RiscvISA::MISCREG_SCAUSE, gem5::RiscvISA::MISCREG_SEDELEG, gem5::RiscvISA::MISCREG_SEPC, gem5::RiscvISA::MISCREG_SIDELEG, gem5::RiscvISA::MISCREG_STATUS, gem5::RiscvISA::MISCREG_STVAL, gem5::RiscvISA::MISCREG_STVEC, gem5::RiscvISA::MISCREG_UCAUSE, gem5::RiscvISA::MISCREG_UEPC, gem5::RiscvISA::MISCREG_UTVAL, gem5::RiscvISA::MISCREG_UTVEC, name(), panic, gem5::ThreadContext::pcState(), gem5::RiscvISA::PRV_M, gem5::RiscvISA::PRV_S, gem5::RiscvISA::PRV_U, gem5::ThreadContext::readMiscReg(), gem5::ThreadContext::setMiscReg(), gem5::ArmISA::status, trap_value(), and warn_if.
| 
 | protectedvirtual | 
Reimplemented in gem5::RiscvISA::UnknownInstFault, gem5::RiscvISA::IllegalInstFault, gem5::RiscvISA::UnimplementedFault, gem5::RiscvISA::IllegalFrmFault, gem5::RiscvISA::BreakpointFault, and gem5::RiscvISA::SyscallFault.
Definition at line 54 of file faults.cc.
References name(), panic, and gem5::ThreadContext::pcState().
Referenced by invoke().
| 
 | inlineprotected | 
Definition at line 122 of file faults.hh.
References _fault_type, and gem5::RiscvISA::INTERRUPT.
Referenced by invoke().
| 
 | inlineprotected | 
Definition at line 123 of file faults.hh.
References _fault_type, and gem5::RiscvISA::NON_MASKABLE_INTERRUPT.
Referenced by invoke().
| 
 | inlineoverrideprotectedvirtual | 
Implements gem5::FaultBase.
Definition at line 121 of file faults.hh.
References _name.
Referenced by invoke(), and invokeSE().
| 
 | inlineprotectedvirtual | 
Reimplemented in gem5::RiscvISA::InstFault, gem5::RiscvISA::AddressFault, and gem5::RiscvISA::BreakpointFault.
Definition at line 128 of file faults.hh.
Referenced by invoke().
| 
 | protected | 
Definition at line 115 of file faults.hh.
Referenced by exception(), invoke(), and gem5::RiscvISA::SyscallFault::SyscallFault().
| 
 | protected | 
Definition at line 114 of file faults.hh.
Referenced by isInterrupt(), and isNonMaskableInterrupt().
| 
 | protected |