| gem5
    v21.1.0.2
    | 
#include <self_debug.hh>
| Public Member Functions | |
| SelfDebug () | |
| ~SelfDebug () | |
| Fault | testDebug (ThreadContext *tc, const RequestPtr &req, BaseMMU::Mode mode) | 
| Fault | testVectorCatch (ThreadContext *tc, Addr addr, ArmFault *flt) | 
| bool | enabled () const | 
| BrkPoint * | getBrkPoint (uint8_t index) | 
| bool | isDebugEnabledForEL64 (ThreadContext *tc, ExceptionLevel el, bool secure, bool mask) | 
| bool | isDebugEnabledForEL32 (ThreadContext *tc, ExceptionLevel el, bool secure, bool mask) | 
| void | activateDebug () | 
| bool | isDebugEnabled (ThreadContext *tc) | 
| void | setbSDD (RegVal val) | 
| void | setMDSCRvals (RegVal val) | 
| void | setMDBGen (RegVal val) | 
| void | setenableTDETGE (HCR hcr, HDCR mdcr) | 
| void | updateOSLock (RegVal val) | 
| void | updateDBGBCR (int index, DBGBCR val) | 
| void | updateDBGWCR (int index, DBGWCR val) | 
| void | setDebugMask (bool mask) | 
| bool | isAArch32 () const | 
| void | setAArch32 (ThreadContext *tc) | 
| SoftwareStep * | getSstep () | 
| VectorCatch * | getVectorCatch (ThreadContext *tc) | 
| bool | targetAArch32 (ThreadContext *tc) | 
| void | init (ThreadContext *tc) | 
| Static Public Member Functions | |
| static bool | securityStateMatch (ThreadContext *tc, uint8_t ssc, bool hmc) | 
| Protected Member Functions | |
| Fault | testBreakPoints (ThreadContext *tc, Addr vaddr) | 
| Fault | testWatchPoints (ThreadContext *tc, Addr vaddr, bool write, bool atomic, unsigned size, bool cm) | 
| Fault | triggerException (ThreadContext *tc, Addr vaddr) | 
| Fault | triggerWatchpointException (ThreadContext *tc, Addr vaddr, bool write, bool cm) | 
| Private Attributes | |
| std::vector< BrkPoint > | arBrkPoints | 
| std::vector< WatchPoint > | arWatchPoints | 
| SoftwareStep * | softStep | 
| VectorCatch * | vcExcpt | 
| bool | initialized | 
| bool | enableTdeTge | 
| bool | mde | 
| bool | sdd | 
| bool | kde | 
| bool | oslk | 
| bool | aarch32 | 
| bool | to32 | 
Definition at line 277 of file self_debug.hh.
| 
 | inline | 
Definition at line 297 of file self_debug.hh.
References softStep.
| 
 | inline | 
Definition at line 304 of file self_debug.hh.
| 
 | inline | 
Definition at line 355 of file self_debug.hh.
References arBrkPoints, and gem5::MipsISA::p.
| 
 | inline | 
Definition at line 324 of file self_debug.hh.
References gem5::ArmISA::SoftwareStep::bSS, mde, and softStep.
Referenced by isDebugEnabledForEL32().
| 
 | inline | 
Definition at line 327 of file self_debug.hh.
References arBrkPoints, and gem5::MipsISA::index.
Referenced by gem5::ArmISA::BrkPoint::test(), and gem5::ArmISA::WatchPoint::test().
| 
 | inline | 
Definition at line 444 of file self_debug.hh.
References softStep.
| 
 | inline | 
