41 #ifndef __ARCH_ARM_ISA_HH__ 42 #define __ARCH_ARM_ISA_HH__ 52 #include "debug/Checkpoint.hh" 53 #include "enums/DecoderFlavor.hh" 54 #include "enums/VecRegRenameMode.hh" 58 struct DummyArmISADeviceParams;
82 std::unique_ptr<BaseISADevice>
timer;
122 _reset(0), _res0(0), _res1(0), _raz(0), _rao(0) {}
129 uint64_t
wi()
const {
return _raz |
_rao; }
137 std::bitset<NUM_MISCREG_INFOS> &
info;
166 return implemented(
false);
209 userNonSecureRead(
v);
210 userNonSecureWrite(
v);
224 privNonSecureRead(
v);
225 privNonSecureWrite(
v);
248 privNonSecureRead(
v);
274 chain
hyp(
bool v =
true)
const {
312 chain
mon(
bool v =
true)
const {
316 monNonSecureWrite(
v);
326 monNonSecureWrite(
v);
330 userNonSecureRead(
v);
331 userNonSecureWrite(
v);
334 privNonSecureRead(
v);
335 privNonSecureWrite(
v);
343 monNonSecureWrite(
v);
347 userNonSecureRead(
v);
348 userNonSecureWrite(
v);
349 privNonSecureRead(
v);
350 privNonSecureWrite(
v);
354 monNonSecureWrite(
v);
367 userNonSecureRead(v);
369 privNonSecureRead(v);
377 userNonSecureWrite(v);
379 privNonSecureWrite(v);
383 monNonSecureWrite(v);
390 chain highest(
ArmSystem *
const sys)
const;
392 std::bitset<NUM_MISCREG_INFOS> &
i)
414 if (cpsr.width == 0) {
444 panic(
"Unrecognized mode setting in CPSR.\n");
469 void clear32(
const ArmISAParams *
p,
const SCTLR &sctlr_rst);
470 void clear64(
const ArmISAParams *p);
471 void initID32(
const ArmISAParams *p);
472 void initID64(
const ArmISAParams *p);
509 return intRegMap[
reg];
516 if (!cpsr.sp && el !=
EL0)
528 panic(
"Invalid exception level");
581 warn(
"User mode does not have SPSR\n");
597 warn(
"User mode does not have SPSR\n");
622 warn(
"Trying to access SPSR in an invalid mode: %d\n",
665 if (pmselr.sel == 31)
672 panic(
"Unrecognized misc. register.\n");
677 bool secureReg = haveSecurity && !highestELIs64 &&
680 flat_idx += secureReg ? 2 : 1;
693 int reg_as_int =
static_cast<int>(
reg);
695 reg_as_int += (haveSecurity && !
ns) ? 2 : 1;
705 if (lookUpMiscReg[flat_idx].
lower == 0) {
706 return std::make_pair(flat_idx, 0);
710 bool S = haveSecurity && !highestELIs64 &&
713 int lower = lookUpMiscReg[flat_idx].lower;
714 int upper = lookUpMiscReg[flat_idx].upper;
718 return std::make_pair(lower, upper);
731 DPRINTF(Checkpoint,
"Serializing Arm Misc Registers\n");
738 DPRINTF(Checkpoint,
"Unserializing Arm Misc Registers\n");
757 assert(afterStartup);
758 return gicv3CpuInterface !=
nullptr;
761 Enums::VecRegRenameMode
772 const Params *
params()
const;
781 static Enums::VecRegRenameMode
784 auto arm_isa =
dynamic_cast<const ArmISA::ISA *
>(isa);
786 return arm_isa->vecRegRenameMode();
789 static Enums::VecRegRenameMode
#define panic(...)
This implements a cprintf based panic() function.
const IntRegMap IntRegSvcMap
chain secure(bool v=true) const
std::bitset< NUM_MISCREG_INFOS > & info
unsigned sveVL
SVE vector length in quadwords.
bitset< NUM_MISCREG_INFOS > miscRegInfo[NUM_MISCREGS]
BaseISADevice & getGenericTimer(ThreadContext *tc)
chain allPrivileges(bool v=true) const
const MiscRegLUTEntryInitializer InitReg(uint32_t reg)
chain monNonSecureRead(bool v=true) const
void clear32(const ArmISAParams *p, const SCTLR &sctlr_rst)
chain userSecureRead(bool v=true) const
Vector Register Abstraction This generic class is the model in a particularization of MVC...
struct MiscRegLUTEntry & entry
chain hypE2HWrite(bool v=true) const
const IntRegMap IntReg64Map
RegVal readMiscRegNoEffect(int misc_reg) const
Enums::VecRegRenameMode vecRegRenameMode() const
chain userNonSecureRead(bool v=true) const
static Enums::VecRegRenameMode mode(const ArmISA::PCState &pc)
chain res0(uint64_t mask) const
Base class for devices that use the MiscReg interfaces.
chain privSecure(bool v=true) const
int flattenIntIndex(int reg) const
RegId flattenRegId(const RegId ®Id) const
MiscRegLUTEntryInitializer(struct MiscRegLUTEntry &e, std::bitset< NUM_MISCREG_INFOS > &i)
Dummy device that prints a warning when it is accessed.
static std::vector< struct MiscRegLUTEntry > lookUpMiscReg
Metadata table accessible via the value of the register.
static Enums::VecRegRenameMode init(const BaseISA *isa)
const MiscRegLUTEntryInitializer & chain
chain hypRead(bool v=true) const
void clear64(const ArmISAParams *p)
chain unimplemented() const
bool haveGICv3CpuIfc() const
Returns true if the ISA has a GICv3 cpu interface.
const IntRegMap IntRegHypMap
ThreadContext is the external interface to all thread state for anything outside of the CPU...
unsigned getCurSveVecLenInBits(ThreadContext *tc) const
chain privSecureRead(bool v=true) const
chain reads(bool v) const
chain banked64(bool v=true) const
void setMiscRegNoEffect(int misc_reg, RegVal val)
int flattenCCIndex(int reg) const
chain monE2H(bool v=true) const
int flattenMiscIndex(int reg) const
const RegIndex & elemIndex() const
Elem accessor.
const Enums::DecoderFlavor _decoderFlavor
const IntRegMap IntRegFiqMap
chain banked(bool v=true) const
Vector Register Native Elem lane.
chain hypWrite(bool v=true) const
chain user(bool v=true) const
virtual void startup()
startup() is the final initialization call before simulation.
int flattenVecIndex(int reg) const
int snsBankedIndex64(MiscRegIndex reg, bool ns) const
void initializeMiscRegMetadata()
bool impdefAsNop
If true, accesses to IMPLEMENTATION DEFINED registers are treated as NOP hence not causing UNDEFINED ...
unsigned getCurSveVecLenInBitsAtReset() const
const Enums::VecRegRenameMode _vecRegRenameMode
RegVal miscRegs[NumMiscRegs]
void initID64(const ArmISAParams *p)
chain bankedChild(bool v=true) const
chain monNonSecure(bool v=true) const
static ExceptionLevel opModeToEL(OperatingMode mode)
chain mutex(bool v=true) const
std::pair< int, int > getMiscIndices(int misc_reg) const
BaseISADevice & getGICv3CPUInterface(ThreadContext *tc)
chain privNonSecureRead(bool v=true) const
void unserialize(CheckpointIn &cp) override
Unserialize an object.
const IntRegMap IntRegUndMap
chain hyp(bool v=true) const
int flattenFloatIndex(int reg) const
chain unverifiable(bool v=true) const
chain monNonSecureWrite(bool v=true) const
const IntRegMap IntRegAbtMap
std::unique_ptr< BaseISADevice > timer
std::unique_ptr< BaseISADevice > gicv3CpuInterface
chain priv(bool v=true) const
#define SERIALIZE_ARRAY(member, size)
static int flattenIntRegModeIndex(int reg)
void initID32(const ArmISAParams *p)
const IntRegIndex * intRegMap
chain privNonSecure(bool v=true) const
chain implemented(bool v=true) const
chain userNonSecureWrite(bool v=true) const
void assert32(ThreadContext *tc)
const Params * params() const
chain privRead(bool v=true) const
DummyISADevice dummyDevice
Dummy device for to handle non-existing ISA devices.
chain exceptUserMode() const
#define UNSERIALIZE_ARRAY(member, size)
const IntRegMap IntRegUsrMap
chain nonSecure(bool v=true) const
const IntRegMap IntRegMonMap
chain rao(uint64_t mask) const
static bool equalsInit(const BaseISA *isa1, const BaseISA *isa2)
std::ostream CheckpointOut
chain res1(uint64_t mask) const
chain monSecure(bool v=true) const
const RegClass & classValue() const
Class accessor.
void setMiscReg(int misc_reg, RegVal val, ThreadContext *tc)
Enums::DecoderFlavor decoderFlavor() const
int flattenVecElemIndex(int reg) const
chain monSecureWrite(bool v=true) const
Helper structure to get the vector register mode for a given ISA.
const RegIndex & index() const
Index accessors.
virtual void init()
init() is called after all C++ SimObjects have been created and all ports are connected.
chain privSecureWrite(bool v=true) const
chain raz(uint64_t mask) const
Register ID: describe an architectural register with its class and index.
void assert64(ThreadContext *tc)
chain monE2HWrite(bool v=true) const
void serialize(CheckpointOut &cp) const override
Serialize an object.
chain hypE2H(bool v=true) const
int flattenVecPredIndex(int reg) const
chain warnNotFail(bool v=true) const
RegVal readMiscReg(int misc_reg, ThreadContext *tc)
bool inSecureState(ThreadContext *tc)
chain monSecureRead(bool v=true) const
chain privNonSecureWrite(bool v=true) const
GenericISA::DelaySlotPCState< MachInst > PCState
chain userSecureWrite(bool v=true) const
const IntRegMap IntRegIrqMap
void updateRegMap(CPSR cpsr)
chain hypE2HRead(bool v=true) const
static void zeroSveVecRegUpperPart(VecRegContainer &vc, unsigned eCount)
chain mapsTo(uint32_t l, uint32_t u=0) const
chain monE2HRead(bool v=true) const
chain mon(bool v=true) const
void takeOverFrom(ThreadContext *new_tc, ThreadContext *old_tc) override
chain writes(bool v) const