48 #include "debug/Arm.hh" 49 #include "debug/MiscRegs.hh" 53 #include "params/ArmISA.hh" 62 _decoderFlavor(p->decoderFlavor), _vecRegRenameMode(Enums::Full),
63 pmu(p->pmu), impdefAsNop(p->impdef_nop),
100 sveVL = p->sve_vl_se;
154 mvfr0.advSimdRegisters = 2;
155 mvfr0.singlePrecision = 2;
156 mvfr0.doublePrecision = 2;
157 mvfr0.vfpExceptionTrapping = 0;
159 mvfr0.squareRoot = 1;
160 mvfr0.shortVectors = 1;
161 mvfr0.roundingModes = 1;
165 mvfr1.flushToZero = 1;
166 mvfr1.defaultNaN = 1;
167 mvfr1.advSimdLoadStore = 1;
168 mvfr1.advSimdInteger = 1;
169 mvfr1.advSimdSinglePrecision = 1;
170 mvfr1.advSimdHalfPrecision = 1;
171 mvfr1.vfpHalfPrecision = 1;
232 sctlr.te = (bool) sctlr_rst.te;
233 sctlr.nmfi = (
bool) sctlr_rst.nmfi;
234 sctlr.v = (bool) sctlr_rst.v;
292 panic(
"Invalid highest implemented exception level");
362 (p->id_aa64dfr0_el1 & 0xfffffffffffff0ff
ULL) |
363 (p->pmu ? 0x0000000000000100ULL : 0);
373 (p->pmu ? 0x03000000
ULL : 0);
395 miscRegs[MISCREG_ID_AA64PFR0_EL1], 11, 8,
399 miscRegs[MISCREG_ID_AA64PFR0_EL1], 35, 32,
407 miscRegs[MISCREG_ID_AA64MMFR0_EL1], 3, 0,
415 miscRegs[MISCREG_ID_AA64ISAR0_EL1], 23, 20,
458 int lower = map.first, upper = map.second;
464 DPRINTF(MiscRegs,
"Reading MiscReg %s with set res0 bits: %#x\n",
468 DPRINTF(MiscRegs,
"Reading MiscReg %s with clear res1 bits: %#x\n",
485 cpsr.j = pc.jazelle() ? 1 : 0;
486 cpsr.t = pc.thumb() ? 1 : 0;
493 warn(
"Unimplemented system register %s read.\n",
496 panic(
"Unimplemented system register %s read.\n",
509 const uint32_t ones = (uint32_t)(-1);
513 cpacrMask.cp10 = ones;
514 cpacrMask.cp11 = ones;
515 cpacrMask.asedis = ones;
524 if (!nsacr.cp10) cpacrMask.cp10 = 0;
525 if (!nsacr.cp11) cpacrMask.cp11 = 0;
530 DPRINTF(MiscRegs,
"Reading misc reg %s: %#x\n",
560 warn_once(
"The clidr register always reports 0 caches.\n");
561 warn_once(
"clidr LoUIS field of 0b001 to match current " 562 "ARM implementations.\n");
565 warn_once(
"The ccsidr register isn't implemented and " 566 "always reads as 0.\n");
573 unsigned lineSizeWords =
575 unsigned log2LineSizeWords = 0;
577 while (lineSizeWords >>= 1) {
583 ctr.iCacheLineSize = log2LineSizeWords;
585 ctr.l1IndexPolicy = 0x3;
587 ctr.dCacheLineSize = log2LineSizeWords;
589 ctr.erg = log2LineSizeWords;
591 ctr.cwg = log2LineSizeWords;
598 warn(
"Not doing anything for miscreg ACTLR\n");
608 panic(
"shouldn't be reading this register seperately\n");
615 const uint32_t ones = (uint32_t)(-1);
617 fpscrMask.ioc = ones;
618 fpscrMask.dzc = ones;
619 fpscrMask.ofc = ones;
620 fpscrMask.ufc = ones;
621 fpscrMask.ixc = ones;
622 fpscrMask.idc = ones;
632 const uint32_t ones = (uint32_t)(-1);
634 fpscrMask.len = ones;
635 fpscrMask.fz16 = ones;
636 fpscrMask.stride = ones;
637 fpscrMask.rMode = ones;
640 fpscrMask.ahp = ones;
726 if (!secure_lookup) {
728 val |= (mask ^ 0x7FFF) & 0xBFFF;
748 | (haveTimer ? 0x00010000 : 0x0);
751 return 0x0000000000000002 |
755 (
haveSVE ? 0x0000000100000000 : 0) |
784 int lower = map.first, upper = map.second;
786 auto v = (val & ~
reg.wi()) |
reg.rao();
790 DPRINTF(MiscRegs,
"Writing to misc reg %d (%d:%d) : %#x\n",
791 misc_reg, lower, upper,
v);
794 DPRINTF(MiscRegs,
"Writing to misc reg %d (%d) : %#x\n",
812 int old_mode = old_cpsr.mode;
814 if (old_mode != cpsr.mode || cpsr.il != old_cpsr.il) {
819 if (cpsr.pan != old_cpsr.pan) {
823 DPRINTF(
Arm,
"Updating CPSR from %#x to %#x f:%d i:%d a:%d mode:%#x\n",
824 miscRegs[misc_reg], cpsr, cpsr.f, cpsr.i, cpsr.a, cpsr.mode);
826 pc.nextThumb(cpsr.t);
827 pc.nextJazelle(cpsr.j);
828 pc.illegalExec(cpsr.il == 1);
844 warn(
"Unimplemented system register %s write with %#x.\n",
847 panic(
"Unimplemented system register %s write with %#x.\n",
855 const uint32_t ones = (uint32_t)(-1);
859 cpacrMask.cp10 = ones;
860 cpacrMask.cp11 = ones;
861 cpacrMask.asedis = ones;
870 if (!nsacr.cp10) cpacrMask.cp10 = 0;
871 if (!nsacr.cp11) cpacrMask.cp11 = 0;
877 newVal |= old_val & ~cpacrMask;
878 DPRINTF(MiscRegs,
"Writing misc reg %s: %#x\n",
884 const uint32_t ones = (uint32_t)(-1);
886 cpacrMask.tta = ones;
887 cpacrMask.fpen = ones;
889 cpacrMask.zen = ones;
892 DPRINTF(MiscRegs,
"Writing misc reg %s: %#x\n",
898 const uint32_t ones = (uint32_t)(-1);
900 cptrMask.tcpac = ones;
908 cptrMask.res1_13_12_el2 = ones;
909 cptrMask.res1_7_0_el2 = ones;
911 cptrMask.res1_8_el2 = ones;
913 cptrMask.res1_9_el2 = ones;
915 DPRINTF(MiscRegs,
"Writing misc reg %s: %#x\n",
921 const uint32_t ones = (uint32_t)(-1);
923 cptrMask.tcpac = ones;
930 DPRINTF(MiscRegs,
"Writing misc reg %s: %#x\n",
935 warn_once(
"The csselr register isn't implemented.\n");
939 warn(
"Calling DC ZVA! Not Implemeted! Expect WEIRD results\n");
944 const uint32_t ones = (uint32_t)(-1);
946 fpscrMask.ioc = ones;
947 fpscrMask.dzc = ones;
948 fpscrMask.ofc = ones;
949 fpscrMask.ufc = ones;
950 fpscrMask.ixc = ones;
951 fpscrMask.idc = ones;
952 fpscrMask.ioe = ones;
953 fpscrMask.dze = ones;
954 fpscrMask.ofe = ones;
955 fpscrMask.ufe = ones;
956 fpscrMask.ixe = ones;
957 fpscrMask.ide = ones;
958 fpscrMask.len = ones;
959 fpscrMask.fz16 = ones;
960 fpscrMask.stride = ones;
961 fpscrMask.rMode = ones;
964 fpscrMask.ahp = ones;
970 newVal = (newVal & (uint32_t)fpscrMask) |
972 ~(uint32_t)fpscrMask);
978 const uint32_t ones = (uint32_t)(-1);
980 fpscrMask.ioc = ones;
981 fpscrMask.dzc = ones;
982 fpscrMask.ofc = ones;
983 fpscrMask.ufc = ones;
984 fpscrMask.ixc = ones;
985 fpscrMask.idc = ones;
991 newVal = (newVal & (uint32_t)fpscrMask) |
993 ~(uint32_t)fpscrMask);
999 const uint32_t ones = (uint32_t)(-1);
1000 FPSCR fpscrMask = 0;
1001 fpscrMask.len = ones;
1002 fpscrMask.fz16 = ones;
1003 fpscrMask.stride = ones;
1004 fpscrMask.rMode = ones;
1005 fpscrMask.fz = ones;
1006 fpscrMask.dn = ones;
1007 fpscrMask.ahp = ones;
1008 newVal = (newVal & (uint32_t)fpscrMask) |
1010 ~(uint32_t)fpscrMask);
1039 const uint32_t fpexcMask = 0x60000000;
1040 newVal = (newVal & fpexcMask) |
1052 const uint32_t ifsrMask =
1054 newVal = newVal & ~ifsrMask;
1060 const uint32_t dfsrMask =
mask(31, 14) |
mask(8, 8);
1061 newVal = newVal & ~dfsrMask;
1071 DPRINTF(MiscRegs,
"Writing AMAIR: %#x\n", newVal);
1080 DPRINTF(MiscRegs,
"Writing SCTLR: %#x\n", newVal);
1091 SCTLR new_sctlr = newVal;
1184 mbits(newVal, 31, 12),
1199 mbits(newVal, 31, 12),
1242 mbits(newVal, 31,12));
1255 mbits(newVal, 31,12));
1271 mbits(newVal, 31,12));
1284 mbits(newVal, 31,12));
1301 static_cast<Addr>(
bits(newVal, 35, 0)) << 12);
1316 static_cast<Addr>(
bits(newVal, 35, 0)) << 12);
1329 mbits(newVal, 31, 12),
1343 mbits(newVal, 31, 12),
1477 static_cast<Addr>(
bits(newVal, 43, 0)) << 12,
1489 static_cast<Addr>(
bits(newVal, 43, 0)) << 12,
1503 static_cast<Addr>(
bits(newVal, 43, 0)) << 12,
1516 static_cast<Addr>(
bits(newVal, 43, 0)) << 12,
1529 bits(newVal, 55, 48);
1532 static_cast<Addr>(bits(newVal, 43, 0)) << 12,
1545 bits(newVal, 55, 48);
1548 static_cast<Addr>(bits(newVal, 43, 0)) << 12,
1561 bits(newVal, 55, 48);
1573 bits(newVal, 55, 48);
1589 static_cast<Addr>(
bits(newVal, 43, 0)) << 12);
1602 static_cast<Addr>(
bits(newVal, 43, 0)) << 12);
1616 static_cast<Addr>(
bits(newVal, 35, 0)) << 12);
1630 static_cast<Addr>(
bits(newVal, 35, 0)) << 12);
1636 warn(
"Not doing anything for write of miscreg ACTLR\n");
1651 newVal &= ~((uint32_t) hstrMask);
1661 if (!secure_lookup) {
1665 newVal = (newVal & ~mask) | (oldValue & mask);
1711 panic(
"Security Extensions required for ATS12NSOPR");
1717 panic(
"Security Extensions required for ATS12NSOPW");
1723 panic(
"Security Extensions required for ATS12NSOUR");
1730 panic(
"Security Extensions required for ATS12NSOUW");
1750 warn(
"Translating via %s in functional mode! Fix Me!\n",
1753 auto req = std::make_shared<Request>(
1758 req, tc, mode, tranType);
1765 Addr paddr = req->getPaddr();
1768 newVal = (paddr &
mask(39, 12)) |
1771 newVal = (paddr & 0xfffff000) |
1775 "MISCREG: Translated addr 0x%08x: PAR: 0x%08x\n",
1781 FSR fsr = armFault->
getFsr(tc);
1783 newVal = ((fsr >> 9) & 1) << 11;
1786 newVal |= ((fsr >> 0) & 0x3f) << 1;
1789 newVal |= ((fsr >> 0) & 0xf) << 1;
1790 newVal |= ((fsr >> 10) & 0x1) << 5;
1791 newVal |= ((fsr >> 12) & 0x1) << 6;
1794 newVal |= ((armFault->
iss() >> 7) & 0x1) << 8;
1795 newVal |= armFault->
isStage2() ? 0x200 : 0;
1797 "MISCREG: Translated addr 0x%08x fault fsr %#x: PAR: 0x%08x\n",
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;
1830 newVal = newVal & ttbcrMask;
1832 newVal = (newVal & ttbcrMask) | (ttbcr & (~ttbcrMask));
1847 uint64_t ttbrMask =
mask(63,56) |
mask(47,40);
1848 newVal = (newVal & (~ttbrMask));
1892 cpsr.daif = (uint8_t) ((CPSR) newVal).
daif;
1909 cpsr.sp = (uint8_t) ((CPSR) newVal).
sp;
1917 cpsr.el = (uint8_t) ((CPSR) newVal).
el;
1928 cpsr.pan = (uint8_t) ((CPSR) newVal).
pan;
1946 RequestPtr req = std::make_shared<Request>();
2011 warn(
"Translating via %s in functional mode! Fix Me!\n",
2022 Addr paddr = req->getPaddr();
2024 uint64_t attr1 = attr >> 56;
2025 if (!attr1 || attr1 ==0x44) {
2027 attr &= ~ uint64_t(0x80);
2029 newVal = (paddr &
mask(47, 12)) | attr;
2031 "MISCREG: Translated addr %#x: PAR_EL1: %#xx\n",
2037 FSR fsr = armFault->
getFsr(tc);
2041 newVal = ((fsr >> 9) & 1) << 11;
2043 newVal |= ((fsr >> 0) & 0x3f) << 1;
2045 newVal |= ((armFault->
iss() >> 7) & 0x1) << 8;
2046 newVal |= armFault->
isStage2() ? 0x200 : 0;
2051 newVal |= armFault->
isStage2() ? 1 << 8 : 0;
2052 newVal |= armFault->
isStage2() ? 1 << 9 : 0;
2056 "MISCREG: Translated addr %#x fault fsr %#x: PAR: %#x\n",
2067 ~(0x5 << 21) : ~(0x7 << 21);
2069 newVal = val & spsr_mask;
2073 warn(
"miscreg L2CTLR (%s) written with %#x. ignored...\n",
2104 return *
timer.get();
2108 if (!generic_timer) {
2109 panic(
"Trying to get a generic timer from a system that hasn't " 2110 "been configured to use a generic timer.\n");
2114 timer->setThreadContext(tc);
2116 return *
timer.get();
2134 "A ThreadContext is needed to determine the SVE vector length " 2135 "in full-system mode");
2149 (el ==
EL0 || el ==
EL1)) {
2152 static_cast<unsigned>(
2161 static_cast<unsigned>(
2165 len = std::min(len,
sveVL - 1);
2167 return (len + 1) * 128;
2173 auto vv = vc.
as<uint64_t>();
2174 for (
int i = 2;
i < eCount; ++
i) {
2185 case EL2: hyp();
break;
2186 case EL3: mon();
break;
2194 ArmISAParams::create()
#define panic(...)
This implements a cprintf based panic() function.
virtual System * getSystemPtr()=0
unsigned sveVL
SVE vector length in quadwords.
bitset< NUM_MISCREG_INFOS > miscRegInfo[NUM_MISCREGS]
BaseISADevice & getGenericTimer(ThreadContext *tc)
decltype(nullptr) constexpr NoFault
virtual void setISA(ISA *isa)
virtual TheISA::Decoder * getDecoderPtr()=0
The file contains the definition of a set of TLB Invalidate Instructions.
Instruction TLB Invalidate All.
This module implements the global system counter and the local per-CPU architected timers as specifie...
bool haveSecurity() const
Returns true if this system implements the Security Extensions.
void clear32(const ArmISAParams *p, const SCTLR &sctlr_rst)
Vector Register Abstraction This generic class is the model in a particularization of MVC...
virtual TheISA::PCState pcState() const =0
virtual RegVal readIntReg(RegIndex reg_idx) const =0
virtual RegVal readMiscReg(int misc_reg)=0
Read a system register belonging to this device.
RegVal readMiscRegNoEffect(int misc_reg) const
std::shared_ptr< Request > RequestPtr
bool havePAN() const
Returns true if Priviledge Access Never is implemented.
Instruction TLB Invalidate by VA.
bool highestELIs64() const
Returns true if the register width of the highest implemented exception level is 64 bits (ARMv8) ...
Base class for devices that use the MiscReg interfaces.
bool FullSystem
The FullSystem variable can be used to determine the current mode of simulation.
void preUnflattenMiscReg()
virtual BaseCPU * getCpuPtr()=0
static std::vector< struct MiscRegLUTEntry > lookUpMiscReg
Metadata table accessible via the value of the register.
virtual FSR getFsr(ThreadContext *tc) const
const char *const miscRegName[]
virtual RegVal readCCReg(RegIndex reg_idx) const =0
void clear64(const ArmISAParams *p)
RegVal readMPIDR(ArmSystem *arm_sys, ThreadContext *tc)
This helper function is either returing the value of MPIDR_EL1 (by calling getMPIDR), or it is issuing a read to VMPIDR_EL2 (as it happens in virtualized systems)
TLB Invalidate by VA, All ASID.
ThreadContext is the external interface to all thread state for anything outside of the CPU...
unsigned getCurSveVecLenInBits(ThreadContext *tc) const
virtual void setThreadContext(ThreadContext *tc)
This master id is used for functional requests that don't come from a particular device.
bool haveSVE() const
Returns true if SVE is implemented (ARMv8)
void setMiscRegNoEffect(int misc_reg, RegVal val)
Data TLB Invalidate by ASID match.
Instruction TLB Invalidate by ASID match.
uint8_t encodePhysAddrRange64(int pa_size)
Returns the encoding corresponding to the specified n.
virtual void startup()
startup() is the final initialization call before simulation.
int unflattenMiscReg(int reg)
void initializeMiscRegMetadata()
const Enums::VecRegRenameMode _vecRegRenameMode
virtual void pcStateNoRecord(const TheISA::PCState &val)=0
RegVal miscRegs[NumMiscRegs]
void initID64(const ArmISAParams *p)
unsigned sveVL() const
Returns the SVE vector length at reset, in quadwords.
BaseGic * getGIC() const
Get a pointer to the system's GIC.
chain highest(ArmSystem *const sys) const
std::pair< int, int > getMiscIndices(int misc_reg) const
bool ELIs32(ThreadContext *tc, ExceptionLevel el)
BaseISADevice & getGICv3CPUInterface(ThreadContext *tc)
unsigned numContexts() const
static const uint32_t CpsrMaskQ
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 void setMiscReg(int misc_reg, RegVal val)=0
Write to a system register belonging to this device.
std::unique_ptr< BaseISADevice > timer
std::unique_ptr< BaseISADevice > gicv3CpuInterface
bool translateFunctional(ThreadContext *tc, Addr vaddr, Addr &paddr)
Do a functional lookup on the TLB (for debugging) and don't modify any internal state.
virtual void setCCReg(RegIndex reg_idx, RegVal val)=0
virtual void setIntReg(RegIndex reg_idx, RegVal val)=0
bool haveVirtualization() const
Returns true if this system implements the virtualization Extensions.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
#define ULL(N)
uint64_t constant
Gicv3CPUInterface * getCPUInterface(int cpu_id) const
VecRegT< VecElem, NumElems, true > as() const
View interposers.
bool haveCrypto() const
Returns true if this system implements the Crypto Extension.
void initID32(const ArmISAParams *p)
virtual bool isStage2() const
TLB Invalidate by ASID match.
void assert32(ThreadContext *tc)
const Params * params() const
virtual uint32_t iss() const =0
DummyISADevice dummyDevice
Dummy device for to handle non-existing ISA devices.
TLB Invalidate All, Non-Secure.
virtual CheckerCPU * getCheckerCpuPtr()=0
uint8_t physAddrRange() const
Returns the supported physical address range in bits.
ExceptionLevel highestEL() const
Returns the highest implemented exception level.
virtual int threadId() const =0
const SimObjectParams * _params
Cached copy of the object parameters.
void setMiscReg(int misc_reg, RegVal val, ThreadContext *tc)
void broadcast(ThreadContext *tc)
Broadcast the TLB Invalidate operation to all TLBs in the Arm system.
virtual ContextID contextId() const =0
BaseInterrupts * getInterruptController(ThreadID tid)
bool haveLSE() const
Returns true if LSE is implemented (ARMv8.1)
GenericTimer * getGenericTimer() const
Get a pointer to the system's generic timer model.
void assert64(ThreadContext *tc)
static const uint32_t FpscrExcMask
void update(ThreadContext *tc)
RegVal readMiscReg(int misc_reg, ThreadContext *tc)
bool inSecureState(ThreadContext *tc)
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 ...
T mbits(T val, int first, int last)
Mask off the given bits in place like bits() but without shifting.
T bits(T val, int first, int last)
Extract the bitfield from position 'first' to 'last' (inclusive) from 'val' and right justify it...
bool haveLargeAsid64() const
Returns true if ASID is 16 bits in AArch64 (ARMv8)
GenericISA::DelaySlotPCState< MachInst > PCState
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
Addr resetAddr() const
Returns the reset address if the highest implemented exception level is 64 bits (ARMv8) ...
virtual RegVal readMiscReg(RegIndex misc_reg)=0
std::shared_ptr< FaultBase > Fault
void updateRegMap(CPSR cpsr)
TLB Invalidate by Intermediate Physical Address.
Data TLB Invalidate by VA.
static void zeroSveVecRegUpperPart(VecRegContainer &vc, unsigned eCount)
static const uint32_t FpscrQcMask
bool haveLPAE() const
Returns true if this system implements the Large Physical Address Extension.
void takeOverFrom(ThreadContext *new_tc, ThreadContext *old_tc) override
unsigned int cacheLineSize() const
Get the cache line size of the system.