Definition at line 450 of file self_debug.hh.
References init(), initialized, and vcExcpt.
| void gem5::SelfDebug::init | ( | ThreadContext * | tc | ) | 
Definition at line 327 of file self_debug.cc.
References aarch32, arBrkPoints, arWatchPoints, gem5::ArmISA::i, initialized, gem5::ArmISA::MISCREG_CPSR, gem5::ArmISA::MISCREG_DBGBCR0_EL1, gem5::ArmISA::MISCREG_DBGBVR0_EL1, gem5::ArmISA::MISCREG_DBGDEVID0, gem5::ArmISA::MISCREG_DBGWCR0, gem5::ArmISA::MISCREG_DBGWVR0, gem5::ArmISA::MISCREG_HCR_EL2, gem5::ArmISA::MISCREG_ID_AA64DFR0_EL1, gem5::ArmISA::MISCREG_ID_AA64MMFR1_EL1, gem5::ArmISA::MISCREG_ID_AA64MMFR2_EL1, gem5::ArmISA::MISCREG_MDCR_EL2, gem5::ArmISA::MISCREG_MDCR_EL3, gem5::ArmISA::MISCREG_MDSCR_EL1, gem5::ArmISA::MISCREG_OSLAR_EL1, gem5::ThreadContext::readMiscReg(), gem5::ThreadContext::readMiscRegNoEffect(), setbSDD(), setenableTDETGE(), setMDSCRvals(), gem5::ArmISA::BrkPoint::updateControl(), gem5::ArmISA::WatchPoint::updateControl(), updateOSLock(), and vcExcpt.
Referenced by getVectorCatch(), gem5::ArmISA::ISA::setupThreadContext(), testBreakPoints(), testVectorCatch(), and testWatchPoints().
| 
 | inline | 
Definition at line 427 of file self_debug.hh.
References aarch32.
Referenced by gem5::ArmISA::VectorCatch::addressMatching(), gem5::ArmISA::VectorCatch::exceptionTrapping(), gem5::ArmISA::BrkPoint::isEnabled(), gem5::ArmISA::WatchPoint::isEnabled(), and gem5::ArmISA::BrkPoint::testContextMatch().
| 
 | inline | 
Definition at line 363 of file self_debug.hh.
References aarch32, gem5::ArmISA::currEL(), gem5::ArmISA::el, isDebugEnabledForEL32(), isDebugEnabledForEL64(), gem5::ArmISA::isSecure(), gem5::ArmISA::MISCREG_CPSR, and gem5::ThreadContext::readMiscReg().
Referenced by gem5::ArmISA::SoftwareStep::debugExceptionReturnSS(), testBreakPoints(), testVectorCatch(), and testWatchPoints().
| bool gem5::SelfDebug::isDebugEnabledForEL32 | ( | ThreadContext * | tc, | 
| ExceptionLevel | el, | ||
| bool | secure, | ||
| bool | mask | ||
| ) | 
Definition at line 184 of file self_debug.cc.
References gem5::bits(), gem5::ArmISA::el, gem5::ArmISA::EL0, gem5::ArmISA::EL1, gem5::ArmISA::EL2, gem5::ArmISA::EL3, gem5::ArmISA::ELStateUsingAArch32(), enabled(), gem5::ArmSystem::haveEL(), isDebugEnabledForEL64(), gem5::ArmISA::mask, gem5::ArmISA::MISCREG_MDCR_EL3, gem5::ArmISA::MISCREG_SDER, oslk, and gem5::ThreadContext::readMiscReg().
Referenced by gem5::ArmISA::SoftwareStep::debugExceptionReturnSS(), and isDebugEnabled().
| bool gem5::SelfDebug::isDebugEnabledForEL64 | ( | ThreadContext * | tc, | 
| ExceptionLevel | el, | ||
| bool | secure, | ||
| bool | mask | ||
| ) | 
Definition at line 165 of file self_debug.cc.
References gem5::ArmISA::el, gem5::ArmISA::EL1, gem5::ArmISA::EL2, gem5::ArmISA::EL3, enableTdeTge, gem5::ArmSystem::haveEL(), gem5::ArmISA::HaveSecureEL2Ext(), kde, gem5::ArmISA::mask, oslk, and sdd.
Referenced by gem5::ArmISA::SoftwareStep::debugExceptionReturnSS(), isDebugEnabled(), and isDebugEnabledForEL32().
| 
 | inlinestatic | 
