Go to the documentation of this file.
39 #ifndef __ARCH_ARM_SELF_DEBUG_HH__
40 #define __ARCH_ARM_SELF_DEBUG_HH__
79 bool vmid16,
bool aarch32):
160 SelfDebug* _conf,
bool lva,
bool aarch32) :
169 uint8_t
bas, uint8_t
mask,
unsigned size);
190 uint8_t
ssc, uint8_t
pac);
192 bool atomic,
unsigned size);
268 return (
Addr) 0xFFFF0000;
316 bool atomic,
unsigned size,
bool cm);
320 bool write,
bool cm);
336 case 0x0:
return true;
344 default:
panic(
"Unreachable value");
350 bool secure,
bool mask);
352 bool secure,
bool mask);
Fault testWatchPoints(ThreadContext *tc, Addr vaddr, bool write, bool atomic, unsigned size, bool cm)
void updateControl(DBGWCR val)
void setenableTDETGE(HCR hcr, HDCR mdcr)
void init(ThreadContext *tc)
virtual RegVal readMiscReg(RegIndex misc_reg)=0
bool isDoubleAligned(Addr addr)
bool test(ThreadContext *tc, Addr pc, ExceptionLevel el, DBGBCR ctr, bool from_link)
static const uint8_t ACTIVE_PENDING_STATE
BrkPoint(MiscRegIndex ctrl_index, MiscRegIndex val_index, SelfDebug *_conf, bool ctx_aw, bool lva, bool vmid16, bool aarch32)
RegVal getContextfromReg(ThreadContext *tc, bool ctxid1) const
bool testVMIDMatch(ThreadContext *tc)
MiscRegIndex ctrlRegIndex
std::vector< BrkPoint > arBrkPoints
bool testAddrMissMatch(ThreadContext *tc, Addr pc, uint8_t bas)
bool isDebugEnabledForEL64(ThreadContext *tc, ExceptionLevel el, bool secure, bool mask)
MiscRegIndex ctrlRegIndex
void updateOSLock(RegVal val)
bool targetAArch32(ThreadContext *tc)
bool debugExceptionReturnSS(ThreadContext *tc, CPSR spsr, ExceptionLevel dest)
bool advanceSS(ThreadContext *tc)
SoftwareStep * getSstep()
Fault testBreakPoints(ThreadContext *tc, Addr vaddr)
bool isDebugEnabledForEL32(ThreadContext *tc, ExceptionLevel el, bool secure, bool mask)
bool testAddrMatch(ThreadContext *tc, Addr pc, uint8_t bas)
void updateDBGBCR(int index, DBGBCR val)
Fault testDebug(ThreadContext *tc, const RequestPtr &req, BaseMMU::Mode mode)
bool isActive(Addr vaddr)
Bitfield< 23, 20 > atomic
bool testContextMatch(ThreadContext *tc, bool ctx1, bool low_ctx)
Addr getAddrfromReg(ThreadContext *tc) const
void setMDBGen(RegVal val)
Fault triggerException(ThreadContext *tc, Addr vaddr)
void setMDSCRvals(RegVal val)
ThreadContext is the external interface to all thread state for anything outside of the CPU.
Addr getAddrfromReg(ThreadContext *tc)
std::shared_ptr< FaultBase > Fault
static const uint8_t INACTIVE_STATE
const DBGBCR getControlReg(ThreadContext *tc)
bool testLinkedBk(ThreadContext *tc, Addr vaddr, ExceptionLevel el)
bool test(ThreadContext *tc, Addr addr, ExceptionLevel el, bool &wrt, bool atomic, unsigned size)
bool exceptionTrapping(ThreadContext *tc, ExceptionLevel el, ArmFault *fault)
bool ELIs32(ThreadContext *tc, ExceptionLevel el)
std::shared_ptr< Request > RequestPtr
static const uint8_t ACTIVE_NOT_PENDING_STATE
static bool securityStateMatch(ThreadContext *tc, uint8_t ssc, bool hmc)
constexpr T bits(T val, unsigned first, unsigned last)
Extract the bitfield from position 'first' to 'last' (inclusive) from 'val' and right justify it.
bool isEnabled(ThreadContext *tc, ExceptionLevel el, bool hmc, uint8_t ssc, uint8_t pac)
ExceptionLevel debugTargetFrom(ThreadContext *tc, bool secure)
WatchPoint(MiscRegIndex ctrl_index, MiscRegIndex val_index, SelfDebug *_conf, bool lva, bool aarch32)
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
bool isSecure(ThreadContext *tc)
ExceptionLevel currEL(const ThreadContext *tc)
Returns the current Exception Level (EL) of the provided ThreadContext.
vmid_t getVMIDfromReg(ThreadContext *tc, bool vs)
VectorCatch * getVectorCatch(ThreadContext *tc)
bool isDebugEnabled(ThreadContext *tc)
Fault testVectorCatch(ThreadContext *tc, Addr addr, ArmFault *flt)
BrkPoint * getBrkPoint(uint8_t index)
std::vector< Fault * > vectorTypes()
std::vector< WatchPoint > arWatchPoints
void updateDBGWCR(int index, DBGWCR val)
void updateControl(DBGBCR val)
bool isEnabled(ThreadContext *tc, ExceptionLevel el, uint8_t hmc, uint8_t ssc, uint8_t pmc)
VectorCatch(bool _vcmatch, SelfDebug *s)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
void setDebugMask(bool mask)
Fault triggerWatchpointException(ThreadContext *tc, Addr vaddr, bool write, bool cm)
bool addressMatching(ThreadContext *tc, Addr addr, ExceptionLevel el)
bool compareAddress(ThreadContext *tc, Addr in_addr, uint8_t bas, uint8_t mask, unsigned size)
void setAArch32(ThreadContext *tc)
Addr getVectorBase(ThreadContext *tc, bool monitor)
#define panic(...)
This implements a cprintf based panic() function.
SoftwareStep(SelfDebug *s)
Generated on Thu Jun 16 2022 10:41:41 for gem5 by doxygen 1.8.17