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);
90 flags[IsMicroop] =
true;
91 flags[IsReadBarrier] =
true;
92 flags[IsWriteBarrier] =
true;
106 panic(
"tfence should not have memory semantics");
115 panic(
"tfence should not have memory semantics");
138 flags[IsHtmStart] =
true;
139 flags[IsInteger] =
true;
140 flags[IsLoad] =
true;
141 flags[IsMicroop] =
true;
142 flags[IsNonSpeculative] =
true;
149 panic(
"TME is not supported with atomic memory");
172 flags[IsInteger] =
true;
173 flags[IsMicroop] =
true;
186 flags[IsLoad] =
true;
187 flags[IsMicroop] =
true;
188 flags[IsNonSpeculative] =
true;
189 flags[IsHtmCancel] =
true;
196 panic(
"TME is not supported with atomic memory");
227 flags[IsHtmStop] =
true;
228 flags[IsLoad] =
true;
229 flags[IsMicroop] =
true;
230 flags[IsNonSpeculative] =
true;
236 panic(
"TME is not supported with atomic memory");
constexpr decltype(nullptr) NoFault
Tstart64(ArmISA::ExtMachInst, ArmISA::IntRegIndex)
RegId(StaticInst::*)[] RegIdArrayPtr
Tcommit64(ArmISA::ExtMachInst _machInst)
int8_t _numFPDestRegs
The following are used to track physical register usage for machines with separate int & FP reg files...
MacroTmeOp(const char *mnem, ArmISA::ExtMachInst _machInst, OpClass __opClass)
Fault completeAcc(PacketPtr, ExecContext *, Trace::InstRecord *) const
Fault execute(ExecContext *, Trace::InstRecord *) const
void setDestRegIdx(int i, const RegId &val)
Fault execute(ExecContext *, Trace::InstRecord *) const
MicroTcommit64(ArmISA::ExtMachInst)
void ccprintf(cp::Print &print)
Ttest64(ArmISA::ExtMachInst, ArmISA::IntRegIndex)
Fault execute(ExecContext *, Trace::InstRecord *) const
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.
int8_t _numVecElemDestRegs
Tcancel64(ArmISA::ExtMachInst, uint64_t)
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.
static const OpClass MemReadOp
Base class for predicated macro-operations.
std::string generateDisassembly(Addr pc, const loader::SymbolTable *symtab) const
Internal function to generate disassembly string.
int8_t _numDestRegs
See numDestRegs().
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
@ IntRegClass
Integer register.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
int8_t _numSrcRegs
See numSrcRegs().
Fault execute(ExecContext *, Trace::InstRecord *) const
int8_t _numVecDestRegs
To use in architectures with vector register file.
Register ID: describe an architectural register with its class and index.
#define panic(...)
This implements a cprintf based panic() function.
Generated on Wed Jul 28 2021 12:10:21 for gem5 by doxygen 1.8.17