Definition at line 333 of file self_debug.hh.
References gem5::ArmISA::b, gem5::ArmISA::hmc, gem5::ArmISA::isSecure(), panic, and gem5::ArmISA::ssc.
Referenced by gem5::ArmISA::BrkPoint::isEnabled(), and gem5::ArmISA::WatchPoint::isEnabled().
| 
 | inline | 
Definition at line 433 of file self_debug.hh.
References aarch32, gem5::ArmISA::currEL(), gem5::ArmISA::EL0, gem5::ArmISA::EL1, and gem5::ArmISA::ELIs32().
Referenced by testBreakPoints(), testVectorCatch(), and testWatchPoints().
| 
 | inline | 
Definition at line 377 of file self_debug.hh.
References gem5::bits(), sdd, and gem5::X86ISA::val.
Referenced by init(), and gem5::ArmISA::ISA::setMiscReg().
| 
 | inline | 
Definition at line 421 of file self_debug.hh.
References gem5::ArmISA::SoftwareStep::cpsrD, gem5::ArmISA::mask, and softStep.
Referenced by gem5::ArmISA::ISA::setMiscReg().
| 
 | inline | 
Definition at line 397 of file self_debug.hh.
References enableTdeTge.
Referenced by init(), and gem5::ArmISA::ISA::setMiscReg().
| 
 | inline | 
Definition at line 391 of file self_debug.hh.
References gem5::bits(), mde, and gem5::X86ISA::val.
Referenced by gem5::ArmISA::ISA::setMiscReg().
| 
 | inline | 
Definition at line 383 of file self_debug.hh.
References gem5::bits(), gem5::ArmISA::SoftwareStep::bSS, kde, mde, softStep, and gem5::X86ISA::val.
Referenced by init(), and gem5::ArmISA::ISA::setMiscReg().
| 
 | inline | 
Definition at line 458 of file self_debug.hh.
References aarch32, gem5::ArmISA::debugTargetFrom(), gem5::ArmISA::ELIs32(), and gem5::ArmISA::isSecure().
Referenced by testBreakPoints(), testVectorCatch(), and testWatchPoints().
| 
 | protected | 
Definition at line 76 of file self_debug.cc.
References arBrkPoints, gem5::ArmISA::currEL(), gem5::ArmISA::el, init(), isDebugEnabled(), mde, gem5::NoFault, gem5::MipsISA::p, gem5::GenericISA::SimplePCState< InstWidth >::pc(), gem5::MipsISA::pc, gem5::ThreadContext::pcState(), setAArch32(), targetAArch32(), to32, triggerException(), and gem5::MipsISA::vaddr.
Referenced by testDebug().
| Fault gem5::SelfDebug::testDebug | ( | ThreadContext * | tc, | 
| const RequestPtr & | req, | ||
| BaseMMU::Mode | mode | ||
| ) | 
Definition at line 51 of file self_debug.cc.
References gem5::ArmISA::SoftwareStep::advanceSS(), gem5::BaseMMU::Execute, gem5::ArmISA::md, gem5::ArmISA::mode, gem5::NoFault, softStep, testBreakPoints(), testVectorCatch(), testWatchPoints(), and gem5::BaseMMU::Write.
| Fault gem5::SelfDebug::testVectorCatch | ( | ThreadContext * | tc, | 
| Addr | addr, | ||
| ArmFault * | flt | ||
| ) | 
Definition at line 715 of file self_debug.cc.
References aarch32, gem5::X86ISA::addr, gem5::ArmISA::VectorCatch::addressMatching(), gem5::ArmISA::currEL(), gem5::ArmISA::ArmFault::DebugEvent, gem5::ArmISA::EC_PREFETCH_ABORT_TO_HYP, gem5::ArmISA::el, enableTdeTge, gem5::ArmISA::VectorCatch::exceptionTrapping(), init(), initialized, isDebugEnabled(), mde, gem5::NoFault, setAArch32(), targetAArch32(), to32, gem5::ArmISA::ArmFault::UnknownTran, vcExcpt, and gem5::ArmISA::ArmFault::VECTORCATCH.
Referenced by testDebug().
| 
 | protected | 
