Go to the documentation of this file.
51 #include "debug/Arm.hh"
52 #include "debug/MiscRegs.hh"
56 #include "params/ArmISA.hh"
68 _decoderFlavor(
p.decoderFlavor), 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");
370 (
p.id_aa64dfr0_el1 & 0xfffffffffffff0ffULL) |
371 (
p.pmu ? 0x0000000000000100ULL : 0);
381 (
p.pmu ? 0x03000000ULL : 0);
498 if (src_mode == enums::Full) {
512 for (
int i = 0;
i < NUM_INTREGS;
i++)
541 int lower = map.first, upper = map.second;
547 DPRINTF(MiscRegs,
"Reading MiscReg %s with set res0 bits: %#x\n",
551 DPRINTF(MiscRegs,
"Reading MiscReg %s with clear res1 bits: %#x\n",
568 cpsr.j =
pc.jazelle() ? 1 : 0;
569 cpsr.t =
pc.thumb() ? 1 : 0;
576 warn(
"Unimplemented system register %s read.\n",
579 panic(
"Unimplemented system register %s read.\n",
593 const uint32_t ones = (uint32_t)(-1);
597 cpacrMask.cp10 = ones;
598 cpacrMask.cp11 = ones;
599 cpacrMask.asedis = ones;
608 if (!nsacr.cp10) cpacrMask.cp10 = 0;
609 if (!nsacr.cp11) cpacrMask.cp11 = 0;
614 DPRINTF(MiscRegs,
"Reading misc reg %s: %#x\n",
644 warn_once(
"The clidr register always reports 0 caches.\n");
645 warn_once(
"clidr LoUIS field of 0b001 to match current "
646 "ARM implementations.\n");
649 warn_once(
"The ccsidr register isn't implemented and "
650 "always reads as 0.\n");
657 unsigned lineSizeWords =
659 unsigned log2LineSizeWords = 0;
661 while (lineSizeWords >>= 1) {
667 ctr.iCacheLineSize = log2LineSizeWords;
669 ctr.l1IndexPolicy = 0x3;
671 ctr.dCacheLineSize = log2LineSizeWords;
673 ctr.erg = log2LineSizeWords;
675 ctr.cwg = log2LineSizeWords;
682 warn(
"Not doing anything for miscreg ACTLR\n");
692 panic(
"shouldn't be reading this register seperately\n");
699 const uint32_t ones = (uint32_t)(-1);
701 fpscrMask.ioc = ones;
702 fpscrMask.dzc = ones;
703 fpscrMask.ofc = ones;
704 fpscrMask.ufc = ones;
705 fpscrMask.ixc = ones;
706 fpscrMask.idc = ones;
716 const uint32_t ones = (uint32_t)(-1);
718 fpscrMask.len = ones;
719 fpscrMask.fz16 = ones;
720 fpscrMask.stride = ones;
721 fpscrMask.rMode = ones;
724 fpscrMask.ahp = ones;
808 if (!secure_lookup) {
810 val |= (
mask ^ 0x7FFF) & 0xBFFF;
830 | (haveTimer ? 0x00010000 : 0x0);
833 return 0x0000000000000002 |
837 (
haveSVE ? 0x0000000100000000 : 0) |
867 int lower = map.first, upper = map.second;
873 DPRINTF(MiscRegs,
"Writing MiscReg %s (%d %d:%d) : %#x\n",
877 DPRINTF(MiscRegs,
"Writing MiscReg %s (%d %d) : %#x\n",
895 int old_mode = old_cpsr.mode;
897 if (old_mode != cpsr.mode || cpsr.il != old_cpsr.il) {
901 if (cpsr.pan != old_cpsr.pan) {
905 DPRINTF(
Arm,
"Updating CPSR from %#x to %#x f:%d i:%d a:%d mode:%#x\n",
906 miscRegs[misc_reg], cpsr, cpsr.f, cpsr.i, cpsr.a, cpsr.mode);
908 pc.nextThumb(cpsr.t);
909 pc.nextJazelle(cpsr.j);
910 pc.illegalExec(cpsr.il == 1);
927 warn(
"Unimplemented system register %s write with %#x.\n",
930 panic(
"Unimplemented system register %s write with %#x.\n",
940 const uint32_t ones = (uint32_t)(-1);
944 cpacrMask.cp10 = ones;
945 cpacrMask.cp11 = ones;
946 cpacrMask.asedis = ones;
955 if (!nsacr.cp10) cpacrMask.cp10 = 0;
956 if (!nsacr.cp11) cpacrMask.cp11 = 0;
962 newVal |= old_val & ~cpacrMask;
963 DPRINTF(MiscRegs,
"Writing misc reg %s: %#x\n",
969 const uint32_t ones = (uint32_t)(-1);
971 cpacrMask.tta = ones;
972 cpacrMask.fpen = ones;
974 cpacrMask.zen = ones;
977 DPRINTF(MiscRegs,
"Writing misc reg %s: %#x\n",
984 const uint32_t ones = (uint32_t)(-1);
986 cptrMask.tcpac = ones;
991 cptrMask.zen = hcr.e2h ? ones : 0;
993 cptrMask.fpen = hcr.e2h ? ones : 0;
996 cptrMask.res1_13_12_el2 = ones;
997 cptrMask.res1_7_0_el2 = ones;
999 cptrMask.res1_8_el2 = ones;
1001 cptrMask.res1_9_el2 = ones;
1003 DPRINTF(MiscRegs,
"Writing misc reg %s: %#x\n",
1009 const uint32_t ones = (uint32_t)(-1);
1011 cptrMask.tcpac = ones;
1012 cptrMask.tta = ones;
1013 cptrMask.tfp = ones;
1018 DPRINTF(MiscRegs,
"Writing misc reg %s: %#x\n",
1023 warn_once(
"The csselr register isn't implemented.\n");
1027 warn(
"Calling DC ZVA! Not Implemeted! Expect WEIRD results\n");
1032 const uint32_t ones = (uint32_t)(-1);
1033 FPSCR fpscrMask = 0;
1034 fpscrMask.ioc = ones;
1035 fpscrMask.dzc = ones;
1036 fpscrMask.ofc = ones;
1037 fpscrMask.ufc = ones;
1038 fpscrMask.ixc = ones;
1039 fpscrMask.idc = ones;
1040 fpscrMask.ioe = ones;
1041 fpscrMask.dze = ones;
1042 fpscrMask.ofe = ones;
1043 fpscrMask.ufe = ones;
1044 fpscrMask.ixe = ones;
1045 fpscrMask.ide = ones;
1046 fpscrMask.len = ones;
1047 fpscrMask.fz16 = ones;
1048 fpscrMask.stride = ones;
1049 fpscrMask.rMode = ones;
1050 fpscrMask.fz = ones;
1051 fpscrMask.dn = ones;
1052 fpscrMask.ahp = ones;
1053 fpscrMask.qc = ones;
1058 newVal = (newVal & (uint32_t)fpscrMask) |
1060 ~(uint32_t)fpscrMask);
1066 const uint32_t ones = (uint32_t)(-1);
1067 FPSCR fpscrMask = 0;
1068 fpscrMask.ioc = ones;
1069 fpscrMask.dzc = ones;
1070 fpscrMask.ofc = ones;
1071 fpscrMask.ufc = ones;
1072 fpscrMask.ixc = ones;
1073 fpscrMask.idc = ones;
1074 fpscrMask.qc = ones;
1079 newVal = (newVal & (uint32_t)fpscrMask) |
1081 ~(uint32_t)fpscrMask);
1087 const uint32_t ones = (uint32_t)(-1);
1088 FPSCR fpscrMask = 0;
1089 fpscrMask.len = ones;
1090 fpscrMask.fz16 = ones;
1091 fpscrMask.stride = ones;
1092 fpscrMask.rMode = ones;
1093 fpscrMask.fz = ones;
1094 fpscrMask.dn = ones;
1095 fpscrMask.ahp = ones;
1096 newVal = (newVal & (uint32_t)fpscrMask) |
1098 ~(uint32_t)fpscrMask);
1127 const uint32_t fpexcMask = 0x60000000;
1128 newVal = (newVal & fpexcMask) |
1154 const uint32_t temp = (
val == 0xC5ACCE55)? 0x1 : 0x0;
1156 r.oslk =
bits(temp,0);
1275 r.udccdis =
v.udccdis;
1276 r.mdbgen =
v.mdbgen;
1397 const uint32_t ifsrMask =
1399 newVal = newVal & ~ifsrMask;
1405 const uint32_t dfsrMask =
mask(31, 14) |
mask(8, 8);
1406 newVal = newVal & ~dfsrMask;
1416 DPRINTF(MiscRegs,
"Writing AMAIR: %#x\n", newVal);
1424 DPRINTF(MiscRegs,
"Writing SCTLR: %#x\n", newVal);
1435 SCTLR new_sctlr = newVal;
1528 mbits(newVal, 31, 12),
1543 mbits(newVal, 31, 12),
1586 mbits(newVal, 31,12));
1599 mbits(newVal, 31,12));
1615 mbits(newVal, 31,12));
1628 mbits(newVal, 31,12));
1645 static_cast<Addr>(
bits(newVal, 35, 0)) << 12);
1660 static_cast<Addr>(
bits(newVal, 35, 0)) << 12);
1673 mbits(newVal, 31, 12),
1687 mbits(newVal, 31, 12),
1828 bool is_host = (hcr.tge && hcr.e2h);
1849 bool is_host = (hcr.tge && hcr.e2h);
1865 static_cast<Addr>(
bits(newVal, 43, 0)) << 12,
1877 static_cast<Addr>(
bits(newVal, 43, 0)) << 12,
1891 static_cast<Addr>(
bits(newVal, 43, 0)) << 12,
1904 static_cast<Addr>(
bits(newVal, 43, 0)) << 12,
1917 bits(newVal, 55, 48);
1920 bool is_host = (hcr.tge && hcr.e2h);
1923 static_cast<Addr>(
bits(newVal, 43, 0)) << 12,
1936 bits(newVal, 55, 48);
1939 bool is_host = (hcr.tge && hcr.e2h);
1942 static_cast<Addr>(
bits(newVal, 43, 0)) << 12,
1954 bits(newVal, 55, 48);
1957 bool is_host = (hcr.tge && hcr.e2h);
1969 bits(newVal, 55, 48);
1972 bool is_host = (hcr.tge && hcr.e2h);
1988 bool is_host = (hcr.tge && hcr.e2h);
1991 static_cast<Addr>(
bits(newVal, 43, 0)) << 12);
2004 bool is_host = (hcr.tge && hcr.e2h);
2007 static_cast<Addr>(
bits(newVal, 43, 0)) << 12);
2021 static_cast<Addr>(
bits(newVal, 35, 0)) << 12);
2035 static_cast<Addr>(
bits(newVal, 35, 0)) << 12);
2041 warn(
"Not doing anything for write of miscreg ACTLR\n");
2056 newVal &= ~((uint32_t) hstrMask);
2064 if (!secure_lookup) {
2068 newVal = (newVal & ~
mask) | (oldValue &
mask);
2094 panic(
"Security Extensions required for ATS12NSOPR");
2099 panic(
"Security Extensions required for ATS12NSOPW");
2104 panic(
"Security Extensions required for ATS12NSOUR");
2110 panic(
"Security Extensions required for ATS12NSOUW");
2123 const uint32_t ones = (uint32_t)(-1);
2124 TTBCR ttbcrMask = 0;
2125 TTBCR ttbcrNew = newVal;
2130 ttbcrMask.pd0 = ones;
2131 ttbcrMask.pd1 = ones;
2133 ttbcrMask.epd0 = ones;
2134 ttbcrMask.irgn0 = ones;
2135 ttbcrMask.orgn0 = ones;
2136 ttbcrMask.sh0 = ones;
2137 ttbcrMask.ps = ones;
2138 ttbcrMask.a1 = ones;
2139 ttbcrMask.epd1 = ones;
2140 ttbcrMask.irgn1 = ones;
2141 ttbcrMask.orgn1 = ones;
2142 ttbcrMask.sh1 = ones;
2144 ttbcrMask.eae = ones;
2147 newVal = newVal & ttbcrMask;
2149 newVal = (newVal & ttbcrMask) | (ttbcr & (~ttbcrMask));
2163 uint64_t ttbrMask =
mask(63,56) |
mask(47,40);
2164 newVal = (newVal & (~ttbrMask));
2213 cpsr.daif = (uint8_t) ((CPSR) newVal).
daif;
2230 cpsr.sp = (uint8_t) ((CPSR) newVal).
sp;
2238 cpsr.el = (uint8_t) ((CPSR) newVal).
el;
2249 cpsr.pan = (uint8_t) ((CPSR) newVal).
pan;
2299 ~(0x2 << 22) : ~(0x3 << 22);
2301 newVal =
val & spsr_mask;
2305 warn(
"miscreg L2CTLR (%s) written with %#x. ignored...\n",
2335 return *
timer.get();
2339 if (!generic_timer) {
2340 panic(
"Trying to get a generic timer from a system that hasn't "
2341 "been configured to use a generic timer.\n");
2347 return *
timer.get();
2365 "A ThreadContext is needed to determine the SVE vector length "
2366 "in full-system mode");
2383 static_cast<unsigned>(
2392 static_cast<unsigned>(
2398 return (
len + 1) * 128;
2404 DPRINTF(Checkpoint,
"Serializing Arm Misc Registers\n");
2411 DPRINTF(Checkpoint,
"Unserializing Arm Misc Registers\n");
2427 warn_once(
"Doing AT (address translation) in functional mode! Fix Me!\n");
2429 auto req = std::make_shared<Request>(
2434 req,
tc,
mode, tran_type);
2438 Addr paddr = req->getPaddr();
2440 uint64_t attr1 =
attr >> 56;
2441 if (!attr1 || attr1 ==0x44) {
2443 attr &= ~ uint64_t(0x80);
2445 par = (paddr &
mask(47, 12)) |
attr;
2447 "MISCREG: Translated addr %#x: PAR_EL1: %#xx\n",
2456 par.fst = fsr.status;
2457 par.ptw = (arm_fault->
iss() >> 7) & 0x1;
2458 par.s = arm_fault->
isStage2() ? 1 : 0;
2461 "MISCREG: Translated addr %#x fault fsr %#x: PAR: %#x\n",
2478 warn_once(
"Doing AT (address translation) in functional mode! Fix Me!\n");
2480 auto req = std::make_shared<Request>(
2485 req,
tc,
mode, tran_type);
2489 Addr paddr = req->getPaddr();
2493 uint8_t max_paddr_bit = 0;
2502 par = (paddr &
mask(max_paddr_bit, 12)) |
2506 "MISCREG: Translated addr 0x%08x: PAR: 0x%08x\n",
2515 par.lpae = fsr.lpae;
2516 par.ptw = (arm_fault->
iss() >> 7) & 0x1;
2517 par.s = arm_fault->
isStage2() ? 1 : 0;
2521 par.fst = fsr.status;
2524 par.fs4_0 = fsr.fsLow | (fsr.fsHigh << 5);
2528 "MISCREG: Translated addr 0x%08x fault fsr %#x: PAR: 0x%08x\n",
virtual void setIntReg(RegIndex reg_idx, RegVal val)=0
virtual void pcStateNoRecord(const TheISA::PCState &val)=0
constexpr unsigned NumVecElemPerVecReg
virtual void setISA(ISA *isa)
Instruction TLB Invalidate All.
uint8_t physAddrRange() const
Returns the supported physical address range in bits.
void setenableTDETGE(HCR hcr, HDCR mdcr)
void init(ThreadContext *tc)
DummyISADevice dummyDevice
Dummy device for to handle non-existing ISA devices.
virtual RegVal readMiscReg(RegIndex misc_reg)=0
constexpr decltype(nullptr) NoFault
virtual System * getSystemPtr()=0
Implementaton of AArch64 TLBI ALLE(1,2,3)(IS) instructions.
int redirectRegVHE(ThreadContext *tc, int misc_reg)
Returns the enconcing equivalent when VHE is implemented and HCR_EL2.E2H is enabled and executing at ...
virtual RegVal readMiscReg(int misc_reg)=0
Read a system register belonging to this device.
@ MISCREG_TLBI_VAAE1IS_Xt
bool haveLSE() const
Returns true if LSE is implemented (ARMv8.1)
unsigned getCurSveVecLenInBits() const
bool highestELIs64() const
Returns true if the register width of the highest implemented exception level is 64 bits (ARMv8)
TLB Invalidate by ASID match.
std::unique_ptr< BaseISADevice > gicv3CpuInterface
Gicv3CPUInterface * getCPUInterface(int cpu_id) const
RegVal readMiscRegNoEffect(int misc_reg) const
BaseInterrupts * getInterruptController(ThreadID tid)
@ MISCREG_TLBI_IPAS2E1IS_Xt
bool haveLPAE() const
Returns true if this system implements the Large Physical Address Extension.
chain priv(bool v=true) const
void takeOverFrom(ThreadContext *new_tc, ThreadContext *old_tc) override
void initID32(const ArmISAParams &p)
void updateRegMap(CPSR cpsr)
virtual BaseMMU * getMMUPtr()=0
std::unique_ptr< BaseISADevice > timer
uint8_t encodePhysAddrRange64(int pa_size)
Returns the encoding corresponding to the specified n.
@ MISCREG_TLBI_IPAS2LE1IS_Xt
@ MISCREG_TLBI_VMALLS12E1IS
bool haveVHE() const
Returns true if Virtualization Host Extensions is implemented.
void updateOSLock(RegVal val)
bool haveLargeAsid64() const
Returns true if ASID is 16 bits in AArch64 (ARMv8)
@ MISCREG_TLBI_VALE2IS_Xt
@ MISCREG_TLBI_VALE1IS_Xt
@ MISCREG_ID_AA64AFR1_EL1
const char *const miscRegName[]
bool haveCrypto() const
Returns true if this system implements the Crypto Extension.
virtual ContextID contextId() const =0
void copyRegsFrom(ThreadContext *src) override
@ MISCREG_ID_AA64MMFR0_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 ...
static const uint32_t CpsrMaskQ
void serialize(CheckpointOut &cp) const override
Serialize an object.
virtual RegVal readIntRegFlat(RegIndex idx) const =0
Flat register interfaces.
#define SERIALIZE_MAPPING(member, names, size)
constexpr T mbits(T val, unsigned first, unsigned last)
Mask off the given bits in place like bits() but without shifting.
static const uint32_t FpscrQcMask
unsigned sveVL
SVE vector length in quadwords.
const typedef MiscRegLUTEntryInitializer & chain
@ MISCREG_ID_AA64DFR1_EL1
Data TLB Invalidate by ASID match.
@ MISCREG_TLBI_VALE3IS_Xt
Instruction TLB Invalidate by ASID match.
static const uint32_t FpscrExcMask
@ MISCREG_TLBI_VMALLS12E1
void updateDBGBCR(int index, DBGBCR val)
BaseGic * getGIC() const
Get a pointer to the system's GIC.
Instruction TLB Invalidate by VA.
virtual TheISA::Decoder * getDecoderPtr()=0
virtual RegVal readCCReg(RegIndex reg_idx) const =0
void addressTranslation(TLB::ArmTranslationType tran_type, BaseMMU::Mode mode, Request::Flags flags, RegVal val)
std::bitset< NUM_MISCREG_INFOS > miscRegInfo[NUM_MISCREGS]
unsigned int cacheLineSize() const
Get the cache line size of the system.
void setMiscRegNoEffect(int misc_reg, RegVal val)
void initID64(const ArmISAParams &p)
TLB Invalidate All, Non-Secure.
virtual uint32_t iss() const =0
void setMDBGen(RegVal val)
virtual void setHtmCheckpointPtr(BaseHTMCheckpointPtr cpt)=0
ArmISA::ExceptionLevel highestEL() const
Returns the highest implemented exception level.
virtual BaseISA * getIsaPtr()=0
@ MISCREG_ID_AA64PFR1_EL1
void setMDSCRvals(RegVal val)
ThreadContext is the external interface to all thread state for anything outside of the CPU.
@ MISCREG_ID_AA64MMFR2_EL1
void clear64(const ArmISAParams &p)
std::shared_ptr< FaultBase > Fault
const Params & params() const
static void copyVecRegs(ThreadContext *src, ThreadContext *dest)
TLB Invalidate by VA, All ASID.
@ MISCREG_ID_AA64AFR0_EL1
std::pair< int, int > getMiscIndices(int misc_reg) const
void unserialize(CheckpointIn &cp) override
Unserialize an object.
bool ELIs32(ThreadContext *tc, ExceptionLevel el)
void update(ThreadContext *tc)
virtual void setIntRegFlat(RegIndex idx, RegVal val)=0
chain mon(bool v=true) const
virtual const TheISA::VecElem & readVecElemFlat(RegIndex idx, const ElemIndex &elem_idx) const =0
@ MISCREG_PMXEVTYPER_PMCCFILTR
@ MISCREG_ICC_IGRPEN1_EL3
@ MISCREG_TLBI_ASIDE1IS_Xt
bool translateFunctional(ThreadContext *tc, Addr vaddr, Addr &paddr)
constexpr T insertBits(T val, unsigned first, unsigned last, B bit_val)
Returns val with bits first to last set to the LSBs of bit_val.
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 havePAN() const
Returns true if Priviledge Access Never is implemented.
BaseISADevice & getGICv3CPUInterface()
RegVal readMiscReg(int misc_reg)
virtual TheISA::PCState pcState() const =0
virtual RegVal readMiscRegNoEffect(RegIndex misc_reg) const =0
void startup() override
startup() is the final initialization call before simulation.
@ MISCREG_ID_AA64DFR0_EL1
BaseISADevice & getGenericTimer()
@ MISCREG_ID_AA64MMFR1_EL1
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
bool haveSVE() const
Returns true if SVE is implemented (ARMv8)
virtual RegVal readIntReg(RegIndex reg_idx) const =0
virtual enums::VecRegRenameMode vecRegRenameMode(ThreadContext *_tc) const
virtual void setVecElemFlat(RegIndex idx, const ElemIndex &elem_idx, const TheISA::VecElem &val)=0
bool isSecure(ThreadContext *tc)
void initializeMiscRegMetadata()
TLB Invalidate by Intermediate Physical Address.
@ MISCREG_ID_AA64ISAR1_EL1
@ MISCREG_ID_AA64ZFR0_EL1
virtual FSR getFsr(ThreadContext *tc) const
@ MISCREG_TLBI_IPAS2LE1_Xt
@ MISCREG_TLBI_VAALE1IS_Xt
void setupThreadContext()
static std::vector< struct MiscRegLUTEntry > lookUpMiscReg
Metadata table accessible via the value of the register.
bool FullSystem
The FullSystem variable can be used to determine the current mode of simulation.
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
virtual void setThreadContext(ThreadContext *tc)
chain highest(ArmSystem *const sys) const
@ funcRequestorId
This requestor id is used for functional requests that don't come from a particular device.
unsigned sveVL() const
Returns the SVE vector length at reset, in quadwords.
virtual void startup()
startup() is the final initialization call before simulation.
void broadcast(ThreadContext *tc)
Broadcast the TLB Invalidate operation to all TLBs in the Arm system.
RegVal miscRegs[NUM_MISCREGS]
virtual void setMiscReg(RegIndex misc_reg, RegVal val)=0
bool haveSecurity() const
Returns true if this system implements the Security Extensions.
Implementaton of AArch64 TLBI VMALLE1(IS)/VMALLS112E1(IS) instructions.
Addr resetAddr() const
Returns the reset address if the highest implemented exception level is 64 bits (ARMv8)
GenericTimer * getGenericTimer() const
Get a pointer to the system's generic timer model.
virtual void setCCReg(RegIndex reg_idx, RegVal val)=0
void setMiscReg(int misc_reg, RegVal val)
virtual void setMiscReg(int misc_reg, RegVal val)=0
Write to a system register belonging to this device.
std::ostream CheckpointOut
virtual BaseCPU * getCpuPtr()=0
virtual int threadId() const =0
Data TLB Invalidate by VA.
virtual void setVecRegFlat(RegIndex idx, const TheISA::VecRegContainer &val)=0
void updateDBGWCR(int index, DBGWCR val)
chain hyp(bool v=true) const
void addressTranslation64(TLB::ArmTranslationType tran_type, BaseMMU::Mode mode, Request::Flags flags, RegVal val)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
@ MISCREG_ID_AA64PFR0_EL1
void setDebugMask(bool mask)
bool haveSecEL2() const
Returns true if Priviledge Access Never is implemented.
virtual bool isStage2() const
bool haveTME() const
Returns true if this system implements the transactional memory extension (ARMv9)
#define UNSERIALIZE_MAPPING(member, names, size)
virtual const TheISA::VecRegContainer & readVecRegFlat(RegIndex idx) const =0
@ MISCREG_TLBI_IPAS2E1_Xt
virtual CheckerCPU * getCheckerCpuPtr()=0
void preUnflattenMiscReg()
void clear32(const ArmISAParams &p, const SCTLR &sctlr_rst)
@ MISCREG_ID_AA64ISAR0_EL1
RegVal readMPIDR(ArmSystem *arm_sys, ThreadContext *tc)
This helper function is either returing the value of MPIDR_EL1 (by calling getMPIDR),...
void invalidateMiscReg(TLBType type=ALL_TLBS)
bool haveVirtualization() const
Returns true if this system implements the virtualization Extensions.
int unflattenMiscReg(int reg)
#define panic(...)
This implements a cprintf based panic() function.
Base class for devices that use the MiscReg interfaces.
virtual void setMiscRegNoEffect(RegIndex misc_reg, RegVal val)=0
Generated on Wed Jul 28 2021 12:10:19 for gem5 by doxygen 1.8.17