Go to the documentation of this file.
50 #include "debug/Arm.hh"
51 #include "debug/MiscRegs.hh"
55 #include "params/ArmISA.hh"
64 _decoderFlavor(
p->decoderFlavor), _vecRegRenameMode(Enums::Full),
65 pmu(
p->pmu), impdefAsNop(
p->impdef_nop),
160 mvfr0.advSimdRegisters = 2;
161 mvfr0.singlePrecision = 2;
162 mvfr0.doublePrecision = 2;
163 mvfr0.vfpExceptionTrapping = 0;
165 mvfr0.squareRoot = 1;
166 mvfr0.shortVectors = 1;
167 mvfr0.roundingModes = 1;
171 mvfr1.flushToZero = 1;
172 mvfr1.defaultNaN = 1;
173 mvfr1.advSimdLoadStore = 1;
174 mvfr1.advSimdInteger = 1;
175 mvfr1.advSimdSinglePrecision = 1;
176 mvfr1.advSimdHalfPrecision = 1;
177 mvfr1.vfpHalfPrecision = 1;
238 sctlr.te = (bool) sctlr_rst.te;
239 sctlr.nmfi = (
bool) sctlr_rst.nmfi;
240 sctlr.v = (bool) sctlr_rst.v;
298 panic(
"Invalid highest implemented exception level");
368 (
p->id_aa64dfr0_el1 & 0xfffffffffffff0ff
ULL) |
369 (
p->pmu ? 0x0000000000000100ULL : 0);
379 (
p->pmu ? 0x03000000
ULL : 0);
496 int lower = map.first, upper = map.second;
502 DPRINTF(MiscRegs,
"Reading MiscReg %s with set res0 bits: %#x\n",
506 DPRINTF(MiscRegs,
"Reading MiscReg %s with clear res1 bits: %#x\n",
523 cpsr.j =
pc.jazelle() ? 1 : 0;
524 cpsr.t =
pc.thumb() ? 1 : 0;
531 warn(
"Unimplemented system register %s read.\n",
534 panic(
"Unimplemented system register %s read.\n",
548 const uint32_t ones = (uint32_t)(-1);
552 cpacrMask.cp10 = ones;
553 cpacrMask.cp11 = ones;
554 cpacrMask.asedis = ones;
563 if (!nsacr.cp10) cpacrMask.cp10 = 0;
564 if (!nsacr.cp11) cpacrMask.cp11 = 0;
569 DPRINTF(MiscRegs,
"Reading misc reg %s: %#x\n",
599 warn_once(
"The clidr register always reports 0 caches.\n");
600 warn_once(
"clidr LoUIS field of 0b001 to match current "
601 "ARM implementations.\n");
604 warn_once(
"The ccsidr register isn't implemented and "
605 "always reads as 0.\n");
612 unsigned lineSizeWords =
614 unsigned log2LineSizeWords = 0;
616 while (lineSizeWords >>= 1) {
622 ctr.iCacheLineSize = log2LineSizeWords;
624 ctr.l1IndexPolicy = 0x3;
626 ctr.dCacheLineSize = log2LineSizeWords;
628 ctr.erg = log2LineSizeWords;
630 ctr.cwg = log2LineSizeWords;
637 warn(
"Not doing anything for miscreg ACTLR\n");
647 panic(
"shouldn't be reading this register seperately\n");
654 const uint32_t ones = (uint32_t)(-1);
656 fpscrMask.ioc = ones;
657 fpscrMask.dzc = ones;
658 fpscrMask.ofc = ones;
659 fpscrMask.ufc = ones;
660 fpscrMask.ixc = ones;
661 fpscrMask.idc = ones;
671 const uint32_t ones = (uint32_t)(-1);
673 fpscrMask.len = ones;
674 fpscrMask.fz16 = ones;
675 fpscrMask.stride = ones;
676 fpscrMask.rMode = ones;
679 fpscrMask.ahp = ones;
763 if (!secure_lookup) {
765 val |= (
mask ^ 0x7FFF) & 0xBFFF;
785 | (haveTimer ? 0x00010000 : 0x0);
788 return 0x0000000000000002 |
792 (
haveSVE ? 0x0000000100000000 : 0) |
822 int lower = map.first, upper = map.second;
828 DPRINTF(MiscRegs,
"Writing MiscReg %s (%d %d:%d) : %#x\n",
832 DPRINTF(MiscRegs,
"Writing MiscReg %s (%d %d) : %#x\n",
850 int old_mode = old_cpsr.mode;
852 if (old_mode != cpsr.mode || cpsr.il != old_cpsr.il) {
857 if (cpsr.pan != old_cpsr.pan) {
861 DPRINTF(
Arm,
"Updating CPSR from %#x to %#x f:%d i:%d a:%d mode:%#x\n",
862 miscRegs[misc_reg], cpsr, cpsr.f, cpsr.i, cpsr.a, cpsr.mode);
864 pc.nextThumb(cpsr.t);
865 pc.nextJazelle(cpsr.j);
866 pc.illegalExec(cpsr.il == 1);
883 warn(
"Unimplemented system register %s write with %#x.\n",
886 panic(
"Unimplemented system register %s write with %#x.\n",
896 const uint32_t ones = (uint32_t)(-1);
900 cpacrMask.cp10 = ones;
901 cpacrMask.cp11 = ones;
902 cpacrMask.asedis = ones;
911 if (!nsacr.cp10) cpacrMask.cp10 = 0;
912 if (!nsacr.cp11) cpacrMask.cp11 = 0;
918 newVal |= old_val & ~cpacrMask;
919 DPRINTF(MiscRegs,
"Writing misc reg %s: %#x\n",
925 const uint32_t ones = (uint32_t)(-1);
927 cpacrMask.tta = ones;
928 cpacrMask.fpen = ones;
930 cpacrMask.zen = ones;
933 DPRINTF(MiscRegs,
"Writing misc reg %s: %#x\n",
939 const uint32_t ones = (uint32_t)(-1);
941 cptrMask.tcpac = ones;
949 cptrMask.res1_13_12_el2 = ones;
950 cptrMask.res1_7_0_el2 = ones;
952 cptrMask.res1_8_el2 = ones;
954 cptrMask.res1_9_el2 = ones;
956 DPRINTF(MiscRegs,
"Writing misc reg %s: %#x\n",
962 const uint32_t ones = (uint32_t)(-1);
964 cptrMask.tcpac = ones;
971 DPRINTF(MiscRegs,
"Writing misc reg %s: %#x\n",
976 warn_once(
"The csselr register isn't implemented.\n");
980 warn(
"Calling DC ZVA! Not Implemeted! Expect WEIRD results\n");
985 const uint32_t ones = (uint32_t)(-1);
987 fpscrMask.ioc = ones;
988 fpscrMask.dzc = ones;
989 fpscrMask.ofc = ones;
990 fpscrMask.ufc = ones;
991 fpscrMask.ixc = ones;
992 fpscrMask.idc = ones;
993 fpscrMask.ioe = ones;
994 fpscrMask.dze = ones;
995 fpscrMask.ofe = ones;
996 fpscrMask.ufe = ones;
997 fpscrMask.ixe = ones;
998 fpscrMask.ide = ones;
999 fpscrMask.len = ones;
1000 fpscrMask.fz16 = ones;
1001 fpscrMask.stride = ones;
1002 fpscrMask.rMode = ones;
1003 fpscrMask.fz = ones;
1004 fpscrMask.dn = ones;
1005 fpscrMask.ahp = ones;
1006 fpscrMask.qc = ones;
1011 newVal = (newVal & (uint32_t)fpscrMask) |
1013 ~(uint32_t)fpscrMask);
1019 const uint32_t ones = (uint32_t)(-1);
1020 FPSCR fpscrMask = 0;
1021 fpscrMask.ioc = ones;
1022 fpscrMask.dzc = ones;
1023 fpscrMask.ofc = ones;
1024 fpscrMask.ufc = ones;
1025 fpscrMask.ixc = ones;
1026 fpscrMask.idc = ones;
1027 fpscrMask.qc = ones;
1032 newVal = (newVal & (uint32_t)fpscrMask) |
1034 ~(uint32_t)fpscrMask);
1040 const uint32_t ones = (uint32_t)(-1);
1041 FPSCR fpscrMask = 0;
1042 fpscrMask.len = ones;
1043 fpscrMask.fz16 = ones;
1044 fpscrMask.stride = ones;
1045 fpscrMask.rMode = ones;
1046 fpscrMask.fz = ones;
1047 fpscrMask.dn = ones;
1048 fpscrMask.ahp = ones;
1049 newVal = (newVal & (uint32_t)fpscrMask) |
1051 ~(uint32_t)fpscrMask);
1080 const uint32_t fpexcMask = 0x60000000;
1081 newVal = (newVal & fpexcMask) |
1107 const uint32_t temp = (
val == 0xC5ACCE55)? 0x1 : 0x0;
1109 r.oslk =
bits(temp,0);
1228 r.udccdis =
v.udccdis;
1229 r.mdbgen =
v.mdbgen;
1350 const uint32_t ifsrMask =
1352 newVal = newVal & ~ifsrMask;
1358 const uint32_t dfsrMask =
mask(31, 14) |
mask(8, 8);
1359 newVal = newVal & ~dfsrMask;
1369 DPRINTF(MiscRegs,
"Writing AMAIR: %#x\n", newVal);
1378 DPRINTF(MiscRegs,
"Writing SCTLR: %#x\n", newVal);
1389 SCTLR new_sctlr = newVal;
1482 mbits(newVal, 31, 12),
1497 mbits(newVal, 31, 12),
1540 mbits(newVal, 31,12));
1553 mbits(newVal, 31,12));
1569 mbits(newVal, 31,12));
1582 mbits(newVal, 31,12));
1599 static_cast<Addr>(
bits(newVal, 35, 0)) << 12);
1614 static_cast<Addr>(
bits(newVal, 35, 0)) << 12);
1627 mbits(newVal, 31, 12),
1641 mbits(newVal, 31, 12),
1757 bool is_host = (hcr.tge && hcr.e2h);
1782 bool is_host = (hcr.tge && hcr.e2h);
1799 static_cast<Addr>(
bits(newVal, 43, 0)) << 12,
1811 static_cast<Addr>(
bits(newVal, 43, 0)) << 12,
1825 static_cast<Addr>(
bits(newVal, 43, 0)) << 12,
1838 static_cast<Addr>(
bits(newVal, 43, 0)) << 12,
1851 bits(newVal, 55, 48);
1854 bool is_host = (hcr.tge && hcr.e2h);
1857 static_cast<Addr>(
bits(newVal, 43, 0)) << 12,
1870 bits(newVal, 55, 48);
1873 bool is_host = (hcr.tge && hcr.e2h);
1876 static_cast<Addr>(
bits(newVal, 43, 0)) << 12,
1889 bits(newVal, 55, 48);
1892 bool is_host = (hcr.tge && hcr.e2h);
1904 bits(newVal, 55, 48);
1907 bool is_host = (hcr.tge && hcr.e2h);
1923 bool is_host = (hcr.tge && hcr.e2h);
1926 static_cast<Addr>(
bits(newVal, 43, 0)) << 12);
1939 bool is_host = (hcr.tge && hcr.e2h);
1942 static_cast<Addr>(
bits(newVal, 43, 0)) << 12);
1956 static_cast<Addr>(
bits(newVal, 35, 0)) << 12);
1970 static_cast<Addr>(
bits(newVal, 35, 0)) << 12);
1976 warn(
"Not doing anything for write of miscreg ACTLR\n");
1991 newVal &= ~((uint32_t) hstrMask);
1999 if (!secure_lookup) {
2003 newVal = (newVal & ~
mask) | (oldValue &
mask);
2029 panic(
"Security Extensions required for ATS12NSOPR");
2034 panic(
"Security Extensions required for ATS12NSOPW");
2039 panic(
"Security Extensions required for ATS12NSOUR");
2045 panic(
"Security Extensions required for ATS12NSOUW");
2058 const uint32_t ones = (uint32_t)(-1);
2059 TTBCR ttbcrMask = 0;
2060 TTBCR ttbcrNew = newVal;
2065 ttbcrMask.pd0 = ones;
2066 ttbcrMask.pd1 = ones;
2068 ttbcrMask.epd0 = ones;
2069 ttbcrMask.irgn0 = ones;
2070 ttbcrMask.orgn0 = ones;
2071 ttbcrMask.sh0 = ones;
2072 ttbcrMask.ps = ones;
2073 ttbcrMask.a1 = ones;
2074 ttbcrMask.epd1 = ones;
2075 ttbcrMask.irgn1 = ones;
2076 ttbcrMask.orgn1 = ones;
2077 ttbcrMask.sh1 = ones;
2079 ttbcrMask.eae = ones;
2082 newVal = newVal & ttbcrMask;
2084 newVal = (newVal & ttbcrMask) | (ttbcr & (~ttbcrMask));
2099 uint64_t ttbrMask =
mask(63,56) |
mask(47,40);
2100 newVal = (newVal & (~ttbrMask));
2151 cpsr.daif = (uint8_t) ((CPSR) newVal).
daif;
2168 cpsr.sp = (uint8_t) ((CPSR) newVal).
sp;
2176 cpsr.el = (uint8_t) ((CPSR) newVal).
el;
2187 cpsr.pan = (uint8_t) ((CPSR) newVal).
pan;
2237 ~(0x2 << 22) : ~(0x3 << 22);
2239 newVal =
val & spsr_mask;
2243 warn(
"miscreg L2CTLR (%s) written with %#x. ignored...\n",
2273 return *
timer.get();
2277 if (!generic_timer) {
2278 panic(
"Trying to get a generic timer from a system that hasn't "
2279 "been configured to use a generic timer.\n");
2285 return *
timer.get();
2303 "A ThreadContext is needed to determine the SVE vector length "
2304 "in full-system mode");
2321 static_cast<unsigned>(
2330 static_cast<unsigned>(
2336 return (
len + 1) * 128;
2342 auto vv = vc.
as<uint64_t>();
2343 for (
int i = 2;
i < eCount; ++
i) {
2358 warn_once(
"Doing AT (address translation) in functional mode! Fix Me!\n");
2360 auto req = std::make_shared<Request>(
2365 req,
tc,
mode, tran_type);
2369 Addr paddr = req->getPaddr();
2371 uint64_t attr1 =
attr >> 56;
2372 if (!attr1 || attr1 ==0x44) {
2374 attr &= ~ uint64_t(0x80);
2376 par = (paddr &
mask(47, 12)) |
attr;
2378 "MISCREG: Translated addr %#x: PAR_EL1: %#xx\n",
2387 par.fst = fsr.status;
2388 par.ptw = (arm_fault->
iss() >> 7) & 0x1;
2389 par.s = arm_fault->
isStage2() ? 1 : 0;
2392 "MISCREG: Translated addr %#x fault fsr %#x: PAR: %#x\n",
2409 warn_once(
"Doing AT (address translation) in functional mode! Fix Me!\n");
2411 auto req = std::make_shared<Request>(
2416 req,
tc,
mode, tran_type);
2420 Addr paddr = req->getPaddr();
2424 uint8_t max_paddr_bit = 0;
2433 par = (paddr &
mask(max_paddr_bit, 12)) |
2437 "MISCREG: Translated addr 0x%08x: PAR: 0x%08x\n",
2446 par.lpae = fsr.lpae;
2447 par.ptw = (arm_fault->
iss() >> 7) & 0x1;
2448 par.s = arm_fault->
isStage2() ? 1 : 0;
2452 par.fst = fsr.status;
2455 par.fs4_0 = fsr.fsLow | (fsr.fsHigh << 5);
2459 "MISCREG: Translated addr 0x%08x fault fsr %#x: PAR: 0x%08x\n",
2481 ArmISAParams::create()
void setupThreadContext()
virtual RegVal readMiscRegNoEffect(RegIndex misc_reg) const =0
@ MISCREG_ID_AA64MMFR2_EL1
bool ELIsInHost(ThreadContext *tc, ExceptionLevel el)
Returns true if the current exception level el is executing a Host OS or an application of a Host OS ...
@ MISCREG_ICC_IGRPEN1_EL3
@ MISCREG_TLBI_IPAS2E1IS_Xt
@ MISCREG_ID_AA64AFR1_EL1
uint8_t encodePhysAddrRange64(int pa_size)
Returns the encoding corresponding to the specified n.
std::pair< int, int > getMiscIndices(int misc_reg) const
void initializeMiscRegMetadata()
@ MISCREG_ID_AA64ISAR1_EL1
void init(ThreadContext *tc)
bool haveCrypto() const
Returns true if this system implements the Crypto Extension.
uint8_t physAddrRange() const
Returns the supported physical address range in bits.
@ MISCREG_TLBI_VAALE1IS_Xt
Base class for devices that use the MiscReg interfaces.
void preUnflattenMiscReg()
virtual uint32_t iss() const =0
bool highestELIs64() const
Returns true if the register width of the highest implemented exception level is 64 bits (ARMv8)
RegVal miscRegs[NumMiscRegs]
Addr resetAddr() const
Returns the reset address if the highest implemented exception level is 64 bits (ARMv8)
@ MISCREG_ID_AA64ZFR0_EL1
@ MISCREG_ID_AA64ISAR0_EL1
@ MISCREG_TLBI_VAAE1IS_Xt
void setMDBGen(RegVal val)
std::unique_ptr< BaseISADevice > gicv3CpuInterface
virtual void setThreadContext(ThreadContext *tc)
virtual void setIntReg(RegIndex reg_idx, RegVal val)=0
@ MISCREG_TLBI_VMALLS12E1
@ MISCREG_TLBI_VALE3IS_Xt
void updateDBGWCR(int index, DBGWCR val)
void setMiscReg(int misc_reg, RegVal val)
@ MISCREG_TLBI_ASIDE1IS_Xt
bool haveSVE() const
Returns true if SVE is implemented (ARMv8)
@ MISCREG_TLBI_IPAS2LE1IS_Xt
virtual bool isStage2() const
void broadcast(ThreadContext *tc)
Broadcast the TLB Invalidate operation to all TLBs in the Arm system.
int redirectRegVHE(ThreadContext *tc, int misc_reg)
Returns the enconcing equivalent when VHE is implemented and HCR_EL2.E2H is enabled and executing at ...
bool FullSystem
The FullSystem variable can be used to determine the current mode of simulation.
BaseGic * getGIC() const
Get a pointer to the system's GIC.
T mbits(T val, int first, int last)
Mask off the given bits in place like bits() but without shifting.
GenericTimer * getGenericTimer() const
Get a pointer to the system's generic timer model.
virtual void setHtmCheckpointPtr(BaseHTMCheckpointPtr cpt)=0
TLB Invalidate by ASID match.
int unflattenMiscReg(int reg)
const char *const miscRegName[]
unsigned sveVL
SVE vector length in quadwords.
@ MISCREG_TLBI_VALE2IS_Xt
bool haveVirtualization() const
Returns true if this system implements the virtualization Extensions.
RegVal readMiscRegNoEffect(int misc_reg) const
static void zeroSveVecRegUpperPart(VecRegContainer &vc, unsigned eCount)
void takeOverFrom(ThreadContext *new_tc, ThreadContext *old_tc) override
@ MISCREG_ID_AA64MMFR0_EL1
virtual int threadId() const =0
void addressTranslation(TLB::ArmTranslationType tran_type, BaseTLB::Mode mode, Request::Flags flags, RegVal val)
@ MISCREG_ID_AA64AFR0_EL1
std::unique_ptr< BaseISADevice > timer
VecRegT< VecElem, NumElems, true > as() const
View interposers.
@ MISCREG_ID_AA64DFR1_EL1
const Enums::VecRegRenameMode _vecRegRenameMode
virtual void startup()
startup() is the final initialization call before simulation.
void setDebugMask(bool mask)
bool ELIs32(ThreadContext *tc, ExceptionLevel el)
virtual void setMiscReg(int misc_reg, RegVal val)=0
Write to a system register belonging to this device.
@ MISCREG_ID_AA64PFR0_EL1
bool haveSecurity() const
Returns true if this system implements the Security Extensions.
ThreadContext is the external interface to all thread state for anything outside of the CPU.
DummyISADevice dummyDevice
Dummy device for to handle non-existing ISA devices.
bool haveLPAE() const
Returns true if this system implements the Large Physical Address Extension.
bool haveLSE() const
Returns true if LSE is implemented (ARMv8.1)
virtual void pcStateNoRecord(const TheISA::PCState &val)=0
void clear32(const ArmISAParams *p, const SCTLR &sctlr_rst)
bool havePAN() const
Returns true if Priviledge Access Never is implemented.
void setMDSCRvals(RegVal val)
std::shared_ptr< FaultBase > Fault
@ MISCREG_ID_AA64MMFR1_EL1
static const uint32_t FpscrExcMask
BaseISADevice & getGICv3CPUInterface()
@ MISCREG_ID_AA64DFR0_EL1
@ MISCREG_TLBI_VMALLS12E1IS
unsigned sveVL() const
Returns the SVE vector length at reset, in quadwords.
bool haveSecEL2() const
Returns true if Priviledge Access Never is implemented.
virtual ContextID contextId() const =0
void clear64(const ArmISAParams *p)
TLB Invalidate by VA, All ASID.
chain highest(ArmSystem *const sys) const
void setMiscRegNoEffect(int misc_reg, RegVal val)
constexpr decltype(nullptr) NoFault
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
RegVal readMPIDR(ArmSystem *arm_sys, ThreadContext *tc)
This helper function is either returing the value of MPIDR_EL1 (by calling getMPIDR),...
void updateOSLock(RegVal val)
chain hyp(bool v=true) const
void updateRegMap(CPSR cpsr)
BaseISADevice & getGenericTimer()
virtual TheISA::PCState pcState() const =0
static const uint32_t CpsrMaskQ
@ funcRequestorId
This requestor id is used for functional requests that don't come from a particular device.
virtual RegVal readCCReg(RegIndex reg_idx) const =0
const typedef MiscRegLUTEntryInitializer & chain
Data TLB Invalidate by VA.
Instruction TLB Invalidate All.
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
@ MISCREG_TLBI_VALE1IS_Xt
virtual void setCCReg(RegIndex reg_idx, RegVal val)=0
void update(ThreadContext *tc)
GenericISA::DelaySlotPCState< MachInst > PCState
const SimObjectParams * _params
Cached copy of the object parameters.
void initID64(const ArmISAParams *p)
Gicv3CPUInterface * getCPUInterface(int cpu_id) const
ArmISA::ExceptionLevel highestEL() const
Returns the highest implemented exception level.
T insertBits(T val, int first, int last, B bit_val)
Returns val with bits first to last set to the LSBs of bit_val.
virtual FSR getFsr(ThreadContext *tc) const
virtual RegVal readMiscReg(RegIndex misc_reg)=0
@ MISCREG_PMXEVTYPER_PMCCFILTR
virtual CheckerCPU * getCheckerCpuPtr()=0
virtual void setMiscReg(RegIndex misc_reg, RegVal val)=0
TLB Invalidate by Intermediate Physical Address.
virtual TheISA::Decoder * getDecoderPtr()=0
@ MISCREG_TLBI_IPAS2E1_Xt
static const uint32_t FpscrQcMask
void startup() override
startup() is the final initialization call before simulation.
RegVal readMiscReg(int misc_reg)
void updateDBGBCR(int index, DBGBCR val)
chain mon(bool v=true) const
void addressTranslation64(TLB::ArmTranslationType tran_type, BaseTLB::Mode mode, Request::Flags flags, RegVal val)
unsigned getCurSveVecLenInBits() const
Data TLB Invalidate by ASID match.
void initID32(const ArmISAParams *p)
unsigned int cacheLineSize() const
Get the cache line size of the system.
Instruction TLB Invalidate by ASID match.
chain priv(bool v=true) const
virtual RegVal readIntReg(RegIndex reg_idx) const =0
bool haveTME() const
Returns true if this system implements the transactional memory extension (ARMv9)
void setenableTDETGE(HCR hcr, HDCR mdcr)
virtual void setISA(ISA *isa)
@ MISCREG_TLBI_IPAS2LE1_Xt
virtual BaseCPU * getCpuPtr()=0
bitset< NUM_MISCREG_INFOS > miscRegInfo[NUM_MISCREGS]
const Params * params() const
BaseInterrupts * getInterruptController(ThreadID tid)
@ MISCREG_ID_AA64PFR1_EL1
bool haveVHE() const
Returns true if Virtualization Host Extensions is implemented.
Instruction TLB Invalidate by VA.
bool translateFunctional(ThreadContext *tc, Addr vaddr, Addr &paddr)
Do a functional lookup on the TLB (for debugging) and don't modify any internal state.
#define ULL(N)
uint64_t constant
Vector Register Abstraction This generic class is the model in a particularization of MVC,...
bool isSecure(ThreadContext *tc)
static std::vector< struct MiscRegLUTEntry > lookUpMiscReg
Metadata table accessible via the value of the register.
virtual System * getSystemPtr()=0
bool haveLargeAsid64() const
Returns true if ASID is 16 bits in AArch64 (ARMv8)
#define panic(...)
This implements a cprintf based panic() function.
TLB Invalidate All, Non-Secure.
virtual RegVal readMiscReg(int misc_reg)=0
Read a system register belonging to this device.
T bits(T val, int first, int last)
Extract the bitfield from position 'first' to 'last' (inclusive) from 'val' and right justify it.
Generated on Thu Mar 18 2021 12:09:08 for gem5 by doxygen 1.8.17