38 #ifndef __ARCH_ARM_INSTS_SVE_HH__ 39 #define __ARCH_ARM_INSTS_SVE_HH__ 64 int8_t _imm1, int8_t _imm2) :
66 dest(_dest), imm1(_imm1), imm2(_imm2)
68 std::string generateDisassembly(
82 dest(_dest), imm1(_imm1), op2(_op2)
84 std::string generateDisassembly(
98 dest(_dest), op1(_op1), imm2(_imm2)
100 std::string generateDisassembly(
114 dest(_dest), op1(_op1), op2(_op2)
116 std::string generateDisassembly(
130 bool _srcIs32b =
false,
bool _destIsVec =
false) :
132 dest(_dest), gp(_gp),
133 srcIs32b(_srcIs32b), destIsVec(_destIsVec)
135 std::string generateDisassembly(
150 dest(_dest), op1(_op1), gp(_gp)
152 std::string generateDisassembly(
166 dest(_dest), op1(_op1), op2(_op2), srcIs32b(_srcIs32b)
168 std::string generateDisassembly(
182 std::string generateDisassembly(
194 dest(_dest), op1(_op1), gp(_gp)
197 std::string generateDisassembly(
209 dest(_dest), op1(_op1)
212 std::string generateDisassembly(
226 dest(_dest), imm(_imm)
229 std::string generateDisassembly(
246 dest(_dest), imm(_imm), gp(_gp), isMerging(_isMerging)
249 std::string generateDisassembly(
263 dest(_dest), op1(_op1), imm(_imm)
266 std::string generateDisassembly(
279 dest(_dest), gp(_gp), imm(_imm)
282 std::string generateDisassembly(
296 dest(_dest), imm(_imm)
299 std::string generateDisassembly(
312 dest(_dest), op2(_op2), gp(_gp)
315 std::string generateDisassembly(
330 dest(_dest), op1(_op1), op2(_op2), gp(_gp), predType(_predType)
333 std::string generateDisassembly(
345 dest(_dest), op1(_op1), op2(_op2)
348 std::string generateDisassembly(
362 dest(_dest), op1(_op1), op2(_op2), index(_index)
365 std::string generateDisassembly(
379 dest(_dest), op1(_op1), op2(_op2), gp(_gp), isSel(_isSel)
382 std::string generateDisassembly(
395 dest(_dest), op1(_op1), op2(_op2)
398 std::string generateDisassembly(
411 dest(_dest), gp(_gp), op1(_op1), op2(_op2)
414 std::string generateDisassembly(
428 dest(_dest), gp(_gp), op1(_op1), imm(_imm)
431 std::string generateDisassembly(
444 dest(_dest), op1(_op1), op2(_op2), gp(_gp)
447 std::string generateDisassembly(
461 dest(_dest), op2(_op2), imm(_imm)
464 std::string generateDisassembly(
476 dest(_dest), op1(_op1), gp(_gp)
479 std::string generateDisassembly(
491 dest(_dest), op1(_op1), gp(_gp)
494 std::string generateDisassembly(
505 OpClass __opClass,
IntRegIndex _dest, uint8_t _imm) :
507 dest(_dest), imm(_imm)
510 std::string generateDisassembly(
526 dest(_dest), op1(_op1), op2(_op2), gp(_gp), op2IsWide(_op2IsWide)
528 std::string generateDisassembly(
544 dest(_dest), op1(_op1), imm(_imm), gp(_gp)
546 std::string generateDisassembly(
556 SveAdrOffsetUnpackedUnsigned
569 dest(_dest), op1(_op1), op2(_op2), mult(_mult),
570 offsetFormat(_offsetFormat)
572 std::string generateDisassembly(
588 bool _dstIsVec,
bool _dstIs32b) :
590 dest(_dest), pattern(_pattern), imm(_imm), dstIsVec(_dstIsVec),
593 std::string generateDisassembly(
609 dest(_dest), gp(_gp), op1(_op1), isMerging(_isMerging)
611 std::string generateDisassembly(
627 dest(_dest), op1(_op1), op2(_op2), gp(_gp)
629 std::string generateDisassembly(
647 bool _conditional,
bool _scalar,
650 dest(_dest), op1(_op1), gp(_gp), conditional(_conditional),
651 scalar(_scalar), simdFp(_simdFp)
653 std::string generateDisassembly(
668 dest(_dest), op1(_op1), gp(_gp)
670 std::string generateDisassembly(
684 dest(_dest), op1(_op1), op2(_op2)
686 std::string generateDisassembly(
699 dest(_dest), op1(_op1)
701 std::string generateDisassembly(
716 std::string generateDisassembly(
730 std::string generateDisassembly(
746 std::string generateDisassembly(
760 std::string generateDisassembly(
771 std::string generateDisassembly(
786 dest(_dest), op1(_op1), imm(_imm)
788 std::string generateDisassembly(
802 dest(_dest), op1(_op1), imm(_imm)
805 std::string generateDisassembly(
819 dest(_dest), op1(_op1), simdFp(_simdFp)
822 std::string generateDisassembly(
838 dest(_dest), op1(_op1), op2(_op2), imm(_imm)
841 std::string generateDisassembly(
856 dest(_dest), op1(_op1), op2(_op2)
859 std::string generateDisassembly(
874 dest(_dest), op1(_op1), op2(_op2), gp(_gp), rot(_rot)
877 std::string generateDisassembly(
892 dest(_dest), op1(_op1), op2(_op2), rot(_rot), imm(_imm)
895 std::string generateDisassembly(
931 #endif // __ARCH_ARM_INSTS_SVE_HH__
Ternary with immediate, destructive, unpredicated SVE instruction.
Ternary, destructive, predicated (merging) SVE instruction.
SveAdrOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _op2, uint8_t _mult, SveAdrOffsetFormat _offsetFormat)
SvePtrueOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, uint8_t _imm)
SVE dot product instruction (vectors)
SveTerPredOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _op2, IntRegIndex _gp)
Compare and terminate loop SVE instruction.
SveIndexIROp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, int8_t _imm1, IntRegIndex _op2)
Unary unpredicated scalar to vector instruction.
Unary, constructive, predicated (merging) SVE instruction.
SVE unary predicate instructions with implicit destination operand.
Partition break with propagation SVE instruction.
SVE unpack and widen predicate.
Binary with immediate, destructive, unpredicated SVE instruction.
While predicate generation SVE instruction.
SVE compare instructions, predicated (zeroing).
Scalar element select SVE instruction.
SveTblOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _op2)
SveBinConstrPredOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _op2, IntRegIndex _gp, SvePredType _predType)
SVE Complex Instructions (indexed)
SveComplexOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _op2, IntRegIndex _gp, uint8_t _rot)
SVE compare-with-immediate instructions, predicated (zeroing).
uint64_t sveExpandFpImmMul(uint8_t imm, uint8_t size)
Expand 1-bit floating-point immediate to 0.5 or 2.0 (FMUL).
SveUnaryPredOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _gp)
SvePredUnaryWImplicitDstOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _op1)
SveReducOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _gp)
unsigned int sveDecodePredCount(uint8_t imm, unsigned int num_elems)
Returns the actual number of elements active for PTRUE(S) instructions.
Unary with wide immediate, constructive, predicated SVE instruction.
SveWImplicitSrcDstOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass)
SveBinDestrPredOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op2, IntRegIndex _gp)
SveIndexRIOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, int8_t _imm2)
Index generation instruction, immediate operands.
Element count SVE instruction.
SveComplexIdxOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _op2, uint8_t _rot, uint8_t _imm)
SveDotProdOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _op2)
Integer compare SVE instruction.
SvePartBrkPropOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _op2, IntRegIndex _gp)
SveIntCmpOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _op2, IntRegIndex _gp, bool _op2IsWide=false)
SVE Complex Instructions (vectors)
Partition break SVE instruction.
uint64_t sveExpandFpImmMaxMin(uint8_t imm, uint8_t size)
Expand 1-bit floating-point immediate to 0.0 or 1.0 (FMAX, FMAXNM, FMIN, FMINNM). ...
SveBinWideImmUnpredOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, uint64_t _imm)
SveUnaryWideImmUnpredOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, uint64_t _imm)
SVE dot product instruction (indexed)
SvePartBrkOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _gp, IntRegIndex _op1, bool _isMerging)
SveBinIdxUnpredOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _op2, uint8_t _index)
SveSelectOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _gp, bool _conditional, bool _scalar, bool _simdFp)
SveUnarySca2VecUnpredOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, bool _simdFp)
SveAdrOffsetFormat offsetFormat
Predicate logical instruction.
Binary with immediate index, destructive, unpredicated SVE instruction.
SveIntCmpImmOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, int64_t _imm, IntRegIndex _gp)
std::string sveDisasmPredCountImm(uint8_t imm)
Returns the symbolic name associated with pattern imm for PTRUE(S) instructions.
Integer compare with immediate SVE instruction.
SVE vector - immediate binary operation.
SveIndexIIOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, int8_t _imm1, int8_t _imm2)
SveBinImmPredOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, uint64_t _imm, IntRegIndex _gp)
Unary with wide immediate, constructive, unpredicated SVE instruction.
SvePredTestOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _op1, IntRegIndex _gp)
SveBinImmUnpredConstrOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, uint64_t _imm)
uint64_t sveExpandFpImmAddSub(uint8_t imm, uint8_t size)
Expand 1-bit floating-point immediate to 0.5 or 1.0 (FADD, FSUB, FSUBR).
SvePredUnaryWImplicitSrcOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest)
Unary, constructive, unpredicated SVE instruction.
SvePredLogicalOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _op2, IntRegIndex _gp, bool _isSel=false)
Binary, constructive, predicated SVE instruction.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
SveDotProdIdxOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _op2, uint64_t _imm)
SveUnaryWideImmPredOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, uint64_t _imm, IntRegIndex _gp, bool _isMerging)
SvePredBinPermOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _op2)
SvePredCountOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _gp, bool _srcIs32b=false, bool _destIsVec=false)
SveUnpackOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1)
Binary with immediate, destructive, predicated (merging) SVE instruction.
SVE unary predicate instructions with implicit source operand.
Predicate binary permute instruction.
SveElemCountOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, uint8_t _pattern, uint8_t _imm, bool _dstIsVec, bool _dstIs32b)
SveOrdReducOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _gp)
Binary, unpredicated SVE instruction with indexed operand.
SveUnaryUnpredOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1)
SveBinUnpredOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _op2)
SVE unary predicate instructions with implicit destination operand.
SveBinImmUnpredDestrOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, uint64_t _imm)
SVE unary operation on predicate (predicated)
SveUnaryPredPredOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _gp)
SVE unary predicate instructions, predicated, with implicit source operand.
Binary, unpredicated SVE instruction.
SveCmpOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _op2, IntRegIndex _gp)
SveCmpImmOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, uint64_t _imm, IntRegIndex _gp)
TheISA::ExtMachInst ExtMachInst
Binary extended machine instruction type.
Binary, destructive, predicated (merging) SVE instruction.
SveIndexRROp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _op2)
SveTerImmUnpredOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op2, uint64_t _imm)
SveCompTermOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _op1, IntRegIndex _op2)
SVE table lookup/permute using vector of element indices (TBL)
const char * svePredTypeToStr(SvePredType pt)
Returns the specifier for the predication type pt as a string.
Binary with wide immediate, destructive, unpredicated SVE instruction.
SvePredUnaryWImplicitSrcPredOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _gp)
SvePredCountPredOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _gp)
SveWhileOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, IntRegIndex _op2, bool _srcIs32b)
tlm::tlm_generic_payload gp
SveBinImmIdxUnpredOp(const char *mnem, ExtMachInst _machInst, OpClass __opClass, IntRegIndex _dest, IntRegIndex _op1, uint64_t _imm)