Go to the documentation of this file.
42 #include "debug/ArmTme.hh"
47 using namespace ArmISA;
49 namespace ArmISAInst {
56 printMnemonic(
ss,
"",
false);
67 printIntReg(
ss, dest);
85 flags[IsMicroop] =
true;
86 flags[IsReadBarrier] =
true;
87 flags[IsWriteBarrier] =
true;
101 panic(
"tfence should not have memory semantics");
110 panic(
"tfence should not have memory semantics");
128 flags[IsHtmStart] =
true;
129 flags[IsInteger] =
true;
130 flags[IsLoad] =
true;
131 flags[IsMicroop] =
true;
132 flags[IsNonSpeculative] =
true;
139 panic(
"TME is not supported with atomic memory");
157 flags[IsInteger] =
true;
158 flags[IsMicroop] =
true;
166 flags[IsLoad] =
true;
167 flags[IsMicroop] =
true;
168 flags[IsNonSpeculative] =
true;
169 flags[IsHtmCancel] =
true;
176 panic(
"TME is not supported with atomic memory");
197 flags[IsHtmStop] =
true;
198 flags[IsLoad] =
true;
199 flags[IsMicroop] =
true;
200 flags[IsNonSpeculative] =
true;
206 panic(
"TME is not supported with atomic memory");
constexpr decltype(nullptr) NoFault
RegId(StaticInst::*)[] RegIdArrayPtr
Tcommit64(ArmISA::ExtMachInst _machInst)
MacroTmeOp(const char *mnem, ArmISA::ExtMachInst _machInst, OpClass __opClass)
uint8_t _numSrcRegs
See numSrcRegs().
Fault completeAcc(PacketPtr, ExecContext *, Trace::InstRecord *) const
Fault execute(ExecContext *, Trace::InstRecord *) const
void setDestRegIdx(int i, const RegId &val)
std::array< uint8_t, MiscRegClass+1 > _numTypedDestRegs
Fault execute(ExecContext *, Trace::InstRecord *) const
MicroTcommit64(ArmISA::ExtMachInst)
void ccprintf(cp::Print &print)
Fault execute(ExecContext *, Trace::InstRecord *) const
Tstart64(ArmISA::ExtMachInst, RegIndex)
std::shared_ptr< FaultBase > Fault
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
std::string generateDisassembly(Addr pc, const loader::SymbolTable *symtab) const
Internal function to generate disassembly string.
Tcancel64(ArmISA::ExtMachInst, uint64_t)
uint8_t _numDestRegs
See numDestRegs().
std::bitset< Num_Flags > flags
Flag values for this instruction.
void setRegIdxArrays(RegIdArrayPtr src, RegIdArrayPtr dest)
Set the pointers which point to the arrays of source and destination register indices.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
std::string generateDisassembly(Addr pc, const loader::SymbolTable *symtab) const
Internal function to generate disassembly string.
Ttest64(ArmISA::ExtMachInst, RegIndex)
static const OpClass MemReadOp
Base class for predicated macro-operations.
@ IntRegClass
Integer register.
std::string generateDisassembly(Addr pc, const loader::SymbolTable *symtab) const
Internal function to generate disassembly string.
The ExecContext is an abstract base class the provides the interface used by the ISA to manipulate th...
MicroTfence64(ArmISA::ExtMachInst)
Fault initiateAcc(ExecContext *, Trace::InstRecord *) const
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Fault execute(ExecContext *, Trace::InstRecord *) const
Register ID: describe an architectural register with its class and index.
#define panic(...)
This implements a cprintf based panic() function.
Generated on Thu Jun 16 2022 10:41:39 for gem5 by doxygen 1.8.17