Go to the documentation of this file.
41 #ifndef __ARCH_ARM_ISA_HH__
42 #define __ARCH_ARM_ISA_HH__
54 #include "debug/Checkpoint.hh"
55 #include "enums/DecoderFlavor.hh"
62 struct DummyArmISADeviceParams;
84 std::unique_ptr<BaseISADevice>
timer;
139 std::bitset<NUM_MISCREG_INFOS> &
info;
551 std::bitset<NUM_MISCREG_INFOS> &
i)
560 const MiscRegLUTEntryInitializer
575 if (cpsr.width == 0) {
605 panic(
"Unrecognized mode setting in CPSR.\n");
617 void clear32(
const ArmISAParams &
p,
const SCTLR &sctlr_rst);
618 void clear64(
const ArmISAParams &
p);
681 }
else if (
reg == int_reg::Spx) {
685 if (!cpsr.sp &&
el !=
EL0)
697 panic(
"Invalid exception level");
750 warn(
"User mode does not have SPSR\n");
766 warn(
"User mode does not have SPSR\n");
791 warn(
"Trying to access SPSR in an invalid mode: %d\n",
834 if (pmselr.sel == 31)
841 panic(
"Unrecognized misc. register.\n");
847 flat_idx += secure_reg ? 2 : 1;
865 int reg_as_int =
static_cast<int>(
reg);
867 reg_as_int += (
release->
has(ArmExtension::SECURITY) && !
ns) ?
880 return std::make_pair(flat_idx, 0);
891 return std::make_pair(lower, upper);
906 template <
typename Elem>
910 static_assert(
sizeof(Elem) <=
sizeof(uint64_t),
911 "Elem type is too large.");
912 eCount *= (
sizeof(uint64_t) /
sizeof(Elem));
913 for (
int i = 16 /
sizeof(Elem);
i < eCount; ++
i) {
928 return new PCState(new_inst_addr);
970 Addr cacheBlockMask)
override;
972 Addr cacheBlockMask)
override;
976 Addr cacheBlockMask)
override;
PCStateBase * newPCState(Addr new_inst_addr=0) const override
chain hypE2HWrite(bool v=true) const
void addressTranslation64(MMU::ArmTranslationType tran_type, BaseMMU::Mode mode, Request::Flags flags, RegVal val)
DummyISADevice dummyDevice
Dummy device for to handle non-existing ISA devices.
static void zeroSveVecRegUpperPart(Elem *v, unsigned eCount)
chain monE2H(bool v=true) const
static SelfDebug * getSelfDebug(ThreadContext *tc)
ExceptionLevel currEL() const
Returns the current Exception Level (EL) of the ISA object.
unsigned getCurSveVecLenInBits() const
chain privNonSecureWrite(bool v=true) const
int flattenIntIndex(int reg) const
std::unique_ptr< BaseISADevice > gicv3CpuInterface
RegVal readMiscRegNoEffect(int misc_reg) const
chain warnNotFail(bool v=true) const
chain mutex(bool v=true) const
@ VecElemClass
Vector Register Native Elem lane.
chain allPrivileges(bool v=true) 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)
bool inUserMode() const override
@ CCRegClass
Condition-code register.
void updateRegMap(CPSR cpsr)
const ArmRelease * release
This could be either a FS or a SE release.
chain privNonSecureRead(bool v=true) const
chain secure(bool v=true) const
chain hypWrite(bool v=true) const
std::unique_ptr< BaseISADevice > timer
chain hypSecureRead(bool v=true) const
std::bitset< NUM_MISCREG_INFOS > & info
int flattenVecPredIndex(int reg) const
chain hypE2HNonSecureWrite(bool v=true) const
chain res0(uint64_t mask) const
chain hypNonSecureRead(bool v=true) const
chain privSecure(bool v=true) const
chain monNonSecureWrite(bool v=true) const
void copyRegsFrom(ThreadContext *src) override
static ExceptionLevel opModeToEL(OperatingMode mode)
unsigned getCurSveVecLenInBitsAtReset() const
void serialize(CheckpointOut &cp) const override
Serialize an object.
unsigned sveVL
SVE vector length in quadwords.
const typedef MiscRegLUTEntryInitializer & chain
chain userSecureWrite(bool v=true) const
chain hypE2HNonSecureRead(bool v=true) const
chain hypE2HSecureWrite(bool v=true) const
chain hypE2H(bool v=true) const
std::bitset< NUM_MISCREG_INFOS > miscRegInfo[NUM_MISCREGS]
chain hypNonSecureWrite(bool v=true) const
chain privRead(bool v=true) const
void setMiscRegNoEffect(int misc_reg, RegVal val)
void initID64(const ArmISAParams &p)
void handleLockedRead(const RequestPtr &req) override
@ FloatRegClass
Floating-point register.
bool has(ArmExtension ext) const
chain unverifiable(bool v=true) const
chain hypSecureWrite(bool v=true) const
chain userNonSecureWrite(bool v=true) const
chain privSecureRead(bool v=true) const
chain writes(bool v) const
chain banked64(bool v=true) const
void handleLockedSnoopHit() override
ThreadContext is the external interface to all thread state for anything outside of the CPU.
void clear64(const ArmISAParams &p)
chain banked(bool v=true) const
chain monSecureWrite(bool v=true) const
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
int snsBankedIndex64(MiscRegIndex reg, bool ns) const
void globalClearExclusive() override
GenericISA::DelaySlotPCState< 4 > PCState
std::pair< int, int > getMiscIndices(int misc_reg) const
void unserialize(CheckpointIn &cp) override
Unserialize an object.
chain mapsTo(uint32_t l, uint32_t u=0) const
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
int flattenVecElemIndex(int reg) const
int flattenVecIndex(int reg) const
bool handleLockedWrite(const RequestPtr &req, Addr cacheBlockMask) override
chain monSecureRead(bool v=true) const
chain nonSecure(bool v=true) const
BaseISADevice & getGICv3CPUInterface()
RegVal readMiscReg(int misc_reg)
chain monNonSecure(bool v=true) const
chain hypSecure(bool v=true) const
void startup() override
startup() is the final initialization call before simulation.
chain hypRead(bool v=true) const
chain bankedChild(bool v=true) const
chain implemented(bool v=true) const
BaseISADevice & getGenericTimer()
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
chain unimplemented() const
enums::DecoderFlavor decoderFlavor() const
void initializeMiscRegMetadata()
RegId flattenRegId(const RegId ®Id) const
chain reads(bool v) const
struct MiscRegLUTEntry & entry
void setupThreadContext()
static std::vector< struct MiscRegLUTEntry > lookUpMiscReg
Metadata table accessible via the value of the register.
@ IntRegClass
Integer register.
const enums::DecoderFlavor _decoderFlavor
int flattenFloatIndex(int reg) const
chain highest(ArmSystem *const sys) const
chain monE2HRead(bool v=true) const
@ MiscRegClass
Control (misc) register.
const MiscRegLUTEntryInitializer InitReg(uint32_t reg)
RegVal miscRegs[NUM_MISCREGS]
Dummy device that prints a warning when it is accessed.
chain exceptUserMode() const
SelfDebug * getSelfDebug() const
static bool inUserMode(CPSR cpsr)
static int flattenIntRegModeIndex(int reg)
The ExecContext is an abstract base class the provides the interface used by the ISA to manipulate th...
MiscRegLUTEntryInitializer(struct MiscRegLUTEntry &e, std::bitset< NUM_MISCREG_INFOS > &i)
void setMiscReg(int misc_reg, RegVal val)
uint64_t getExecutingAsid() const override
chain hypE2HRead(bool v=true) const
std::ostream CheckpointOut
chain monE2HWrite(bool v=true) const
chain monSecure(bool v=true) const
@ 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 ...
constexpr RegIndex index() const
Index accessors.
virtual BaseISA * getIsaPtr() const =0
chain hyp(bool v=true) const
chain userNonSecureRead(bool v=true) const
chain privSecureWrite(bool v=true) const
chain user(bool v=true) const
chain raz(uint64_t mask) const
chain hypE2HSecureRead(bool v=true) const
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
constexpr RegClassType classValue() const
Class accessor.
chain res1(uint64_t mask) const
const ArmRelease * getRelease() const
int flattenCCIndex(int reg) const
chain monNonSecureRead(bool v=true) const
void clear32(const ArmISAParams &p, const SCTLR &sctlr_rst)
chain rao(uint64_t mask) const
bool inSecureState() const
Return true if the PE is in Secure state.
chain privNonSecure(bool v=true) const
bool haveGICv3CpuIfc() const
Returns true if the ISA has a GICv3 cpu interface.
Register ID: describe an architectural register with its class and index.
bool impdefAsNop
If true, accesses to IMPLEMENTATION DEFINED registers are treated as NOP hence not causing UNDEFINED ...
#define panic(...)
This implements a cprintf based panic() function.
Base class for devices that use the MiscReg interfaces.
int flattenMiscIndex(int reg) const
chain userSecureRead(bool v=true) const
Generated on Wed Jul 13 2022 10:39:09 for gem5 by doxygen 1.8.17