Go to the documentation of this file.
55 #include "debug/Arm.hh"
56 #include "debug/CCRegs.hh"
57 #include "debug/FloatRegs.hh"
58 #include "debug/IntRegs.hh"
59 #include "debug/LLSC.hh"
60 #include "debug/MiscRegs.hh"
61 #include "debug/VecPredRegs.hh"
62 #include "debug/VecRegs.hh"
66 #include "params/ArmISA.hh"
92 _decoderFlavor(
p.decoderFlavor), pmu(
p.pmu), impdefAsNop(
p.impdef_nop),
173 mvfr0.advSimdRegisters = 2;
174 mvfr0.singlePrecision = 2;
175 mvfr0.doublePrecision = 2;
176 mvfr0.vfpExceptionTrapping = 0;
178 mvfr0.squareRoot = 1;
179 mvfr0.shortVectors = 1;
180 mvfr0.roundingModes = 1;
184 mvfr1.flushToZero = 1;
185 mvfr1.defaultNaN = 1;
186 mvfr1.advSimdLoadStore = 1;
187 mvfr1.advSimdInteger = 1;
188 mvfr1.advSimdSinglePrecision = 1;
189 mvfr1.advSimdHalfPrecision = 1;
190 mvfr1.vfpHalfPrecision = 1;
251 sctlr.te = (bool) sctlr_rst.te;
252 sctlr.nmfi = (
bool) sctlr_rst.nmfi;
253 sctlr.v = (bool) sctlr_rst.v;
311 panic(
"Invalid highest implemented exception level");
327 }
else if (
release->
has(ArmExtension::VIRTUALIZATION)) {
375 release->
has(ArmExtension::CRYPTO) ? 0x1112 : 0x0);
379 release->
has(ArmExtension::FEAT_RDM) ? 0x1 : 0x0);
383 release->
has(ArmExtension::FEAT_FCMA) ? 0x1 : 0x0);
388 release->
has(ArmExtension::FEAT_JSCVT) ? 0x1 : 0x0);
398 (
p.id_aa64dfr0_el1 & 0xfffffffffffff0ffULL) |
399 (
p.pmu ? 0x0000000000000100ULL : 0);
409 (
p.pmu ? 0x03000000ULL : 0);
417 }
else if (
release->
has(ArmExtension::VIRTUALIZATION)) {
428 release->
has(ArmExtension::SECURITY) ? 0x2 : 0x0);
432 release->
has(ArmExtension::VIRTUALIZATION) ? 0x2 : 0x0);
436 release->
has(ArmExtension::FEAT_SVE) ? 0x1 : 0x0);
440 release->
has(ArmExtension::FEAT_SEL2) ? 0x1 : 0x0);
455 release->
has(ArmExtension::CRYPTO) ? 0x1112 : 0x0);
459 release->
has(ArmExtension::FEAT_LSE) ? 0x2 : 0x0);
463 release->
has(ArmExtension::FEAT_RDM) ? 0x1 : 0x0);
469 release->
has(ArmExtension::FEAT_PAuth) ? 0x1 : 0x0);
473 release->
has(ArmExtension::FEAT_JSCVT) ? 0x1 : 0x0);
477 release->
has(ArmExtension::FEAT_FCMA) ? 0x1 : 0x0);
481 release->
has(ArmExtension::FEAT_PAuth) ? 0x1 : 0x0);
487 release->
has(ArmExtension::FEAT_VMID16) ? 0x2 : 0x0);
491 release->
has(ArmExtension::FEAT_VHE) ? 0x1 : 0x0);
495 release->
has(ArmExtension::FEAT_HPDS) ? 0x1 : 0x0);
499 release->
has(ArmExtension::FEAT_PAN) ? 0x1 : 0x0);
505 release->
has(ArmExtension::FEAT_UAO) ? 0x1 : 0x0);
509 release->
has(ArmExtension::FEAT_LVA) ? 0x1 : 0x0);
613 bool sec_el2 = scr.eel2 &&
release->
has(ArmExtension::FEAT_SEL2);
759 int lower = map.first, upper = map.second;
765 DPRINTF(MiscRegs,
"Reading MiscReg %s with set res0 bits: %#x\n",
769 DPRINTF(MiscRegs,
"Reading MiscReg %s with clear res1 bits: %#x\n",
785 cpsr.j =
pc.jazelle() ? 1 : 0;
786 cpsr.t =
pc.thumb() ? 1 : 0;
793 warn(
"Unimplemented system register %s read.\n",
796 panic(
"Unimplemented system register %s read.\n",
805 if (!
release->
has(ArmExtension::VIRTUALIZATION))
810 const uint32_t ones = (uint32_t)(-1);
814 cpacrMask.cp10 = ones;
815 cpacrMask.cp11 = ones;
816 cpacrMask.asedis = ones;
825 if (!nsacr.cp10) cpacrMask.cp10 = 0;
826 if (!nsacr.cp11) cpacrMask.cp11 = 0;
831 DPRINTF(MiscRegs,
"Reading misc reg %s: %#x\n",
861 warn_once(
"The clidr register always reports 0 caches.\n");
862 warn_once(
"clidr LoUIS field of 0b001 to match current "
863 "ARM implementations.\n");
866 warn_once(
"The ccsidr register isn't implemented and "
867 "always reads as 0.\n");
874 unsigned lineSizeWords =
876 unsigned log2LineSizeWords = 0;
878 while (lineSizeWords >>= 1) {
884 ctr.iCacheLineSize = log2LineSizeWords;
886 ctr.l1IndexPolicy = 0x3;
888 ctr.dCacheLineSize = log2LineSizeWords;
890 ctr.erg = log2LineSizeWords;
892 ctr.cwg = log2LineSizeWords;
899 warn(
"Not doing anything for miscreg ACTLR\n");
909 panic(
"shouldn't be reading this register seperately\n");
916 const uint32_t ones = (uint32_t)(-1);
918 fpscrMask.ioc = ones;
919 fpscrMask.dzc = ones;
920 fpscrMask.ofc = ones;
921 fpscrMask.ufc = ones;
922 fpscrMask.ixc = ones;
923 fpscrMask.idc = ones;
933 const uint32_t ones = (uint32_t)(-1);
935 fpscrMask.len = ones;
936 fpscrMask.fz16 = ones;
937 fpscrMask.stride = ones;
938 fpscrMask.rMode = ones;
941 fpscrMask.ahp = ones;
1028 bool secure_lookup =
release->
has(ArmExtension::SECURITY) &&
1030 if (!secure_lookup) {
1032 val |= (
mask ^ 0x7FFF) & 0xBFFF;
1052 (
release->
has(ArmExtension::VIRTUALIZATION) ?
1054 (have_timer ? 0x00010000 : 0x0);
1057 return 0x0000000000000002 |
1058 0x0000000000000020 |
1059 (
release->
has(ArmExtension::VIRTUALIZATION) ?
1060 0x0000000000000200 : 0) |
1062 0x0000000000002000 : 0) |
1064 0x0000000100000000 : 0) |
1066 0x0000001000000000 : 0) |
1095 int lower = map.first, upper = map.second;
1101 DPRINTF(MiscRegs,
"Writing MiscReg %s (%d %d:%d) : %#x\n",
1105 DPRINTF(MiscRegs,
"Writing MiscReg %s (%d %d) : %#x\n",
1123 int old_mode = old_cpsr.mode;
1125 if (cpsr.pan != old_cpsr.pan || cpsr.il != old_cpsr.il) {
1129 DPRINTF(
Arm,
"Updating CPSR from %#x to %#x f:%d i:%d a:%d mode:%#x\n",
1130 miscRegs[misc_reg], cpsr, cpsr.f, cpsr.i, cpsr.a, cpsr.mode);
1132 pc.nextThumb(cpsr.t);
1133 pc.nextJazelle(cpsr.j);
1134 pc.illegalExec(cpsr.il == 1);
1151 if (old_mode != cpsr.mode) {
1170 warn(
"Unimplemented system register %s write with %#x.\n",
1173 panic(
"Unimplemented system register %s write with %#x.\n",
1183 const uint32_t ones = (uint32_t)(-1);
1184 CPACR cpacrMask = 0;
1187 cpacrMask.cp10 = ones;
1188 cpacrMask.cp11 = ones;
1189 cpacrMask.asedis = ones;
1198 if (!nsacr.cp10) cpacrMask.cp10 = 0;
1199 if (!nsacr.cp11) cpacrMask.cp11 = 0;
1204 newVal &= cpacrMask;
1205 newVal |= old_val & ~cpacrMask;
1206 DPRINTF(MiscRegs,
"Writing misc reg %s: %#x\n",
1212 const uint32_t ones = (uint32_t)(-1);
1213 CPACR cpacrMask = 0;
1214 cpacrMask.tta = ones;
1215 cpacrMask.fpen = ones;
1217 cpacrMask.zen = ones;
1219 newVal &= cpacrMask;
1220 DPRINTF(MiscRegs,
"Writing misc reg %s: %#x\n",
1227 const uint32_t ones = (uint32_t)(-1);
1229 cptrMask.tcpac = ones;
1230 cptrMask.tta = ones;
1231 cptrMask.tfp = ones;
1234 cptrMask.zen = hcr.e2h ? ones : 0;
1236 cptrMask.fpen = hcr.e2h ? ones : 0;
1239 cptrMask.res1_13_12_el2 = ones;
1240 cptrMask.res1_7_0_el2 = ones;
1242 cptrMask.res1_8_el2 = ones;
1244 cptrMask.res1_9_el2 = ones;
1246 DPRINTF(MiscRegs,
"Writing misc reg %s: %#x\n",
1252 const uint32_t ones = (uint32_t)(-1);
1254 cptrMask.tcpac = ones;
1255 cptrMask.tta = ones;
1256 cptrMask.tfp = ones;
1261 DPRINTF(MiscRegs,
"Writing misc reg %s: %#x\n",
1266 warn_once(
"The csselr register isn't implemented.\n");
1270 warn(
"Calling DC ZVA! Not Implemeted! Expect WEIRD results\n");
1275 const uint32_t ones = (uint32_t)(-1);
1276 FPSCR fpscrMask = 0;
1277 fpscrMask.ioc = ones;
1278 fpscrMask.dzc = ones;
1279 fpscrMask.ofc = ones;
1280 fpscrMask.ufc = ones;
1281 fpscrMask.ixc = ones;
1282 fpscrMask.idc = ones;
1283 fpscrMask.ioe = ones;
1284 fpscrMask.dze = ones;
1285 fpscrMask.ofe = ones;
1286 fpscrMask.ufe = ones;
1287 fpscrMask.ixe = ones;
1288 fpscrMask.ide = ones;
1289 fpscrMask.len = ones;
1290 fpscrMask.fz16 = ones;
1291 fpscrMask.stride = ones;
1292 fpscrMask.rMode = ones;
1293 fpscrMask.fz = ones;
1294 fpscrMask.dn = ones;
1295 fpscrMask.ahp = ones;
1296 fpscrMask.qc = ones;
1301 newVal = (newVal & (uint32_t)fpscrMask) |
1303 ~(uint32_t)fpscrMask);
1309 const uint32_t ones = (uint32_t)(-1);
1310 FPSCR fpscrMask = 0;
1311 fpscrMask.ioc = ones;
1312 fpscrMask.dzc = ones;
1313 fpscrMask.ofc = ones;
1314 fpscrMask.ufc = ones;
1315 fpscrMask.ixc = ones;
1316 fpscrMask.idc = ones;
1317 fpscrMask.qc = ones;
1322 newVal = (newVal & (uint32_t)fpscrMask) |
1324 ~(uint32_t)fpscrMask);
1330 const uint32_t ones = (uint32_t)(-1);
1331 FPSCR fpscrMask = 0;
1332 fpscrMask.len = ones;
1333 fpscrMask.fz16 = ones;
1334 fpscrMask.stride = ones;
1335 fpscrMask.rMode = ones;
1336 fpscrMask.fz = ones;
1337 fpscrMask.dn = ones;
1338 fpscrMask.ahp = ones;
1339 newVal = (newVal & (uint32_t)fpscrMask) |
1341 ~(uint32_t)fpscrMask);
1370 const uint32_t fpexcMask = 0x60000000;
1371 newVal = (newVal & fpexcMask) |
1376 if (!
release->
has(ArmExtension::VIRTUALIZATION))
1383 if (!
release->
has(ArmExtension::VIRTUALIZATION))
1397 const uint32_t temp = (
val == 0xC5ACCE55)? 0x1 : 0x0;
1399 r.oslk =
bits(temp,0);
1518 r.udccdis =
v.udccdis;
1519 r.mdbgen =
v.mdbgen;
1640 const uint32_t ifsrMask =
1642 newVal = newVal & ~ifsrMask;
1648 const uint32_t dfsrMask =
mask(31, 14) |
mask(8, 8);
1649 newVal = newVal & ~dfsrMask;
1659 DPRINTF(MiscRegs,
"Writing AMAIR: %#x\n", newVal);
1667 DPRINTF(MiscRegs,
"Writing SCTLR: %#x\n", newVal);
1679 SCTLR new_sctlr = newVal;
1680 new_sctlr.nmfi = ((bool)sctlr.nmfi) &&
1723 warn(
"Not doing anything for write of miscreg ACTLR\n");
1738 newVal &= ~((uint32_t) hstrMask);
1745 secure_lookup =
release->
has(ArmExtension::SECURITY) &&
1747 if (!secure_lookup) {
1751 newVal = (newVal & ~
mask) | (oldValue &
mask);
1777 panic(
"Security Extensions required for ATS12NSOPR");
1782 panic(
"Security Extensions required for ATS12NSOPW");
1787 panic(
"Security Extensions required for ATS12NSOUR");
1793 panic(
"Security Extensions required for ATS12NSOUW");
1806 const uint32_t ones = (uint32_t)(-1);
1807 TTBCR ttbcrMask = 0;
1808 TTBCR ttbcrNew = newVal;
1813 ttbcrMask.pd0 = ones;
1814 ttbcrMask.pd1 = ones;
1816 ttbcrMask.epd0 = ones;
1817 ttbcrMask.irgn0 = ones;
1818 ttbcrMask.orgn0 = ones;
1819 ttbcrMask.sh0 = ones;
1820 ttbcrMask.ps = ones;
1821 ttbcrMask.a1 = ones;
1822 ttbcrMask.epd1 = ones;
1823 ttbcrMask.irgn1 = ones;
1824 ttbcrMask.orgn1 = ones;
1825 ttbcrMask.sh1 = ones;
1827 ttbcrMask.eae = ones;
1829 if (
release->
has(ArmExtension::LPAE) && ttbcrNew.eae) {
1830 newVal = newVal & ttbcrMask;
1832 newVal = (newVal & ttbcrMask) | (ttbcr & (~ttbcrMask));
1846 uint64_t ttbrMask =
mask(63,56) |
mask(47,40);
1847 newVal = (newVal & (~ttbrMask));
1896 cpsr.daif = (uint8_t) ((CPSR) newVal).
daif;
1913 cpsr.sp = (uint8_t) ((CPSR) newVal).
sp;
1921 cpsr.el = (uint8_t) ((CPSR) newVal).
el;
1932 cpsr.pan = (uint8_t) ((CPSR) newVal).
pan;
1943 cpsr.uao = (uint8_t) ((CPSR) newVal).
uao;
1989 warn(
"miscreg L2CTLR (%s) written with %#x. ignored...\n",
2020 return *
timer.get();
2024 if (!generic_timer) {
2025 panic(
"Trying to get a generic timer from a system that hasn't "
2026 "been configured to use a generic timer.\n");
2032 return *
timer.get();
2082 "A ThreadContext is needed to determine the SVE vector length "
2083 "in full-system mode");
2100 static_cast<unsigned>(
2106 }
else if (
release->
has(ArmExtension::SECURITY)) {
2109 static_cast<unsigned>(
2115 return (
len + 1) * 128;
2121 DPRINTF(Checkpoint,
"Serializing Arm Misc Registers\n");
2128 DPRINTF(Checkpoint,
"Unserializing Arm Misc Registers\n");
2144 warn_once(
"Doing AT (address translation) in functional mode! Fix Me!\n");
2146 auto req = std::make_shared<Request>(
2151 req,
tc,
mode, tran_type);
2155 Addr paddr = req->getPaddr();
2157 uint64_t attr1 =
attr >> 56;
2158 if (!attr1 || attr1 ==0x44) {
2160 attr &= ~ uint64_t(0x80);
2162 par = (paddr &
mask(47, 12)) |
attr;
2164 "MISCREG: Translated addr %#x: PAR_EL1: %#xx\n",
2173 par.fst = fsr.status;
2174 par.ptw = (arm_fault->
iss() >> 7) & 0x1;
2175 par.s = arm_fault->
isStage2() ? 1 : 0;
2178 "MISCREG: Translated addr %#x fault fsr %#x: PAR: %#x\n",
2195 warn_once(
"Doing AT (address translation) in functional mode! Fix Me!\n");
2197 auto req = std::make_shared<Request>(
2202 req,
tc,
mode, tran_type);
2206 Addr paddr = req->getPaddr();
2210 uint8_t max_paddr_bit = 0;
2220 par = (paddr &
mask(max_paddr_bit, 12)) |
2224 "MISCREG: Translated addr 0x%08x: PAR: 0x%08x\n",
2233 par.lpae = fsr.lpae;
2234 par.ptw = (arm_fault->
iss() >> 7) & 0x1;
2235 par.s = arm_fault->
isStage2() ? 1 : 0;
2239 par.fst = fsr.status;
2242 par.fs4_0 = fsr.fsLow | (fsr.fsHigh << 5);
2246 "MISCREG: Translated addr 0x%08x fault fsr %#x: PAR: 0x%08x\n",
2268 Addr cacheBlockMask)
2273 DPRINTF(LLSC,
"%s: handling snoop for address: %#x locked: %d\n",
2281 Addr snoop_addr = pkt->
getAddr() & cacheBlockMask;
2283 DPRINTF(LLSC,
"%s: handling snoop for address: %#x locked addr: %#x\n",
2284 tc->
getCpuPtr()->name(), snoop_addr, locked_addr);
2285 if (locked_addr == snoop_addr) {
2286 DPRINTF(LLSC,
"%s: address match, clearing lock and signaling sev\n",
2312 DPRINTF(LLSC,
"%s: Placing address %#x in monitor\n",
2321 DPRINTF(LLSC,
"%s: Placing address %#x in monitor\n",
2328 DPRINTF(LLSC,
"%s: handling snoop lock hit address: %#x\n",
2337 DPRINTF(LLSC,
"%s: handling snoop lock hit address: %#x\n",
2347 Addr cacheBlockMask)
2352 DPRINTF(LLSC,
"Handling locked write for address %#x in monitor.\n",
2358 if (!lock_flag || (req->getPaddr() & cacheBlockMask) != lock_addr) {
2361 req->setExtraData(0);
2363 DPRINTF(LLSC,
"clearing lock flag in handle locked write\n",
2369 int stCondFailures = xc->readStCondFailures();
2371 xc->setStCondFailures(stCondFailures);
2372 if (stCondFailures % 100000 == 0) {
2373 warn(
"context %d: %d consecutive "
2374 "store conditional failures\n",
2392 Addr cacheBlockMask)
2404 DPRINTF(LLSC,
"Clearing lock and signaling sev\n");
2418 DPRINTF(LLSC,
"Clearing lock and signaling sev\n");
constexpr unsigned NumVecElemPerVecReg
virtual void setISA(ISA *isa)
uint8_t physAddrRange() const
Returns the supported physical address range in bits.
void addressTranslation64(MMU::ArmTranslationType tran_type, BaseMMU::Mode mode, Request::Flags flags, RegVal val)
void setenableTDETGE(HCR hcr, HDCR mdcr)
Addr instAddr() const
Returns the memory address of the instruction this PC points to.
void init(ThreadContext *tc)
DummyISADevice dummyDevice
Dummy device for to handle non-existing ISA devices.
virtual RegVal readMiscReg(RegIndex misc_reg)=0
@ MISCREG_CNTHVS_TVAL_EL2
constexpr decltype(nullptr) NoFault
virtual System * getSystemPtr()=0
ExceptionLevel currEL() const
Returns the current Exception Level (EL) of the ISA object.
TypedRegClassOps< ArmISA::VecRegContainer > vecRegClassOps
virtual RegVal readMiscReg(int misc_reg)=0
Read a system register belonging to this device.
virtual void setMiscReg(int misc_reg, RegVal val)=0
Sets a miscellaneous register, handling any architectural side effects due to writing that register.
unsigned getCurSveVecLenInBits() const
VecPredReg::Container VecPredRegContainer
bool highestELIs64() const
Returns true if the register width of the highest implemented exception level is 64 bits (ARMv8)
std::unique_ptr< BaseISADevice > gicv3CpuInterface
Gicv3CPUInterface * getCPUInterface(int cpu_id) const
RegVal readMiscRegNoEffect(int misc_reg) const
@ MISCREG_CNTHPS_TVAL_EL2
@ MISCREG_CNTHVS_CVAL_EL2
@ VecElemClass
Vector Register Native Elem lane.
virtual RegVal getReg(const RegId ®) const
chain priv(bool v=true) const
void takeOverFrom(ThreadContext *new_tc, ThreadContext *old_tc) override
void handleLockedSnoop(PacketPtr pkt, Addr cacheBlockMask) override
void initID32(const ArmISAParams &p)
static bool lockedWriteHandler(ThreadContext *tc, XC *xc, const RequestPtr &req, Addr cacheBlockMask)
@ CCRegClass
Condition-code register.
void updateRegMap(CPSR cpsr)
const ArmRelease * release
This could be either a FS or a SE release.
virtual BaseMMU * getMMUPtr()=0
virtual const PCStateBase & pcState() const =0
std::unique_ptr< BaseISADevice > timer
uint8_t encodePhysAddrRange64(int pa_size)
Returns the encoding corresponding to the specified n.
void updateOSLock(RegVal val)
bool haveLargeAsid64() const
Returns true if ASID is 16 bits in AArch64 (ARMv8)
@ MISCREG_ID_AA64AFR1_EL1
const char *const miscRegName[]
virtual ContextID contextId() const =0
void copyRegsFrom(ThreadContext *src) override
@ MISCREG_ID_AA64MMFR0_EL1
static ExceptionLevel opModeToEL(OperatingMode mode)
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
virtual RegVal getRegFlat(const RegId ®) const
Flat register interfaces.
void serialize(CheckpointOut &cp) const override
Serialize an object.
#define SERIALIZE_MAPPING(member, names, size)
virtual RegVal readMiscReg(int misc_reg)=0
Reads a miscellaneous register, handling any architectural side effects due to reading that register.
static const uint32_t FpscrQcMask
unsigned sveVL
SVE vector length in quadwords.
const typedef MiscRegLUTEntryInitializer & chain
@ MISCREG_ID_AA64DFR1_EL1
static const uint32_t FpscrExcMask
void updateDBGBCR(int index, DBGBCR val)
BaseGic * getGIC() const
Get a pointer to the system's GIC.
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)
constexpr RegId Nz(CCRegClass, _NzIdx)
void handleLockedRead(const RequestPtr &req) override
VecElemRegClassOps< ArmISA::VecElem > vecRegElemClassOps(NumVecElemPerVecReg)
virtual uint32_t iss() const =0
bool has(ArmExtension ext) const
void setMDBGen(RegVal val)
virtual void setHtmCheckpointPtr(BaseHTMCheckpointPtr cpt)=0
ArmISA::ExceptionLevel highestEL() const
Returns the highest implemented exception level.
Vector Register Abstraction This generic class is the model in a particularization of MVC,...
void handleLockedSnoopHit() override
@ 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
constexpr RegId V(CCRegClass, _VIdx)
const Params & params() const
@ MISCREG_CONTEXTIDR_EL12
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
virtual InstDecoder * getDecoderPtr()=0
void globalClearExclusive() override
@ 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)
std::shared_ptr< Request > RequestPtr
chain mon(bool v=true) const
void addressTranslation(MMU::ArmTranslationType tran_type, BaseMMU::Mode mode, Request::Flags flags, RegVal val)
@ MISCREG_PMXEVTYPER_PMCCFILTR
virtual ThreadContext * tcBase() const =0
Returns a pointer to the ThreadContext.
@ MISCREG_ICC_IGRPEN1_EL3
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.
bool handleLockedWrite(const RequestPtr &req, Addr cacheBlockMask) override
constexpr T bits(T val, unsigned first, unsigned last)
Extract the bitfield from position 'first' to 'last' (inclusive) from 'val' and right justify it.
gem5::ArmISA::MiscRegClassOps miscRegClassOps
BaseISADevice & getGICv3CPUInterface()
RegVal readMiscReg(int misc_reg)
virtual RegVal readMiscRegNoEffect(RegIndex misc_reg) const =0
virtual void setRegFlat(const RegId ®, RegVal val)
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.
constexpr RegId C(CCRegClass, _CIdx)
bool isSecure(ThreadContext *tc)
void initializeMiscRegMetadata()
@ MISCREG_ID_AA64ISAR1_EL1
@ MISCREG_ID_AA64ZFR0_EL1
virtual FSR getFsr(ThreadContext *tc) const
@ funcRequestorId
This requestor id is used for functional requests that don't come from a particular device.
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.
virtual void pcStateNoRecord(const PCStateBase &val)=0
@ IntRegClass
Integer register.
#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
unsigned sveVL() const
Returns the SVE vector length at reset, in quadwords.
virtual void startup()
startup() is the final initialization call before simulation.
TranslationGenPtr translateFunctional(Addr start, Addr size, ThreadContext *tc, Mode mode, Request::Flags flags) override
Returns a translation generator for a region of virtual addresses, instead of directly translating a ...
RegVal miscRegs[NUM_MISCREGS]
static void lockedSnoopHandler(ThreadContext *tc, XC *xc, PacketPtr pkt, Addr cacheBlockMask)
void sendEvent(ThreadContext *tc)
Send an event (SEV) to a specific PE if there isn't already a pending event.
virtual void setMiscReg(RegIndex misc_reg, RegVal val)=0
Addr resetAddr() const
Returns the reset address if the highest implemented exception level is 64 bits (ARMv8)
The ExecContext is an abstract base class the provides the interface used by the ISA to manipulate th...
const ArmRelease * releaseFS() const
GenericTimer * getGenericTimer() const
Get a pointer to the system's generic timer model.
@ MISCREG_CNTHPS_CVAL_EL2
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
@ VecRegClass
Vector Register.
int redirectRegVHE(int misc_reg)
Returns the enconcing equivalent when VHE is implemented and HCR_EL2.E2H is enabled and executing at ...
void updateDBGWCR(int index, DBGWCR val)
chain hyp(bool v=true) const
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
@ MISCREG_ID_AA64PFR0_EL1
void setDebugMask(bool mask)
virtual bool isStage2() const
#define UNSERIALIZE_MAPPING(member, names, size)
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),...
std::string regName(const RegId &id) const override
Print the name of the register specified in id.
bool inSecureState() const
Return true if the PE is in Secure state.
TypedRegClassOps< ArmISA::VecPredRegContainer > vecPredRegClassOps
int unflattenMiscReg(int reg)
bool isInvalidate() const
Register ID: describe an architectural register with its class and index.
#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
virtual void setReg(const RegId ®, RegVal val)
Generated on Wed Jul 13 2022 10:39:07 for gem5 by doxygen 1.8.17