Definition at line 125 of file self_debug.cc.
References arWatchPoints, gem5::ArmISA::atomic, gem5::ArmISA::cm, gem5::ArmISA::currEL(), gem5::ArmISA::el, init(), initialized, isDebugEnabled(), mde, gem5::NoFault, gem5::MipsISA::p, setAArch32(), targetAArch32(), to32, triggerWatchpointException(), and gem5::MipsISA::vaddr.
Referenced by testDebug().
| 
 | protected | 
Definition at line 112 of file self_debug.cc.
References gem5::ArmISA::ArmFault::BRKPOINT, gem5::ArmISA::ArmFault::DebugEvent, to32, gem5::ArmISA::ArmFault::UnknownTran, and gem5::MipsISA::vaddr.
Referenced by testBreakPoints().
| 
 | protected | 
Definition at line 149 of file self_debug.cc.
References gem5::ArmISA::cm, gem5::ArmISA::d, gem5::ArmISA::ArmFault::DebugEvent, gem5::ArmISA::TlbEntry::NoAccess, to32, gem5::ArmISA::ArmFault::UnknownTran, gem5::MipsISA::vaddr, gem5::ArmISA::ArmFault::WPOINT_CM, and gem5::ArmISA::ArmFault::WPOINT_NOCM.
Referenced by testWatchPoints().
| 
 | inline | 
Definition at line 409 of file self_debug.hh.
References arBrkPoints, gem5::MipsISA::index, and gem5::X86ISA::val.
Referenced by gem5::ArmISA::ISA::setMiscReg().
| 
 | inline | 
Definition at line 415 of file self_debug.hh.
References arWatchPoints, gem5::MipsISA::index, and gem5::X86ISA::val.
Referenced by gem5::ArmISA::ISA::setMiscReg().
| 
 | inline | 
Definition at line 403 of file self_debug.hh.
References gem5::bits(), oslk, and gem5::X86ISA::val.
Referenced by init(), and gem5::ArmISA::ISA::setMiscReg().
| 
 | private | 
Definition at line 293 of file self_debug.hh.
Referenced by init(), isAArch32(), isDebugEnabled(), setAArch32(), targetAArch32(), and testVectorCatch().
| 
 | private | 
Definition at line 280 of file self_debug.hh.
Referenced by activateDebug(), getBrkPoint(), init(), testBreakPoints(), and updateDBGBCR().
| 
 | private | 
Definition at line 281 of file self_debug.hh.
Referenced by init(), testWatchPoints(), and updateDBGWCR().
| 
 | private | 
Definition at line 286 of file self_debug.hh.
Referenced by isDebugEnabledForEL64(), setenableTDETGE(), and testVectorCatch().
| 
 | private | 
Definition at line 285 of file self_debug.hh.
Referenced by getVectorCatch(), init(), testVectorCatch(), and testWatchPoints().
| 
 | private | 
Definition at line 290 of file self_debug.hh.
Referenced by isDebugEnabledForEL64(), and setMDSCRvals().
| 
 | private | 
Definition at line 288 of file self_debug.hh.
Referenced by enabled(), setMDBGen(), setMDSCRvals(), testBreakPoints(), testVectorCatch(), and testWatchPoints().
| 
 | private | 
Definition at line 291 of file self_debug.hh.
Referenced by isDebugEnabledForEL32(), isDebugEnabledForEL64(), and updateOSLock().
| 
 | private | 
Definition at line 289 of file self_debug.hh.
Referenced by isDebugEnabledForEL64(), and setbSDD().
| 
 | private | 
Definition at line 282 of file self_debug.hh.
Referenced by enabled(), getSstep(), SelfDebug(), setDebugMask(), setMDSCRvals(), testDebug(), and ~SelfDebug().
| 
 | private | 
Definition at line 294 of file self_debug.hh.
Referenced by testBreakPoints(), testVectorCatch(), testWatchPoints(), triggerException(), and triggerWatchpointException().
| 
 | private | 
Definition at line 283 of file self_debug.hh.
Referenced by getVectorCatch(), init(), testVectorCatch(), and ~SelfDebug().